首页 > 嵌入式软件 > Uc/os II

引言

LED大屏幕显示屏是当今室外平面显示的主流,其控制系统的技术发展也日趋成熟,控制系统按数据传输方式分为两类:同步显示和异步显示。同步显示控制系统即LED显示屏和视频数据源实时保持一致,视频信号实时变化。异步显示控制系统通过USB、通用串行接口、以太网等数据通信方式,更新大屏幕控制系统的视频数据存储区。数据更新由上位机控制,LED显示屏的视频信息变化由视频数据存储区的数据决定。在异步显示系统中,可实现将显示屏分为若干区域,不同的区域对应不同的存储区,数据更新时可以只更新其中的一个或几个窗口。本设计采用嵌入式操作系统μC/OS-II的多线程控制方式,分别控制各个窗口的数据区域,实现单屏幕多窗口的任意位置显示,使得显示方式更加灵活方便。

1 系统总体设计

采用SOPC技术在FPGA上构建Nios II软核作为LED显示控制系统的处理器,实现32位的嵌入式系统操作。通过基于μC/OS-II的嵌入式操作系统的软件设计,完成对DVI视频显示数据的接收和预处理。扫描电路接收视频数据后进行存储,同时将数据进行再组织并送往扫描屏。

1.1 系统硬件结构

多窗口显示屏控制系统的结构框图如图1所示。

计算机显卡数据通过DVI接口将数据传送给显示屏控制系统的解码电路部分,DVI解码芯片将获得的视频数据解码,得到RGB视频数据和控制信号。控制信号中包含行扫描信号和场扫描信号,显示屏控制系统根据场扫描信号判断采集1帧视频数据是否结束,并将视频数据写入发送系统的数据存储器RAM进行缓存。FPGA从RAM存储器中读取数据,将该数据按照灰度级分为8个区域模块进行重新组织、转换,然后通过移位串行时钟送入LED显示屏进行显示。本系统的数据处理模块、数据存储模块、扫描控制模块3部分均在FPGA上实现。

本文引用地址: http://www.21ic.com/embed/software/ucos/201806/62932.html

1.2 软件总体设计

全彩色LED大屏幕数据量大,本设计将显示屏从逻辑上划分为多个窗口,软件部分基于μC/OS-II嵌入式操作系统编程实现。μC/OS-II操作系统的任务调度算法比较先进,在显示系统中,可以将每个窗口的显示操作都交给某个任务来执行,这样可以从很大程度上提高整个系统的运行速度和软件的可靠性。

软件基于Nios II IDE开发完成,应用程序基于μC/OS-II实时操作系统实现。软件主要由2个任务和1个定时器中断服务程序组成,任务间采用信号量的方式进行通信。计算机系统的显卡数据经DVI解码模块解码后得到RGB视频数据。任务1接收RGB视频信息,并对视频信息进行滤波、数据的位组合、数据存储区的重新组合等处理操作。任务2从内存中读取数据,并进行分析处理,把分析处理完的数据送往扫描控制模块。利用μC/OS-II的实时性和多任务的特点,采用嵌入式文件系统进行数据管理。

2 控制器的硬件部分设计方案

2.1 视频数据解码模块分析

采取从显卡的DVI接口获取数据,经过视频控制系统进行适当的数据变换,再发送到LED显示屏上显示。此模块用来获取视频源数据,完成对显卡DVI接口传输的TMDS编码数据的接收。通过TMDS解码,实现对RGB视频数据和像素时钟CLOCK、像素有效信号DE、行同步信号HSYN、场同步信号VSYN、同步检测信号SCDT等视频显示控制信号的恢复。

计算机显卡输出的DVI差分信号不能直接作为LED的扫描数据信号,需要经过解码,将该信号恢复为数字视频数据RED[70]、GREEN[70]、BLUE[70]等像素信息,还需要恢复控制信号,如行同步信号HSYNC、场同步信号VSYNC、数据使能信号DE和时钟CLK等控制信息。需要一个解码电路对DVI差分信号进行解码,本设计采用TFP401A DVI解码芯片实现该功能,解码后的数据信息用于提供给LED屏控制器使用。

2.2 数据的存储组织模块分析

