基于FPGA的条纹显示设计与实现论文.doc

上传人:文库蛋蛋多 文档编号:3938480 上传时间:2023-03-28 格式:DOC 页数:9 大小:4.30MB
返回 下载 相关 举报
基于FPGA的条纹显示设计与实现论文.doc_第1页
第1页 / 共9页
基于FPGA的条纹显示设计与实现论文.doc_第2页
第2页 / 共9页
基于FPGA的条纹显示设计与实现论文.doc_第3页
第3页 / 共9页
基于FPGA的条纹显示设计与实现论文.doc_第4页
第4页 / 共9页
基于FPGA的条纹显示设计与实现论文.doc_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《基于FPGA的条纹显示设计与实现论文.doc》由会员分享,可在线阅读,更多相关《基于FPGA的条纹显示设计与实现论文.doc(9页珍藏版)》请在三一办公上搜索。

1、基于FPGA的条纹显示设计与实现1 FPGA介绍FPGA(Field Programmable Gate Array,现场可编程门阵列),它是在PAL、GAL、CPLD等可编程器件的基础上进一步发展的产物。它是作为ASIC(Application Specific Integrated Circuit,专用集成电路)领域中的一种半定制电路而出现的,既解决了定制电路的不足,又克服了原有可编程器件门电路数有限的缺点。1.1 工作原理FPGA采用了逻辑单元阵列LCA(Logic Cell Array)这样一个概念,内部包括可配置逻辑模块CLB(Configurable Logic Block)、输出

2、输入模块IOB(Input Output Block)和内部连线(Interconnect)三个部分。 现场可编程门阵列(FPGA)是可编程器件,与传统逻辑电路和门阵列(如PAL,GAL及CPLD器件)相比,FPGA具有不同的结构。FPGA利用小型查找表(161RAM)来实现组合逻辑,每个查找表连接到一个D触发器的输入端,触发器再来驱动其他逻辑电路或驱动I/O,由此构成了既可实现组合逻辑功能又可实现时序逻辑功能的基本逻辑单元模块,这些模块间利用金属连线互相连接或连接到I/O模块。FPGA的逻辑是通过向内部静态存储单元加载编程数据来实现的,存储在存储器单元中的值决定了逻辑单元的逻辑功能以及各模块

3、之间或模块与I/O间的联接方式,并最终决定了FPGA所能实现的功能,FPGA允许无限次的编程。1.2 基本特点1)采用FPGA设计ASIC电路(专用集成电路),用户不需要投片生产,就能得到合用的芯片。2)FPGA可做其它全定制或半定制ASIC电路的中试样片。3)FPGA内部有丰富的触发器和I/O引脚。4)FPGA是ASIC电路中设计周期最短、开发费用最低、风险最小的器件之一。5) FPGA采用高速CMOS工艺,功耗低,可以与CMOS、TTL电平兼容。可以说,FPGA芯片是小批量系统提高系统集成度、可靠性的最佳选择之一。FPGA是由存放在片内RAM中的程序来设置其工作状态的,因此,工作时需要对片

4、内的RAM进行编程。用户可以根据不同的配置模式,采用不同的编程方式。加电时,FPGA芯片将EPROM中数据读入片内编程RAM中,配置完成后,FPGA进入工作状态。掉电后,FPGA恢复成白片,内部逻辑关系消失,因此,FPGA能够反复使用。FPGA的编程无须专用的FPGA编程器,只须用通用的EPROM、PROM编程器即可。当需要修改FPGA功能时,只需换一片EPROM即可。这样,同一片FPGA,不同的编程数据,可以产生不同的电路功能。因此,FPGA的使用非常灵活。2 VGA介绍VGA(Video Graphics Array)是IBM在1987年随PS/2机一起推出的一种视频传输标准,具有分辨率高

