当前位置: 首页 > 编程学习 > 其它语言 > Verilog > 正文

基于FPGA的Uart接收图像数据至VGA显示

2018-04-23 来源:博客园/NingHeChuan

系统框图

前面我们设计了基于FPGA的静态图片显示,并对一幅彩色图片提取了灰度,学习了RGB转Gray算法。这是基于一幅静态图片的,那么后面我们要怎么模拟一下一幅动态图片的显示,最终对动态数据进行滤波、边缘检测等算法,下来我们首先来建立一个基于FPGA的动态图片显示基础框架,本实验内容为:由PC端上位机软件通过串口发送一幅图像数据至FPGA,FPGA内部将图像数据存储,最后扫描到VGA屏幕上显示。

从系统框图上我们可以看到,可以划分为三个部分进行设计,一个是串口接收部分,然后是RAM数据存储部分,最后是VGA驱动显示部分。这里串口接收部分只需要用到串口接收代码,代码很多书上都有,我这里就不贴出来了,

数据存储部分需要使用的是双口RAM IP Core,一端将数据写入RAM中,一端将数据读出来用VGA显示,下面是基于Vivado的双口RAM IP Core调用方法。

打开IP Catalog,选择block memory Generater

这里按如图所示选择,我这里将写使能信号去掉,wea也可以代表写使能

设置写数据位宽和深度,使能选择always enable

设置读数据参数

这里因为我们是往RAM里面写数据,所以这里不需要添加初始化RAM文件

点击OK