数据写入SRAM存储器中的组织方式有两种:位平面法和组合像素法。位平面法是指像素的每一位分别存放在不同的存储设备中;组合像素法是指画面上每个像素的所有位均集中存放在单个存储设备中。LED屏像素数据每一位的权值是不同的,高位的权值高,也就意味着高位为1时LED的点亮时间要长。根据两种存储结构的特点,对于LED屏,采用位平面结构有利于提高LED屏的显示效果,从而更容易实现D/T(data to time)转换。位平面法的数据需要重新组织,利用位平面结构有利于提高LED屏的显示效果。数据重构示意图如图2所示。

数据重构后,通过QuartusⅡ软件编译,得出如图3所示仿真波形。其中,当col为1时,表示已写完上面8个地址的数据,此时读地址计数器开始计数。datain为串行输入数据,dout为串行输出数据。

图3 数据重构模块的仿真波形

2.3 扫描控制模块

将数字视频信号进行缓存处理,并将RGB信号通过脉宽调制(PWM)转换为供LED显示所需的信号送往扫描模块。扫描控制模块由用户自定义的PWM IP核和显存组成,显存采用1片SRAM实现,用来保存当前显示的1帧点阵信息数据。PWM模块通过AvalON总线和Nios IICPU连接,将从CPU接收到的数据按指定地址写入显存,然后再按一定的寻址方式从显存中读取点阵信息数据进行扫描。

2.4 其他功能模块

串口控制器、定时器、存储器控制器通过SOPC Builder软件定制集成IP核自动生成。

3 控制系统软件部分设计

该操作系统利用高效任务调度算法调度每个任务,而每个窗口的显示由单个任务完成。

3.1 数据结构

数据在存储器中的存储形式直接影响数据的存取速度和控制的复杂度,本系统对显存中的数据和缓存区的数据均重新组织,降低了数据处理和扫描控制复杂度。

3.1.1 显存数据的组织

LED显示屏的每个像素点都包括红、绿、蓝3种基色,每种颜色的灰度级均为256级,即由8位数据对像素点灰度级进行编码,故每个像素点需要占用3字节的存储空间。显示时,每个像素的红管、绿管、蓝管是同时点亮的,也就是说,3种颜色的数据是并行上屏的。据此,可将红绿蓝3种颜色对应的数据分开存储,以方便操作。数据存储方式如图4所示。每种颜色的数据集中存放在某个区中,每个区域的首地址作为3种颜色的基址,在进行数据存放时,每个像素点只需给出相对变化地址(变址),然后加上不同的基址就可以在3个区域中找到对应点的视频数据。

图4 存储器分区图
LED显示屏灰度的实现方法,是分权重扫描的。这样就需要把颜色数据位分离,然后同权重的位重新组合。为了方便操作,存储时把图4所示的分区中的每个区再分为8个权重区,所有同权重的数值集中放于对应权重区中。所谓位分离就是把数据的高低位按权重分开,然后重新组织。位分离的实现在可编程逻辑器件中也比较容易实现,可以划出一块逻辑矩阵,操作时横向存入,纵向读出即可。位分离示意图如图5所示。

图5 位分离示意图

3.1.2 缓存数据的组织

若要进行特技效果显示,则当前显示的数据帧和下一个数据帧存在着某种变换关系,由于CPU只能对显存进行写操作,所以需在缓存中划分出一块大小和显存相等、地址一一对应的区域screen,用于存储当前显示的数据帧信息。如果各窗口之间存在重叠现象,且特技数据处理运算直接在screen区域进行,则窗口重叠部分信息可能发生混乱。故在缓存中再为每一个窗口划分出一块存取空间(part 1,part 2,…,part n),用于存储本窗口显示的前一帧数据信息。在特技数据处理运算时,先在part区域处理各窗口的数据信息,然后将转换完的数据送往各窗口在screen区域所对应地址的存取空间,最后将screen中的数据写入地址对应的显存,从而完成显示。

3.2 软件设计

基于上述方案,程序的设计将变得非常简洁。首先进行系统初始化,然后从Flash中读取屏参数,进行参数初始化。接着建立任务Task Control,对各窗口显示任务进行实时管理,它拥有比各窗口显示任务都高的优先级。它每隔1 s对reset标志进行一次查询,如果reset=1,则删除原先建立的各窗口显示任务,从Flash中读取新的窗口个数,然后依此建立新任务,将每个窗口的显示交由单个任务来控制。

下面是TaskControl任务的程序演示:

