FPGA VGA时序的理解

最近在做FPGA毕业设计,毕业设计规划的是摄像头采集图像,经过均值滤波,中值滤波,高斯滤波,然后通过VGA接口控制显示器显示出来,所以最近学习了一下FPGA的VGA驱动的相关内容。

VGA接口

如上图所示,VGA接口一共15针,分为3*5。

主要使用的信号线是上面的5根线,行同步信号,场同步信号和R,G,B基色的模拟信号。

显示器扫描方式分为逐行扫描和隔行扫描:逐行扫描是扫描从屏幕左上角一点开始,从左像右逐点扫描,每扫描完一行,电子束回到屏幕的左边下一行的起始位置,在这期间,CRT对电子束进行消隐,每行结束时,用行同步信号进行同步;当扫描完所有的行,形成一帧,用场同步信号进行场同步,并使扫描回到屏幕左上方,同时进行场消隐,开始下一帧。隔行扫描是指电子束扫描时每隔一行扫一线,完成一屏后在返回来扫描剩下的线,隔行扫描的显示器闪烁的厉害,会让使用者的眼睛疲劳。

VGA水平扫描时序

VGA垂直扫描时序

VGA时序图

如上图VGA显示时序所示,VGA每次显示都需要同步信号,经过同步脉冲a,显示后沿b,显示时序段c,显示前沿d,然后是同步脉冲a,这样一个循环。

根据VGA协议标准,以640*480 60HZ为例,每秒钟要显示60次,一次显示800*525个点,其中640*480为显示时序段的有效点,其他的是为了同步时序的无效点。

如下图所示黄色区域为800个点的行周期,红色区域为525个点的场周期,只有行周期和场周期同时有效的橘色区域640*480才是有效显示区域。

VGA时序分析

一秒钟需要显示800*525*60个点,而时序的时钟频率是25MHZ,所以显示一个点的时间是25M/(800*525*60)=40ns.

行时序如上图所示:

a段的持续时间是96*40ns

b段的持续时间是45*40ns

c段的持续时间是646*40ns

d段的持续时间是13*40ns

e段的持续时间是800*40ns(e段是整个行周期)

场时序如上图所示:

o段的持续时间是2*e

p段的持续时间是30*e

q段的持续时间是484*e

r段的持续时间是9*e

S段的持续时间是528*e

只有行时序处于c段和场时序处于q段的时候发送的才是有效数据,一个行周期要显示640个点,一个场周期要显示480个行。

