《基于FPGA的大屏幕LED单色图文显示屏控制系统.docx》由会员分享,可在线阅读,更多相关《基于FPGA的大屏幕LED单色图文显示屏控制系统.docx(6页珍藏版)》请在第一文库网上搜索。
1、基于FPGA的大屏幕1ED单色图文显示屏控制系统目前,市场上的中小规模3显示系统,一般采用传统的里左机作为主控芯片。对1ED大屏幕显示屏来说,由于数据传输量大,要求扫描速度快,而单片机内部的资源较少、运行速度较慢,难于满足系统要求。以FPGA作为控制造,一方面,器GA采用软件编程实现硬件功能,速度较快;另一方面,它的引脚资源丰富,可扩展性强。因此,用单片FPGA和简单的外围电路就可以实现大屏幕1ED显示屏的控制,无需另外设计汉字库,具有集成度高、稳定性好、设计灵活和效率高等优点。1系统总体结构1ED大屏幕显示系统由上位机(PC机)、单片机系统、FPGA控制器、1ED显示屏的行列驱动电路等模块组
2、成,如图1所示。上位机负责汉字、字符等数据的采集与发送。单片机系统与上位机之间以异步串行通信工作方式,通过串行选旦从上位机获得已完成格式转换的待显示的图形点阵数据,并将其存入EEPRoM存储器。之后通过FPGA控制器,将存储器的显示数据还原到1ED显示屏。扫描控捌也壁采用可编程逻辑芯片CyCIoneEP1C6,利用VHD1语言编程实现,采用1/16扫描方式,刷新频率在60HZ以上。本文着重介绍256X1024的单色图文显示屏的FPGA控制模块。上位机Pc)图1系统整体木构框图单片机系统21ED显示屏基本工作原理对大屏幕1ED显示屏来说,列显示数据通常采用的是串行传输方式,行采用1/16的扫描方
3、式。图2为16X32点阵屏单元模块的基本结构,列驱动电路采用4个74HC595级联而成。在移位脉冲SRC1K的作用下,串行数据从74HC595的数据端口SER一位一位地输入,当一行的所有32列数据传送完后,输出锁存值旻RC1K并选通行信号YO,则第1行的各列数据就可按要求显示。按同样的方法显示其余各行,当16行数据扫描一遍(即完成一个周期)后,再从第1行开始下一个周期的扫描。只要扫描的周期小于20ms,显示屏就不闪烁。RC1KSRC1RSRC1K第I行Cr0).74HC59574HC59574HC59574HC595!I1111IIII11IHIIIIIHiiiiT16x32点阵屏列显示数据(
4、SER)第2行(Y1I第16fi(Y15)J38216*32点阵屏基茶话构框图256X1024大屏幕显示屏由16X32个的16X32点阵屏级联而成。为了缩短控制系统到屏体的信号传输时间,将显示数据分为16个区,每个区由16X1024点阵组成,每行数据为1024/8=128字节,显示屏的像素信号由1ED显示屏的右侧向左侧传输移位,把16个分区的数据存在同一块存储器。一屏的显示数据为32KB,要准确读出16个分区的数据,其存储器的读地址由16位组成,由于数据只有32KB,因此最高可置为0。其余15位地址从高到低依次为:行地址(4位)、列地址(7位)、分区地址(4位)。4位分区地址的译码信号(Y0Y
5、15)作为锁存器的锁存脉冲,在16个读地址发生周期内,依次将第116分区的第1字节数据锁存到相应的锁存器,然后在移位锁存信号上升沿将该16字节数据同时锁存入16个8位并转串移位蜜立番组中。在下一个16个读地址发生四周期,一方面,并转串移位寄存器将8位数据移位串行输出,移位时钟为读地址发生时钟的二分频;另一方面,依次将16个分区的第2字节数据读出并锁入相应的锁存器,按照这种规律将所有分区的第一行数据依次全部读出后,在数据有效脉冲信号的上升沿将所有串行移位数据输出,驱动1ED显示。接下来,移位输出第2行的数据,在此期间第1行保持显示;第2行全部移入后,驱动第2行显示,同时移入第3行按照这种各分区分
6、行扫描的方式完成整个1ED大屏幕的扫描显示。IMaUIbRAMi1SRaK3电路图3FPGA控制模块整架构框图译码器读地址发生器移位寄存器组数据锁存器组3基于FPGA显示屏控制器的设计3.1FPGA控制模块总体方案如图3所示,FPGA控制模块主要由单片机与FPGA接且及数据读写模块、读地址发生器、译码器、行地址发生器、数据锁存器组、移位寄存器组、脉冲发生器等模块组成。读地址发生器主要产生读地址信号,地址信号送往侬接口及数据读写模块,读取外部S幽1或SRAM2中已处理好的1ED显示屏数据,并把数据按分区方式送到数据锁存器组锁存。锁存器输出16分区数据,通过移位寄存器组实现并串转换得到显示屏所需要
7、的串行数据,并送往1ED显示屏列驱动电路。脉冲发生器为各模块提供相应的同步时钟,行地址发生器产生相应的行信号送往显示屏的行驱动电路。3.2单片机与FPGA接口及数据读写模块单片机与FPGA接口及数据读写模块结构如图4所示。单片机从EEPROM中读取数据并根据显示要求进行处理后,通过接口及数据读写模块把数据送往数据缓冲器SRAMI或SRAM2。为提高数据的传输速度,保证显示效果的连续性,在系统中采用双体切换技术来完成数据存储过程。也就是说,采用双SRAM存储结构,两套完全独立的读、写地址线和数据线轮流切换进行读写。工作时,FPGA在一个特定的时间只从两块SRAM中的一块读取显示的数据进行显示,同
8、时另外一块SRAM与MCU进行数据交换。MCU会写入新的数据,依次交替工作,可实现左移、上移、双屏等显示模式。如果显示的内容不改变,即一块SRAM里的数据不变时,MCU不需要给另外一块SRAM写数据。JWR/FSRAM1;ADt15.汗VR1EEjD17一0DINP.0V*VJ二二二二.ADDRJVRn5单用I1MTGA接口及数据读写模块ADDRD0UT7.Q/READENDAD215.0J1wE27.0ISRAM2I图4单片机与FpGA接口及数加唉写结构模块橇身该模块采用VHD1有限状态机来实现,整个控制分为4个状态,其状态转换图如图5所示。其工作过程如下:系统开机进入初始状态STO,单片机
9、的写入使能端E为低电平,单片机从EEPROM中读取数据并把数据写入到SRAM1同时FPGA读取SRAM2中的数据;当单片机数据写完一屏数据后E变为高电平,当FPGA从SRAM2中读完数据、结束信号READEND为低电平时,进入ST1状态。E0E1STOE=O图5数据读写状态转换困在ST1状态下,若没有新的数据写入则E保持高电平,FPGA读取SRAM1的数据,为静态显示;只有当单片机的读入控制信号E为低电平且READ_END为低电平时,进入ST2状态。在ST2状态下,单片机把数据写入SRAM2,由时FPGA读取SRAM1的数据,单片机数据写完后E变为高电平,当FPGA一屏数据读完后READ_EN
10、D为低电平,进入ST3状态。在ST3状态下,如果没有新数据写入E为高电辛,FPGA读取SRAM2中的数据。当单片机有新的数据写入时E变为低电平,当FPGA一屏数据读完后READEND为低电平时,重新进入STO状态。通过这种周而复始的交替工作完成数据的写入与读取,其端口程序如下:entityWritereaD-SE1isPORT(REST1INSTD.1OGICIC1K1INSTD.1ICjEsINSTt11OG1G单片机写人行记WR1INSTD.1IC一单片机写控制信号DDR.WRJNSTD1OGIQVECTOR。5DoWNTOO八一雌片机写地址信号ADDR-RD:INSTD.1IC.VECT
11、OR(15DoWNTO0);一读地址信号DINJNSTDJoG1C_VECTOR(7DOWNTO0)一单片机写入数据READENDJNSTD,OG1C;-谈一屏数据结束标记D1,D2,BUFFERSTD,1OGIC.VECTOR(7DOWNTO0)-SRAM数据AD),AD2,OUTSTD_1OG1jVECTOR(15DOWNTO0)一SRAM地址wri.wr2,outStdjogic1SRAM的写控制信号OE1.OE2:OUTSTD_1OGIC;-SRAM的读控制信号DOUT1OUTSTD_1OGIC,EeTORqDOWNTO0)橘山牧拉ENDENTITYWRITEREAD.SE13.3读地
12、址发生器读地址发生器主要产生外部缓存器SRAM1(SRAM2)的读地址信号,使系统能正确地从存储器中读取相应的显示数据。其地址最高位为0,其余地址分别为行地址(hang3.0)、列地址(1ie6.0)、分区地址(qu3.0)15位有效地址信号。在16个脉冲周期内读出在SRAM1(SRAM2)中的16字节数据,其部分VHD1源程序如下:读地址时钟信号一清零及使能控制信号屏数据读完信号RDC1K1INSTD.1OGIC;C1R,ADDR_EN:【NSTD_1OGIC,READ_END:OUTSTD.1OGIC;ADDR.RDsOUTSTD_1OGIC_VECTORU5DOWNTO0),生的读写地址
13、符号ENDENTITYaddress;3.4译码器译码器模块主要是产生16路的分区信号(低电平有效)分别控制16个锁存器,把16个分区的显示数据分别锁存在相应的锁存器中。3. 5数据锁存器组及移位寄存器组模块数据锁存器组模块由16个8位锁存器组成锁存器组,锁存16个分区的数据。移位寄存器组模块由16个8位移位寄存器组成,把各路锁存器中8位并行数据转换成同时输出的16路串行数据,驱动1ED显示屏,实现数据的并串转换。其生成的元件符号如图6所示。其中,DATAIN7.0为每个分区的8位并行数据输入,SC1K为移位时钟,C1R为清零信号,1OAD为数据锁存信号,CS15.0为16分区的输入信号(接译
14、码器的输出),DATA_O1JTItwCshiftUdZA,IN7.0RC1KT15.0为16路的串行数据输出。SC1KDATA_OUT(15.,0C1R1OADCS15.0JinstSI6并予#换兀件符号图4. 6脉冲发生器系统采用1/16的扫描方式,把数据分为16分区,16分区数据同时传送。假设刷新的频率为60Hz(即周期为16.67ms),每一行显示的时间约为16.67ms16=1.04ms0每行有1024位,则移位脉冲周期为1.04/1024=1.02s,即移位频率为0.983MHZ以上才能满足要求。由于移位脉冲是数据读取模块时钟的2分频,因此系统的时钟至少197MHZ以上,本系统采用
15、50MHz时钟源。其时序图如图7所示。I816rdc1kJ-1-1.,1,11,_J-1Sc1k|r-I,-rs1OAD;1JDArA-X产夕Z1%n7时钟产生时呼/其中,R匹1K为FPGA读取数据时钟;SC1K是串行输出的移位时钟,是RDC1K的2分频;1OAD是数据锁存信号,每次读完16个分区中的某个字节数据DATA后产生锁存信号,数据锁存在数据锁存器组中,其时钟是RDC1K的16分频。5. FPGA控制模块的仿真测试在Q1IarUISn5.1中建立一个工程,并建立原理图文件,把单片机与FPGA接口及数据读写模块、读地址发生器、译码器、行地址发生器、数据锁存器、移位寄存器、脉冲发生器等单元模块所生的模块元件符号连接起来,构成总控制模块逻辑图并对其功能仿真。仿真结果如图8所示,从存储器中读取16字节数据,经并串转换输出16路的串行数据。从波形图分析,功能正确,且各输出端口信号均符合时序要求。FPGA是在线可编程芯片,可以根据不同的用户要求进行不同的编程,缩