利用可编程器件 CPLD/FPGA 实现 VGA 彩色显示控制器在工业现场中有许多实际应用。以硬件描述语言 VHDL 对可编程器件进行功能模块设计、仿真综合,可实现 VGA 显示控制器显示各种图形、图像、文字,并实现了动画效果。
VGA 接口及设计参数
VGA 接口是与显示器进行通信的唯一接口。通过 CPLD/FPGA 器件对 RGB 信号、行同步信号、场同步信号等信号的控制,并参照有关标准,可以实现对 VGA 显示器的控制。由此可见,了解接口标准,控制时序和设定恰当的参数是系统设计的关键。
参照 VGA 主要参数的工业标准,像素输出频率为 25.175MHz;行频(线频率)为 31.469KHz;场频(刷新率)为 59.94Hz. 参数设计原理以及行同步信号(Ts)与显示信号(Tdis)的关系如图 1 所示。
VGA 图像控制器的设计方案
VGA 图像控制器是一个较大的数字系统。采用模块化设计原则,借鉴自顶而下的程序设计思想,进行功能分离并按层次设计。将 VHDL 硬件描述语言设计与原理图设计相结合,逐一对每个功能模块进行仿真,使顶层 VGA 图像控制器的模块实体仿真综合得以顺利通过。VGA 控制器主要由以下模块组成:消隐模块,显示模块,分频模块,网格生成模块,汉字显示模块,图像控制模块,动画生成模块,LPM-ROM 调用模块,EEPROM 调用模块等。功能模块的 VHDL 设计如下。
消隐模块
消隐模块是整个显示控制器的关键部分,显示模块、汉字模块、彩条模块、网格模块、动画控制模块、LPM-ROM 调用模块等都由消隐模块控制,并且行同步信号(HS)和场同步信号(VS)都由该模块产生。
图 2 是消隐模块的仿真结果。由于 CLK 频率相当高,像素速率也很高,为了观察 HS、VS 信号,适当缩小了波形比例。其中, C[9……0]为像素坐标值,L[8……0]为扫描线信号,也就是像素的横坐标。
显示模块
显示模块是整个显示控制器的重要组成部分。各个模块的输出数据都要经过该模块处理后送到显示器。显示模块在 VGA 显示控制器中起着至关重要的作用。
显示模块的 VHDL 设计如下:
显示模块仿真波形如图 3 所示。
GRBP 为三原色数据信号,由模式控制模块产生;行同步信号 HS 由消隐模块产生;场同步信号 VS 由消隐模块产生。输出的 R、G、B 信号分别为红色、绿色、蓝色信号。
显示模块的输出信号直接连到 VGA 接口,它是控制器与显示器进行通信的桥梁。该模块以 VHDL 语言实现,该模块中的结构体描述一共只用了 6 条语句。而要实现同样的功能,一般操作系统的视频卡驱动程序需要冗长的代码去描述。由此可见,VHDL 语言具有很大的优越性。
汉字生成模块
汉字生成模块可实现在显示器上显示汉字、字符等。字模信息可以利用字模提取软件来获得,得到了汉字的字模信息后,可以通过屏幕上的横坐标和纵坐标按照字模信息定义像素的颜色,这样就可以显示任何字体、任何点阵的汉字,并根据需要决定汉字在屏幕上的位置。至于英文以及其他任何符号的显示原理与汉字显示的原理一样。
网格生成模块
网格生成模块用来编辑各种图形。网格生成模块的实现原理与汉字生成模块、彩条发生器类似,在像素的横坐标和纵坐标控制下,实现各种网格图形的生成。网格生成模块所产生的九种图形送显示器依次显示,所以可以看到网格由小到大逐渐变化,虽然不是动画效果,但每秒一帧画面的速度依然使图像连续变化呈现出动感。网格以及背景的颜色也可以随意设置。每帧图像的速率可由时钟来控制。
网格生成模块的主要功能是编辑各种图形,因此本模块可以按照设计方案生成各种各样的图形。网格的选择是一种比较简单的图像编辑,该部分虽然名为网格生成模块,但实际上可以编辑出多种彩色图像。
LPM-ROM 调用模块
LPM 是参数可设置模块库。本设计中调用了三个 LPM-ROM,其中两个用来存放汉字信息,另一个用来存放动态彩条信息。调用 LPM-ROM 模块,一个重要的问题就是*.mif 文件的生成。这里文件生成借助字模提取软件和 WORD 编辑功能。设置好参数后,生成元件作为自定义元件库中的元件以供调用。
LPM-ROM 调用模块为不使用外挂 ROM 而建立字库提供了条件,直接调用 LPM 模块,可以大大提高效率。通过 LPM-ROM 可以在显示器上显示汉字、字符等。
EEPROM 调用模块
EEPROM 调用模块是设计的难点之一。该模块实现了对系统外挂的两个 EEPROM(W27E040 和 W27C020)的访问,通过该模块可以使显示器显示各种各样的彩色图像。
图像模式控制模块图像模式控制模块也是该数字系统的关键部分,它的主体部分是一个功能齐全的数据选择器(32 选 1)。
该模块由一个 32 选 1 数据选择器和一个 32 进制可逆计数器组成。可逆计数器控制端为 EC、DIR、CLR,MD 为计数时钟信号。计数结果(即对应一种模式)是数据选择器进行选择的依据,通过对可逆计数器的控制,可以实现对模式选择的控制。
图像控制模块共产生了 32 种模式,由计数器实现了对模式的有效控制。其实图像控制模块功能还可以进一步扩展。计数器输出为 8 比特,实际共有 255 种模式,在输入的 32 个信号中,可以将它们其中的任意几个进行再处理,如叠加、异或(棋盘格生成就是横彩条与竖彩条的异或而实现的)、相与等等,这样就可以产生成千上万种图形的输出。
VGA 控制器中的十余个模块都采用 VHDL 语言实现,每个模块在功能仿真无误后生成元件,放入元件库中,由顶层原理图调用各个模块(元件)。VGA 图像控制器整体设计经过调试,通过了 MAX+PLUSⅡ的功能仿真、时序仿真以及硬件仿真综合,在 VGA 显示器上实现了所设计的各种功能。
结语
利用可编程逻辑器件可以很方便地实现数字系统设计,基于 CPLD/FPGA 器件的 VGA 控制器可以实现显示器的实时显示。该系统性能高低取决于系统设计方案,硬件描述语言设计以及开发工具的性能。