代码如下,代码只实现了VGA时序,时钟默认25MHZ。需要进一步修改。

  1. module vga_driver(
  2. clk         ,
  3. rst_n       ,
  4. din         ,
  5. vga_hys     ,
  6. vga_vys     ,
  7. vga_rgb
  8. );
  9. parameter       DATA_W  = 16;
  10. input         clk      ;
  11. input         rst_n    ;
  12. input         din      ;
  13. output        vga_hys    ;
  14. output        vga_vys    ;
  15. output [DATA_W-1:0]  vga_rgb    ;
  16. reg             vga_hys;
  17. reg             vga_vys;
  18. reg     [DATA_W-1:0]    vga_rgb;
  19. reg     [9:0]   cnt_hys;
  20. reg     [9:0]   cnt_vys;
  21. wire            add_cnt_hys;
  22. wire            end_cnt_hys;
  23. wire            add_cnt_vys;
  24. wire            end_cnt_vys;
  25. reg             display_area;
  26. always @(posedge clk or negedge rst_n)begin
  27. if(!rst_n)begin
  28. cnt_hys <= 0;
  29. end
  30. else if(add_cnt_hys)begin
  31. if(end_cnt_hys)
  32. cnt_hys <= 0;
  33. else
  34. cnt_hys <= cnt_hys + 1;
  35. end
  36. end
  37. assign add_cnt_hys = 1;
  38. assign end_cnt_hys = add_cnt_hys && cnt_hys== 800-1;
  39. always @(posedge clk or negedge rst_n)begin
  40. if(!rst_n)begin
  41. cnt_vys <= 0;
  42. end
  43. else if(add_cnt_vys)begin
  44. if(end_cnt_vys)
  45. cnt_vys <= 0;
  46. else
  47. cnt_vys <= cnt_vys + 1;
  48. end
  49. end
  50. assign add_cnt_vys = end_cnt_hys;
  51. assign end_cnt_vys = add_cnt_vys && cnt_vys==525-1 ;
  52. always  @(posedge clk or negedge rst_n)begin
  53. if(rst_n==1‘b0)begin
  54. vga_hys <= 0;
  55. end
  56. else if(add_cnt_hys && cnt_hys == 96-1)begin
  57. vga_hys <= 1;
  58. end
  59. else if(end_cnt_hys)begin
  60. vga_hys <= 0;
  61. end
  62. end
  63. always  @(posedge clk or negedge rst_n)begin
  64. if(rst_n==1‘b0)begin
  65. vga_vys <= 0;
  66. end
  67. else if(add_cnt_vys && cnt_vys == 2-1)begin
  68. vga_vys <= 1;
  69. end
  70. else if(end_cnt_vys)begin
  71. vga_vys <= 0;
  72. end
  73. end
  74. always  @(*)begin
  75. display_area = cnt_hys >= 141 && cnt_hys <= (141+646) && cnt_vys >= 32 && cnt_vys < (32+484);
  76. end
  77. always  @(posedge clk or negedge rst_n)begin
  78. if(rst_n==1‘b0)begin
  79. vga_rgb <= 0;
  80. end
  81. else if(display_area)
  82. begin
  83. vga_rgb <= din;
  84. end
  85. else begin
  86. vga_rgb <= 0;
  87. end
  88. end
  89. endmodule

原文地址:https://www.cnblogs.com/Librarian/p/10066774.html

时间: 2024-11-06 15:54:03

FPGA VGA时序的理解的相关文章

VGA时序

原文链接:[笔记]VGA时序及其原理 显示器扫描方式分为逐行扫描和隔行扫描:逐行扫描是扫描从屏幕左上角一点开始,从左像右逐点扫描,每扫描完一行,电子束回到屏幕的左边下一行的起始位置,在这期间,CRT对电子束进行消隐,每行结束时,用行同步信号进行同步:当扫描完所有的行,形成一帧,用场同步信号进行场同步,并使扫描回到屏幕左上方,同时进行场消隐,开始下一帧.隔行扫描是指电子束扫描时每隔一行扫一线,完成一屏后在返回来扫描剩下的线,隔行扫描的显示器闪烁的厉害,会让使用者的眼睛疲劳. 完成一行扫描的时间称为

(转)FPGA异步时序和多时钟模块

http://bbs.ednchina.com/BLOG_ARTICLE_3019907.HTM   第六章   时钟域 有一个有趣的现象,众多数字设计特别是与FPGA设计相关的教科书都特别强调整个设计最好采用唯一的时钟域.换句话说,只有一个独立的网络可以驱动一个设计中所有触发器的时钟端口.虽然这样可以简化时序分析以及减少很多与多时钟域有关的问题,但是由于FPG**外各种系统限制,只使用一个时钟常常又不现实.FPGA时常需要在两个不同时钟频率系统之间交换数据,在系统之间通过多I/O接口接收和发送

FPGA时序分析的一些理解

最开始看的一些资料,大家其实讲得都差不多,但是我却看得云里雾里的,应该是还没真正理解这个东西. 今天心血来潮又把 <七天玩转ALTREA之时序篇>拿出来看了看,应该有些豁然开朗的感觉,在下实属愚笨,想透彻理解一个东西太慢. 首先看一下寄存器到寄存器的路径,如图1: data arrive time:数据到达REG2.D的时刻.进行时序分析时,setup 和hold时间分析时的data arrive time的计算公式都是一样的 关于data arrive time的理解要基于第一个寄存器REG