5、、显示速率快、颜色丰富等优点,在彩色显示器领域得到了广泛的应用。VGA(Video Graphics Array,视频图像阵列)接口是一种D型接口,上面共有15针孔,分成三排,没排五个。其中,除了2根NC(Not Connect)信号、3根显示数据总线和5个GND信号,比较重要的是3根RGB彩色分量信号和2根扫描同步信号HSYNC和VSYNC针。VGA接口中彩色分量采用RS343电平标准。RS343电平标准的峰峰值电压为1V。VGA接口是显卡上应用最为广泛的接口类型,多数的显卡都带有此种接口。现行的VGA接口设计都用于CRT显示器,用于计算机的输出设备。主要端口说明如表2.1所示。表2.1 主

6、要端口说明端口功能OSC_50输入,时钟信息RST_n输入,复位信号,低电平有效SW输入,电键选择VGA_CLK输出,VGA工作时钟,由OSC_50二分频产生VGA_HS输出,VGA行频率输入信号VGA_VS输出,VGA场频率输入信号VGA_BLANK输出,VGA复合空白对照输入信号,高电平时有效VGA_SYNC输出,VGA同步信号,低电平有效VGA_R输出,VGA红色信号输入信号,10位VGA_G输出,VGA绿色信号输入信号,10位VGA_B输出,VGA蓝色信号输入信号,10位工作原理通用VGA显示卡系统主要由控制电路、显示缓存区和视频BIOS(Basic Input Output Syst

7、em即基本输入输出系统)程序三个部分组成。控制电路主要完成时序发生、显示缓冲区数据操作、主时钟选择和D/A(Digital to Analog即将数字信号转换为模拟信号)转换等功能;显示缓冲区提供显示数据缓存空间;视频BIOS作为控制程序固化在显示卡的ROM(Read-Only Memory即只读存储器)中。要实现VGA显示就要解决数据来源、数据存储、时序实现等问题,其中关键还是如何实现VGA时序。VGA的标准参考显示时序如图2所示。行时序和帧时序都需要产生同步脉冲(Sync a)、显示后沿(Back porch b)、显示时序段(Display interval c)和显示前沿(Front

8、porch d)四个部分。VGA显示采用逐行扫描方式。扫描是从屏幕的左上方开始,从左到右,从上到下。每扫完一行,电子束回到左边下一行的开始位置。期间对电子束进行行消隐。并在每行结束时,用行同步信号对行进行同步,扫描完所有行后,再用场同步信号对场进行同步,并使电子束回到屏幕的左上方,同时对场进行消隐,并预备下一次扫描。行扫描从每一行的左边开始,采用的时钟为25MHz,每一个时钟周期,对应该行上的一个像素点。从左到右的扫描过程中,包括行消隐、行图像输出两个过程,每完成一次从左到右的行扫描,则显示一行的像素点。行扫描时序如图2.1所示。图2.1 VGA行扫描时序场扫描从屏幕最上端一行开始,从上到下进

9、行扫描。每行扫描完成一次时,以场扫描的溢出信号作为时钟,每一个时钟周期,对应屏幕上的一行。场扫描的过程,包括场消隐、场图像输出两个过程,每完成一次从上到下的场扫描过程,则完成一帧图像的输出。3 软硬件开发概述3.1 DE2开发板本次设计使用的是Altera公司的DE2开发板,如图3.1所示。图3.1 DE2开发板在本次设计中,所用实验室资源DE2板(EP2C35F672C6)除了将其数据线与所用电脑主机相连外,还需用9V电源,否则DE2板无法工作。DE2开发板是以Cyclone II 2C35FPGA为特点的672针引脚的包装。板上所有重要的部件都与板上的芯片相连,使用户能够控制板上各种的操作

10、。DE2板包括了很多开关(兼有拨动开关和按键),发光二极管和七段数码管。需要进行处理器和I/O接口实验时,也有标准MIC、line-in、line-out接口(24位音频解编码器),video-in(TV Decoder)和VGA(10-bit DAC);DE2还提供了USB2.0接口(包括主、从USB),10/100M自适应以太网,红外(IRDA)接口,以及SD卡接口。DE2以Cyclone II FPGA为核心芯片,可自由选择存储卡以及一些高级的I/O口驱动,对各类数字系统的实现来说是一个理想的平台,它还有音频、视频、网络和存储设备。对以Altera Nios II为处理器的嵌入式应用中也

