NIOS2随笔——JPEG图片的UART传输显示

简介:

1. 系统概述

本设计采用NIOS2 32位处理器,通过SPI接口将SD/TF卡中的JPEG图片数据读取到内存中,SD/TF卡的文件系统为FAT32,NIOS2软件实现将JPEG图片通过UART串口发送给上位机显示,系统框图如下:

wKioL1j63TTihq4wAADsDtyTL_k224.png


2. UART介绍

UART(Universal Asynchronous Receiver/Transmitter)是一种异步收发传输器,工作原理是将传输数据的每个字符一位接一位地传输。

UART在空闲时为逻辑1状态,其各位的的意义如下:

  • 起始位:先发出一个逻辑”0”的信号,表示传输字符的开始。

  • 资料位:紧接着起始位之后。资料位的个数一般为8,构成一个字符。通常采用ASCII码,从最低位开始传送,靠时钟定位。

  • 奇偶校验位:资料位加上这一位后,使得1的位数应为偶数(偶校验)或奇数(奇校验)。

  • 停止位:一个字符数据的结束标志,可以是1位、1.5位、2位的高电平。 由于数据是在传输线上定时的,并且每一个设备有其自己的时钟,很可能在通信中两台设备间出现了小小的不同步。因此需要多于1位的高电平时间,提供计算机校正时钟同步的机会。


3. 搭建QSYS系统

这里主要是添加UART组件,如下图所示:

wKiom1jnrMPzj9L2AACDBB2PwPY808.jpg

wKiom1jnqzqj_AYHAAEnNguCXSE408.jpg


4. 驱动软件设计
驱动代码,负责将SD中的JPEG图片读取到内存中,然后通过UART发送给上位机显示。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
unsigned  char  desk[54171];
 
int  main ( void )
{
     int  i;
     FILE * fp;
     fp =  fopen  ( "/dev/uart_0" "w" );
     while (1)
     {
         for (i=0;i<54171;i++)
         {
             if  (fp!=NULL)
             {
                 fprintf (fp,  "%c" ,desk[i]);
             }
         }
     }
     fclose (fp);
     return  0;
}


5. 最终结果

编译运行软件后,打开上位机DEMO软件,设置串口波特率为115200,打开串口后,图片正确显示。

wKiom1jnroaxumgEAAQgTRDa4UM901.png


本文转自 shugenyin 51CTO博客,原文链接:http://blog.51cto.com/shugenyin/1914015


相关文章
|
Android开发 异构计算
nios ii FIFO读取FPGA数据交互实验1
nios ii FIFO读取FPGA数据交互实验1
269 0
nios ii FIFO读取FPGA数据交互实验1
|
Android开发 C++ 芯片
nios ii小实验——第一个demo指导书
nios ii小实验——第一个demo指导书
209 0
nios ii小实验——第一个demo指导书
|
异构计算
nios ii小实验——SDRAM读写
nios ii小实验——SDRAM读写
260 0
nios ii小实验——SDRAM读写
|
编解码 Linux
Linux MIPI DSI驱动调试笔记-设备树DCS格式序列之配置LCD初始化代码(二)
Linux MIPI DSI驱动调试笔记-设备树DCS格式序列之配置LCD初始化代码(二)
1496 0
|
前端开发 内存技术
DSP(css)开发代码掉电保存下载到flash
DSP(css)开发代码掉电保存下载到flash
117 0
移植mjpg_streamer使其支持拍照功能
移植mjpg_streamer使其支持拍照功能
92 0
|
API 计算机视觉
V4L2抓取USB摄像头YUV视频数据代码
V4L2抓取USB摄像头YUV视频数据代码
298 0