FPGA 提高 时序的方法

解决FPGA时序问题的八大忠告 忠告一..如果时序差的不多,在1NS以内,可以通过修改综合,布局布线选项来搞定,如果差的多,就得动代码. 忠告二.看下时序报告,挑一个时序最紧的路径,仔细看看是什么原因导致,先看逻辑级数是多少?是哪种电路有问题,乘法器 或者还是RAM接口数据 先弄清楚哪儿的问题 忠告三.搞时序优化的话 插入寄存器是王道 但也要看具体情况 不一定都得插寄存器,插入寄存器效果不明显的话,先检查一下寄存器插入的位置,如果寄存器不是在关键路径的中间插入而是在某一端的话,确实不大明显 忠告

对FPGA的时钟资源理解(更新中)

7系列FPGA中包含了多达24个CMT(时钟管理单元),MMCM和PLL均为时钟综合器,对外部输入时钟.内部时钟进行处理,生成需要的低抖动时钟.PLL是MMCM的功能子集,也是基于MMCM的.其中MMCM包含的额外特性有: 输入多路复用器从IBUFG,BUFG,BUFR,BUFH,GTs(CLKIN only)或互连(不推荐)中选择其一 作为参考和反馈时钟,每个时钟输入都经过一个可编程的计数器(D).相位频率检测器(PFD)比较输入(参考)时钟和反馈时钟的上升边缘的相位和频率.如果最小的高/低脉

VGA时序驱动模块

`timescale 1ns/1ps module VGA_Driver #(parameter   IMAGE_X = 1056, IMAGE_Y = 628,             H_FRONT = 40, H_BACK  = 88, HSYNC_L = 128, V_FRONT = 1, V_BACK  = 23, VSYNC_L = 4, DATAWIDTH = 8, OUTPUT_REG = 0 ) ( input          clk, input          rst_

基于FPGA的VGA可移植模块终极设计【转】

本文转载自:http://www.cnblogs.com/lueguo/p/3373643.html 略过天涯 基于FPGA的VGA可移植模块终极设计 一.VGA的诱惑 首先,VGA的驱动,这事,一般的单片机是办不到的:由于FPGA的速度,以及并行的优势,加上可现场配置的优势,VGA的配置,只有俺们FPGA可以胜任,也只有FPGA可以随心所欲地配置(当然ARM也可以,应用比较高吧). 初学者就是喜欢看炫的效果,往往会忍不住想玩.尤其玩FPGA的,没玩VGA就感到跟单片机没啥提升,因此VGA的驱动

FPGA设计——VGA (Altera)

1. VGA概述 VGA(Video Graphics Array)是IBM在1987年推出的一种视频传输,具有分辨率高.显示速率快.颜色丰富等优点,在彩色显示器领域得到了广泛的应用.不支持热插拔,不支持音频传输. 2. VGA时序 下面以640*[email protected]为例说明VGA时序和FPGA设计,其他分辨率和帧率的可参考VESA中查找. 计算像素时钟pclk = 800*525*60 = 25200000,注意这里的HSYNC和VSYNC都是低电平有效,且HSYNC在数据行无效

FPGA静态时序分析——IO口时序(Input Delay /output Delay)(转载)

转载地址:http://www.cnblogs.com/linjie-swust/archive/2012/03/01/FPGA.html 1.1  概述 在高速系统中FPGA时序约束不止包括内部时钟约束,还应包括完整的IO时序约束和时序例外约束才能实现PCB板级的时序收敛.因此,FPGA时序约束中IO口时序约束也是一个重点.只有约束正确才能在高速情况下保证FPGA和外部器件通信正确. 1.2  FPGA整体概念 由于IO口时序约束分析是针对于电路板整个系统进行时序分析,所以FPGA需要作为一个