11、是一个理想工具。DE2开发板的资源非常丰富,主要器件接口有:FPGA;I/O驱动;存储设备;开关,发光二极管,液晶和晶振;超强多媒体。本系统选用的是Altera公司的Cyclone II系列的EP2C35F672C6芯片,此系列芯片不但具有高性能、高密度和非常大的灵活性,还具有改进的结构、先进的处理技术、现代化的开发工具以及多个宏功能模块可选用等优点。Cyclone II系列的EP2C35F672C6芯片,它具有672个引脚,其中475个I/O通信口。同时还有33216个逻辑单元、105M4K RAM、35个乘法器以及4个同步逻辑器。由于Cyclone II系列芯片有高性能、高密度和非常大的灵

12、活性,所以采用该芯片可以很好的实现设计功能。3.2 Quartus II的使用Quartus II 开发流程如图3.2所示。图3.2 Quartus II 开发流程框图本次设计用的是实验室资源Quartus II 9.1版本。本设计中的软件设计是基于硬件描述语言Verilog HDL编程语言。它是一种以文本形式来描述数字系统硬件的结构和行为的语言,用它可以表示逻辑电路图、逻辑表达式,还可以表示数字逻辑系统所完成的逻辑功能。Verilog HDL是在用途最广泛的C语言的基础上发展起来的一种硬件描述语言,它简单、规范,描述硬件单元的结构单元的结构简单且易读。4 设计实现本次设计采用VGA的工作标准

13、(64048060Hz)模式,对应的时钟频率(Clock Frequency)为25.175MHz(像素输出频率);行频(Line Frequency)为31946Hz;场频(Field Frequency)为59.94Hz(每秒图像刷新频率),设计VGA显示控制器时,并需要严格遵循“VGA工业标准”,否则会损坏VGA显示器。4.1 硬件结构系统的硬件电路在Altera公司的DE2开发板上完成,实现FPGA对VGA显示器的控制。本系统由FPGA最小系统、D/A转换模块、显示接口模块组成,从而实现对行场信号的控制。其结构如图4.1所示。图4.1 硬件结构设计示意图本系统用到的有:一块FPGA核心

14、板,板上有CycloneII EP2C35F672芯片以及外围电路;D/A转换电路;VGA接口电路。通过计算机编程,将图像数据与时序信号一同下载进入FPGA,经过FPGA的处理,再通过D/A转换电路,完成数字信号向模拟信号的转换,最后由VGA接口输出,在显示器上显示图像。本系统结构简单、设计方便,从而实现显示条纹的功能。待添加的隐藏文字内容34.2 设计原理图本设计使用640480的分辨率,VGA电路原理如图4.2所示。图4.2 VGA电路原理图DE2开发板包括一个15针的VGA输出的D-SUB连接器。在VGA同步信号提供直接的Cyclone II器件和模拟器件ADV7123三重10位高速视频

15、DAC是用来产生模拟数据信号(红色,绿色和蓝色)。其中包括8个输入信号,它们是:红、绿、蓝三种颜色信号输入VGA_R0:9、VGA_G0:9、VGA_B0:9 ,复合空白对照输入信号VGA_BLANK,复合同步控制输入VGA_SYNC,输入时钟VGA_CLOCK,以及行场频率输入信号VGA_HS、VGA_VS11。这些电路组合能最高支持16001200100MHz的分辨率。4.3 VGA编程设计VGA图像控制器是一个较大的数字系统。本设计显示图像时采用模块化设计原则和自顶向下的设计思想,进行功能分离并按层次设计。将Verilog硬件描述语言设计与原理图设计相结合,逐一对每个功能模块进行仿真,使

