FPGA之旅

以FPGA为主导,分享一些FPGA知识,同时还会介绍51,32,arm linux编程语言,Qt等其他知识。

FPGA驱动VGA显示屏

0
阅读(894)

一. 简介


本例是FPGA之旅设计的第十七例,本例将介绍如何使用FPGA来驱动VGA显示器,并且显示彩条,为后面的图像显示做好准备。


二. VGA简介


实物图如下,之前的显示器,一般都是VGA接口。现在可能都是HDMI接口的了,但也会转到VGA接口上弄,比较比较方便,因此掌握VGA时序是非常重要的


image.png



VGA接口原理图如下,信号接口可以分为三大类

image.png



VGA_HSYNC(1bit):行同步信号,FPGA输出,默认为高电平,每一行显示之前,都要将其拉低,一定的周期,用于同步。


VGA_VSYNC(1bit):帧同步信号,FPGA输出,默认为高电平,每一帧图像显示之前,都要将其拉低,一定的周期,用于同步。


Color(RGB)(16/24bit):显示数据,FPGA输出,根据外部电路不同,可以有16bit RGB565 ,和 24bit RGB888,这两种常见的电路。


行同步时序如下


image.png



帧同步时序如下


image.png



每幅图中,都标注出了五个关键点,以及下面的参数,就可以开始编写VGA驱动了。


image.png



每个部分持续的周期数,都在表中给出来了,根据选择的显示模式,确定行帧的周期数。

这里我选择的是第一种640*480@60的模式。



三. Verilog代码编写

1

定义各状态的时间参数

根据表格定义好,即可。另外输入的时钟要是25Mhz

image.png


2

行列计数

行计数器每计满一个周期,列计数器加一。


在计数器小于各种的同步周期内时,将各自的同步信号拉低即可。

image.png





3

数据使能输出

在行列都在有效数据阶段的时候,进行数据输出,其他时间输出零。


image.png


至此就完成了一个简单的VGA显示了。效果如下

image.png

关注公众号FPGA之旅获取更多


回复FPGA之旅设计99例之第十七例获取驱动代码

原文链接:https://mp.weixin.qq.com/s/HFHb4kDVQe3cm93JKnVb5A

微信截图_20220708161426.png

电子技术应用专栏作家 FPGA之旅


Baidu
map