窗口显示任务用于实现屏幕各窗口的显示。它可根据各窗口显示方式的不同在其相应area区域中进行下一帧数据的运算。在完成1帧数据显示后,调用OSTime DlyHMSM()使当前任务进入等待状态并进行一次任务调度,将系统控制权交给其他处于就绪状态的显示任务,由此完成和窗口显示任务之间的切换。也可以通过调整OSTimeDlyHMSM()的参数来改变各窗口2帧显示信息之间的时间间隔,从而可调整各窗口特技显示的效果,如移动显示的移动速度。下面是其中一个窗口显示任务的程序演示:


4 结论

本设计充分利用了Nios II 32位处理器的高性能和μC/OS-II实时操作系统高效的任务调度算法,实现了单屏幕多窗口显示,显示屏控制变得更加灵活。整个控制系统在1片FPGA芯片上完成,有效降低了系统的成本。

换一批

延伸阅读

[趣科技] 厉害了!这款咖啡无人机能配送,还能预测何时想喝咖啡......

厉害了!这款咖啡无人机能配送,还能预测何时想喝咖啡......

北京时间8月23日早间消息,IBM刚刚获得了一项咖啡无人机专利,不仅能配送咖啡,还可以预测某人何时需要咖啡。根据IBM提交给美国专利和商标局的文件,这款设备可以用在办公室、咖啡厅或活动现场,将预订的咖啡投递送......

关键字:咖啡 无人机

[猎聘集] 复盘一次失败的技术面试后,我成功拿到了 5 个offer

复盘一次失败的技术面试后,我成功拿到了 5 个offer

对于开发者来说,找工作最难的莫过于技术面试。Fredrik Strand Oseberg在freeCodeCamp上发表了一篇文章,介绍了自己学习编程6个月后找工作获得5个offer的经历。......

关键字:技术面试 offer

[趣科技] 可以为手机充电的牛仔裤

可以为手机充电的牛仔裤

但是如果有一条神奇的既可以容纳你的手机,同时还可以给你的手机充电,让你出门在外,从此无忧,你会去购买这款神奇的牛仔裤吗?......

关键字:充电

[真心话] 充电时到底该先插手机还是先插电源?作为电工你应该知道...

充电时到底该先插手机还是先插电源?作为电工你应该知道...

手机不离身似乎已经成为当代人的日常状态,如此频繁地使用手机,会十分消耗手机的电量,不经意间,一天充电数次,而且一旦充电方式不正确的话不仅会损伤手机电池,甚至还存在安全隐患。关于手机充电,很多人都忽视了......

关键字:充电 手机 电源

[疯狂史] 忆当年硬件开发梦:就俩字,TM青涩!

忆当年硬件开发梦:就俩字,TM青涩!

此文仅献给那些刚刚踏上硬件之路和还在徘徊的同学们,在此我简要的记录了我的学习经历和其间自己所获的一些心得,以帮助初学者少走弯路。......

关键字:硬件开发 硬件学习
条评论

我 要 评 论

网友评论

大家都爱看

  • 扇出型晶圆级封装的优势和挑战!

    我们有能力创造一些能保持前代性能并且更好更小的电子设备,例如今天的可穿戴设备、智能手机或平板电脑,这是由于很多因素超过摩尔定律而快速发展,从而能够从底层的嵌入组件发展到今天把它们封…

    2018-03-29
  • Xilinx推出革命性的新型自适应计算产品

    自适应和智能计算的全球领先企业赛灵思公司(Xilinx, Inc.,(NASDAQ:XLNX)),近日宣布推出一款超越FPGA功能的突破性新型产品,名为ACAP(Adaptive Compute Acceleration Platform,自适应计算加速…

    2018-03-20
  • 赛普拉斯为树莓派3 B+ IoT单板计算机提供强大稳定的无

    先进嵌入式系统解决方案的领导者赛普拉斯(纳斯达克代码:CY)近日宣布其Wi-Fi®和蓝牙®combo解决方案为全新的树莓派 3 B+(Raspberry Pi 3Model B+)IoT单板计算机提供强大稳定的无线连接…

    2018-03-20
  • 观看直播领红包,SEED-A10加速卡助力人工智能

    随着云服务器、云计算的发展,大家对硬件加速的需求越来越多,但是随着设备功耗的上升、性能需求越来越高,常规加速设备以及开始不能满足需求,因此FPGA逐渐在硬件加速中找到了自己的位置,而艾…

    2018-03-19
  • 特朗普:博通不得以任何形式收购高通

    白宫周一(3月12日)晚发出声明,川普(特朗普)总统出于“国家安全”考量、禁止新加坡博通公司(Broadcom)收购美国高通公司(Qualcomm)。

    2018-03-14