16、顶层VGA图像控制器的模块实体仿真综合得以顺利通过。VGA控制器主要由以下模块组成:消隐模块,显示模块,汉字显示模块,图像控制模块等。本设计的目标是:运用Verilog HDL实现通过VGA接口使图形和文字在显示器上的显示。本设计总体代码流程如图4.3所示。图4.3 设计代码编写总体框图VGA工作时钟频率为25MHz,但系统只能提供OSC为50MHz的频率,故需通过二分频来满足VGA工作时钟要求。本设计利用Quartus II 自带的宏功能锁相环PLL产生分频器,并在顶层模块例化。设置输入时钟50MHz,输出25 MHz,得到时钟可例化.v文件、图形文件等。打开产生的.bsf文件,有图4.4。

17、图4.4 VGA工作时钟的产生编写VGA行频率程序,场频率程序,和有效显示标志位产生程序。VGA行频率程序如下:always(posedge CLK_to_DAC or negedge RST_n)begin if(!RST_n)begin H_Cont = 0; VGA_HS = 0; X = 0; end else begin if(H_ContH_TOTAL) H_Cont = H_Cont+1b1; else H_Cont = 1b0; /判断行计数器是否小于H_TOTAL,若是则加一,否则为0 /Horizontal Sync if(H_Cont=H_FRONT-1) /Front

18、porch end VGA_HS = 1b0; /判断显示前沿是否结束,若是则行频率置0 if(H_Cont=H_FRONT+H_SYNC-1) /Sync pulse end VGA_HS =H_BLANK) X = H_Cont-H_BLANK;/判断横坐标是否大于消隐值,若大于则根据等式赋值给X,否则置0 else X = 0; endend 显示条纹时,设置了一个复位键,四个电建SW0、SW1、SW2、SW3,四个电建优先有效由高到低。当按下复位键时,显示器为白色背景;当SW0有效时,显示器显示的条纹颜色从上到下依次为红绿蓝;当SW1有效时,显示器显示的条纹颜色依次为白绿蓝;当SW2有

19、效时,显示器显示的条纹颜色依次为黄白蓝;当SW3有效时,显示器显示的条文颜色依次为红绿白。4.4 下载验证打开Quartus II 9.1,建立一个工程,将设计(Verilog HDL)输入,之后选择芯片类型(EP2C35F672C6),综合、布局布线、调试、时序分析、仿真,引脚配置,再综合调试仿真等,最后下载到开发板上验证。DE2板上的VGA接口连接到显示器上,测试结果会在显示器上显示。当按下电键SW0时,显示器上的显示(红绿蓝条纹)如图4.5所示。图4.5 电键SW0有效时出现红绿蓝条纹当按下电键SW2时,显示器上的显示(黄白蓝条纹)如图4.6。图4.6电键SW2有效时出现黄白蓝条纹5 总

20、结和展望本设计针对通过FPGA控制VGA的显示,实现不同颜色条纹的显示,研究并实现了基于FPGA的VGA接口设计软硬件总体结构设计。硬件平台选用Altera公司的Cyclone II 系列EP2C35F672C6芯片可编程逻辑器件,利用ADV7123实现了数模转换,通过硬件描述语言Verilog HDL对VGA行、场扫描时序,利用Quartus II 9.1软件自带的宏功能模块得到VGA需用时钟,并实现整个设计的编译、仿真、测试,实现了在显示器上输出条纹的设计目的。基于FPGA的VGA接口设计涉及到多个软硬件结合使用,其发展应用还有很长的路要走。随着FPGA的不断发展及其价格的不断下降,FPGA的可编程逻辑设计的应用优势逐渐显现出来,现在越来越多的嵌入式系统选择了基于FPGA的设计方案。VGA设计应用于图像处理、视频信号再现、数据可视化分析等方面也越来越有优势。之前有同学建议显示国旗,也就是显示图像信息,这可以利用开发板上带有的存储器资源如SDRAM、Flash等来存储图像,值得继续研究。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号