《電子技術(shù)應(yīng)用》
您所在的位置:首頁(yè) > 可編程邏輯 > 設(shè)計(jì)應(yīng)用 > 基于μC/OS-II的多窗口顯示屏控制器
基于μC/OS-II的多窗口顯示屏控制器
劉許亮,王留奎
摘要: 本設(shè)計(jì)充分利用了Nios II 32位處理器的高性能和μC/OS-II實(shí)時(shí)操作系統(tǒng)高效的任務(wù)調(diào)度算法,實(shí)現(xiàn)了單屏幕多窗口顯示,顯示屏控制變得更加靈活。整個(gè)控制系統(tǒng)在1片F(xiàn)PGA芯片上完成,有效降低了系統(tǒng)的成本。
Abstract:
Key words :

引言
LED大屏幕顯示屏是當(dāng)今室外平面顯示的主流,其控制系統(tǒng)的技術(shù)發(fā)展也日趨成熟,控制系統(tǒng)按數(shù)據(jù)傳輸方式分為兩類(lèi):同步顯示和異步顯示。同步顯示控制系統(tǒng)即LED顯示屏和視頻數(shù)據(jù)源實(shí)時(shí)保持一致,視頻信號(hào)實(shí)時(shí)變化。異步顯示控制系統(tǒng)通過(guò)USB、通用串行接口、以太網(wǎng)等數(shù)據(jù)通信方式,更新大屏幕控制系統(tǒng)的視頻數(shù)據(jù)存儲(chǔ)區(qū)。數(shù)據(jù)更新由上位機(jī)控制,LED顯示屏的視頻信息變化由視頻數(shù)據(jù)存儲(chǔ)區(qū)的數(shù)據(jù)決定。在異步顯示系統(tǒng)中,可實(shí)現(xiàn)將顯示屏分為若干區(qū)域,不同的區(qū)域?qū)?yīng)不同的存儲(chǔ)區(qū),數(shù)據(jù)更新時(shí)可以只更新其中的一個(gè)或幾個(gè)窗口。本設(shè)計(jì)采用嵌入式操作系統(tǒng)μC/OS-II的多線(xiàn)程控制方式,分別控制各個(gè)窗口的數(shù)據(jù)區(qū)域,實(shí)現(xiàn)單屏幕多窗口的任意位置顯示,使得顯示方式更加靈活方便。

1 系統(tǒng)總體設(shè)計(jì)
采用SOPC技術(shù)在FPGA上構(gòu)建Nios II軟核作為L(zhǎng)ED顯示控制系統(tǒng)的處理器,實(shí)現(xiàn)32位的嵌入式系統(tǒng)操作。通過(guò)基于μC/OS-II的嵌入式操作系統(tǒng)的軟件設(shè)計(jì),完成對(duì)DVI視頻顯示數(shù)據(jù)的接收和預(yù)處理。掃描電路接收視頻數(shù)據(jù)后進(jìn)行存儲(chǔ),同時(shí)將數(shù)據(jù)進(jìn)行再組織并送往掃描屏。
1.1 系統(tǒng)硬件結(jié)構(gòu)
多窗口顯示屏控制系統(tǒng)的結(jié)構(gòu)框圖如圖1所示。

a.jpg


計(jì)算機(jī)顯卡數(shù)據(jù)通過(guò)DVI接口將數(shù)據(jù)傳送給顯示屏控制系統(tǒng)的解碼電路部分,DVI解碼芯片將獲得的視頻數(shù)據(jù)解碼,得到RGB視頻數(shù)據(jù)和控制信號(hào)。控制信號(hào)中包含行掃描信號(hào)和場(chǎng)掃描信號(hào),顯示屏控制系統(tǒng)根據(jù)場(chǎng)掃描信號(hào)判斷采集1幀視頻數(shù)據(jù)是否結(jié)束,并將視頻數(shù)據(jù)寫(xiě)入發(fā)送系統(tǒng)的數(shù)據(jù)存儲(chǔ)器RAM進(jìn)行緩存。FPGA從RAM存儲(chǔ)器中讀取數(shù)據(jù),將該數(shù)據(jù)按照灰度級(jí)分為8個(gè)區(qū)域模塊進(jìn)行重新組織、轉(zhuǎn)換,然后通過(guò)移位串行時(shí)鐘送入LED顯示屏進(jìn)行顯示。本系統(tǒng)的數(shù)據(jù)處理模塊、數(shù)據(jù)存儲(chǔ)模塊、掃描控制模塊3部分均在FPGA上實(shí)現(xiàn)。
1.2 軟件總體設(shè)計(jì)
全彩色LED大屏幕數(shù)據(jù)量大,本設(shè)計(jì)將顯示屏從邏輯上劃分為多個(gè)窗口,軟件部分基于μC/OS-II嵌入式操作系統(tǒng)編程實(shí)現(xiàn)。μC/OS-II操作系統(tǒng)的任務(wù)調(diào)度算法比較先進(jìn),在顯示系統(tǒng)中,可以將每個(gè)窗口的顯示操作都交給某個(gè)任務(wù)來(lái)執(zhí)行,這樣可以從很大程度上提高整個(gè)系統(tǒng)的運(yùn)行速度和軟件的可靠性。
軟件基于Nios II IDE開(kāi)發(fā)完成,應(yīng)用程序基于μC/OS-II實(shí)時(shí)操作系統(tǒng)實(shí)現(xiàn)。軟件主要由2個(gè)任務(wù)和1個(gè)定時(shí)器中斷服務(wù)程序組成,任務(wù)間采用信號(hào)量的方式進(jìn)行通信。計(jì)算機(jī)系統(tǒng)的顯卡數(shù)據(jù)經(jīng)DVI解碼模塊解碼后得到RGB視頻數(shù)據(jù)。任務(wù)1接收RGB視頻信息,并對(duì)視頻信息進(jìn)行濾波、數(shù)據(jù)的位組合、數(shù)據(jù)存儲(chǔ)區(qū)的重新組合等處理操作。任務(wù)2從內(nèi)存中讀取數(shù)據(jù),并進(jìn)行分析處理,把分析處理完的數(shù)據(jù)送往掃描控制模塊。利用μC/OS-II的實(shí)時(shí)性和多任務(wù)的特點(diǎn),采用嵌入式文件系統(tǒng)進(jìn)行數(shù)據(jù)管理。

2 控制器的硬件部分設(shè)計(jì)方案
2.1 視頻數(shù)據(jù)解碼模塊分析
采取從顯卡的DVI接口獲取數(shù)據(jù),經(jīng)過(guò)視頻控制系統(tǒng)進(jìn)行適當(dāng)?shù)臄?shù)據(jù)變換,再發(fā)送到LED顯示屏上顯示。此模塊用來(lái)獲取視頻源數(shù)據(jù),完成對(duì)顯卡DVI接口傳輸?shù)腡MDS編碼數(shù)據(jù)的接收。通過(guò)TMDS解碼,實(shí)現(xiàn)對(duì)RGB視頻數(shù)據(jù)和像素時(shí)鐘CLOCK、像素有效信號(hào)DE、行同步信號(hào)HSYN、場(chǎng)同步信號(hào)VSYN、同步檢測(cè)信號(hào)SCDT等視頻顯示控制信號(hào)的恢復(fù)。
計(jì)算機(jī)顯卡輸出的DVI差分信號(hào)不能直接作為L(zhǎng)ED的掃描數(shù)據(jù)信號(hào),需要經(jīng)過(guò)解碼,將該信號(hào)恢復(fù)為數(shù)字視頻數(shù)據(jù)RED[7..0]、GREEN[7..0]、BLUE[7..0]等像素信息,還需要恢復(fù)控制信號(hào),如行同步信號(hào)HSYNC、場(chǎng)同步信號(hào)VSYNC、數(shù)據(jù)使能信號(hào)DE和時(shí)鐘CLK等控制信
息。需要一個(gè)解碼電路對(duì)DVI差分信號(hào)進(jìn)行解碼,本設(shè)計(jì)采用TFP401A DVI解碼芯片實(shí)現(xiàn)該功能,解碼后的數(shù)據(jù)信息用于提供給LED屏控制器使用。
2.2 數(shù)據(jù)的存儲(chǔ)組織模塊分析
數(shù)據(jù)寫(xiě)入SRAM存儲(chǔ)器中的組織方式有兩種:位平面法和組合像素法。位平面法是指像素的每一位分別存放在不同的存儲(chǔ)設(shè)備中;組合像素法是指畫(huà)面上每個(gè)像素的所有位均集中存放在單個(gè)存儲(chǔ)設(shè)備中。LED屏像素?cái)?shù)據(jù)每一位的權(quán)值是不同的,高位的權(quán)值高,也就意味著高位為1時(shí)LED的點(diǎn)亮?xí)r間要長(zhǎng)。根據(jù)兩種存儲(chǔ)結(jié)構(gòu)的特點(diǎn),對(duì)于LED屏,采用位平面結(jié)構(gòu)有利于提高LED屏的顯示效果,從而更容易實(shí)現(xiàn)D/T(data to time)轉(zhuǎn)換。位平面法的數(shù)據(jù)需要重新組織,利用位平面結(jié)構(gòu)有利于提高LED屏的顯示效果。數(shù)據(jù)重構(gòu)示意圖如圖2所示。

b.jpg

數(shù)據(jù)重構(gòu)后,通過(guò)QuartusⅡ軟件編譯,得出如圖3所示仿真波形。其中,當(dāng)col為1時(shí),表示已寫(xiě)完上面8個(gè)地址的數(shù)據(jù),此時(shí)讀地址計(jì)數(shù)器開(kāi)始計(jì)數(shù)。datain為串行輸入數(shù)據(jù),dout為串行輸出數(shù)據(jù)。

c.jpg


2.3 掃描控制模塊
將數(shù)字視頻信號(hào)進(jìn)行緩存處理,并將RGB信號(hào)通過(guò)脈寬調(diào)制(PWM)轉(zhuǎn)換為供LED顯示所需的信號(hào)送往掃描模塊。掃描控制模塊由用戶(hù)自定義的PWM IP核和顯存組成,顯存采用1片SRAM實(shí)現(xiàn),用來(lái)保存當(dāng)前顯示的1幀點(diǎn)陣信息數(shù)據(jù)。PWM模塊通過(guò)Avalon總線(xiàn)和Nios IICPU連接,將從CPU接收到的數(shù)據(jù)按指定地址寫(xiě)入顯存,然后再按一定的尋址方式從顯存中讀取點(diǎn)陣信息數(shù)據(jù)進(jìn)行掃描。
2.4 其他功能模塊
串口控制器、定時(shí)器、存儲(chǔ)器控制器通過(guò)SOPC Builder軟件定制集成IP核自動(dòng)生成。

3 控制系統(tǒng)軟件部分設(shè)計(jì)
該操作系統(tǒng)利用高效任務(wù)調(diào)度算法調(diào)度每個(gè)任務(wù),而每個(gè)窗口的顯示由單個(gè)任務(wù)完成。
3.1 數(shù)據(jù)結(jié)構(gòu)
數(shù)據(jù)在存儲(chǔ)器中的存儲(chǔ)形式直接影響數(shù)據(jù)的存取速度和控制的復(fù)雜度,本系統(tǒng)對(duì)顯存中的數(shù)據(jù)和緩存區(qū)的數(shù)據(jù)均重新組織,降低了數(shù)據(jù)處理和掃描控制復(fù)雜度。
3.1.1 顯存數(shù)據(jù)的組織
LED顯示屏的每個(gè)像素點(diǎn)都包括紅、綠、藍(lán)3種基色,每種顏色的灰度級(jí)均為256級(jí),即由8位數(shù)據(jù)對(duì)像素點(diǎn)灰度級(jí)進(jìn)行編碼,故每個(gè)像素點(diǎn)需要占用3字節(jié)的存儲(chǔ)空間。顯示時(shí),每個(gè)像素的紅管、綠管、藍(lán)管是同時(shí)點(diǎn)亮的,也就是說(shuō),3種顏色的數(shù)據(jù)是并行上屏的。據(jù)此,可將紅綠藍(lán)3種顏色對(duì)應(yīng)的數(shù)據(jù)分開(kāi)存儲(chǔ),以方便操作。數(shù)據(jù)存儲(chǔ)方式如圖4所示。每種顏色的數(shù)據(jù)集中存放在某個(gè)區(qū)中,每個(gè)區(qū)域的首地址作為3種顏色的基址,在進(jìn)行數(shù)據(jù)存放時(shí),每個(gè)像素點(diǎn)只需給出相對(duì)變化地址(變址),然后加上不同的基址就可以在3個(gè)區(qū)域中找到對(duì)應(yīng)點(diǎn)的視頻數(shù)據(jù)。

d.jpg


 LED顯示屏灰度的實(shí)現(xiàn)方法,是分權(quán)重掃描的。這樣就需要把顏色數(shù)據(jù)位分離,然后同權(quán)重的位重新組合。為了方便操作,存儲(chǔ)時(shí)把圖4所示的分區(qū)中的每個(gè)區(qū)再分為8個(gè)權(quán)重區(qū),所有同權(quán)重的數(shù)值集中放于對(duì)應(yīng)權(quán)重區(qū)中。所謂位分離就是把數(shù)據(jù)的高低位按權(quán)重分開(kāi),然后重新組織。位分離的實(shí)現(xiàn)在可編程邏輯器件中也比較容易實(shí)現(xiàn),可以劃出一塊邏輯矩陣,操作時(shí)橫向存入,縱向讀出即可。位分離示意圖如圖5所示。

e.jpg

 

3.1.2 緩存數(shù)據(jù)的組織
若要進(jìn)行特技效果顯示,則當(dāng)前顯示的數(shù)據(jù)幀和下一個(gè)數(shù)據(jù)幀存在著某種變換關(guān)系,由于CPU只能對(duì)顯存進(jìn)行寫(xiě)操作,所以需在緩存中劃分出一塊大小和顯存相等、地址一一對(duì)應(yīng)的區(qū)域screen,用于存儲(chǔ)當(dāng)前顯示的數(shù)據(jù)幀信息。如果各窗口之間存在重疊現(xiàn)象,且特技數(shù)據(jù)處理運(yùn)算直接在screen區(qū)域進(jìn)行,則窗口重疊部分信息可能發(fā)生混亂。故在緩存中再為每一個(gè)窗口劃分出一塊存取空間(part 1,part 2,…,part n),用于存儲(chǔ)本窗口顯示的前一幀數(shù)據(jù)信息。在特技數(shù)據(jù)處理運(yùn)算時(shí),先在part區(qū)域處理各窗口的數(shù)據(jù)信息,然后將轉(zhuǎn)換完的數(shù)據(jù)送往各窗口在screen區(qū)域所對(duì)應(yīng)地址的存取空間,最后將screen中的數(shù)據(jù)寫(xiě)入地址對(duì)應(yīng)的顯存,從而完成顯示。
3.2 軟件設(shè)計(jì)
基于上述方案,程序的設(shè)計(jì)將變得非常簡(jiǎn)潔。首先進(jìn)行系統(tǒng)初始化,然后從Flash中讀取屏參數(shù),進(jìn)行參數(shù)初始化。接著建立任務(wù)Task Control,對(duì)各窗口顯示任務(wù)進(jìn)行實(shí)時(shí)管理,它擁有比各窗口顯示任務(wù)都高的優(yōu)先級(jí)。它每隔1 s對(duì)reset標(biāo)志進(jìn)行一次查詢(xún),如果reset=1,則刪除原先建立的各窗口顯示任務(wù),從Flash中讀取新的窗口個(gè)數(shù),然后依此建立新任務(wù),將每個(gè)窗口的顯示交由單個(gè)任務(wù)來(lái)控制。
下面是TaskControl任務(wù)的程序演示:
f.jpg
g.jpg
窗口顯示任務(wù)用于實(shí)現(xiàn)屏幕各窗口的顯示。它可根據(jù)各窗口顯示方式的不同在其相應(yīng)area區(qū)域中進(jìn)行下一幀數(shù)據(jù)的運(yùn)算。在完成1幀數(shù)據(jù)顯示后,調(diào)用OSTime DlyHMSM()使當(dāng)前任務(wù)進(jìn)入等待狀態(tài)并進(jìn)行一次任務(wù)調(diào)度,將系統(tǒng)控制權(quán)交給其他處于就緒狀態(tài)的顯示任務(wù),由此完成和窗口顯示任務(wù)之間的切換。也可以通過(guò)調(diào)整OSTimeDlyHMSM()的參數(shù)來(lái)改變各窗口2幀顯示信息之間的時(shí)間間隔,從而可調(diào)整各窗口特技顯示的效果,如移動(dòng)顯示的移動(dòng)速度。下面是其中一個(gè)窗口顯示任務(wù)的程序演示:
h.jpg

4 結(jié)論
本設(shè)計(jì)充分利用了Nios II 32位處理器的高性能和μC/OS-II實(shí)時(shí)操作系統(tǒng)高效的任務(wù)調(diào)度算法,實(shí)現(xiàn)了單屏幕多窗口顯示,顯示屏控制變得更加靈活。整個(gè)控制系統(tǒng)在1片F(xiàn)PGA芯片上完成,有效降低了系統(tǒng)的成本。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
午夜视频精品| 一区二区不卡在线视频 午夜欧美不卡在| 国产一区二区三区日韩欧美| 欧美日韩专区| 欧美激情在线观看| 欧美国产日韩xxxxx| 欧美+亚洲+精品+三区| 久久夜色精品一区| 久久伊人亚洲| 久久亚洲国产精品一区二区| 久久九九精品| 久久久久国产精品一区三寸| 久久精品免费看| 亚洲欧美在线免费| 亚洲一区在线视频| 亚洲自拍都市欧美小说| 午夜精品福利一区二区三区av | 亚洲国产日韩美| 在线看片一区| 亚洲国产精品国自产拍av秋霞 | 欧美影院在线播放| 亚洲电影免费观看高清完整版| 久久国产免费看| 亚洲高清电影| 亚洲黄网站黄| 99亚洲伊人久久精品影院红桃| 一区二区三区你懂的| 亚洲午夜精品国产| 午夜精品久久久久久99热软件| 久久爱91午夜羞羞| 久久久精品性| 欧美sm重口味系列视频在线观看| 欧美高清你懂得| 欧美日韩在线播放一区| 国产精品久久久久久久一区探花| 国产精品捆绑调教| 国产一区二区福利| 在线观看亚洲视频啊啊啊啊| 亚洲欧洲日韩综合二区| 99国产精品久久| 午夜精品一区二区三区在线| 亚洲大黄网站| 欧美成va人片在线观看| 欧美aa国产视频| 欧美日韩在线视频观看| 国产精品久久久久久模特| 国产一区二区久久精品| 在线成人激情| 在线视频欧美精品| 久久精彩免费视频| 日韩视频一区| 欧美一区二区视频在线观看| 久久综合国产精品台湾中文娱乐网| 欧美黄在线观看| 国产精品嫩草影院一区二区| 一区在线影院| 正在播放欧美视频| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲毛片av在线| 亚洲欧美成人一区二区在线电影| 久久久久久久综合狠狠综合| 欧美激情一区二区三区在线视频 | 欧美电影专区| 国产片一区二区| 亚洲黄色成人久久久| 亚洲一区二区欧美日韩| 91久久精品www人人做人人爽| 亚洲欧美日韩国产另类专区| 久久一区二区视频| 国产精品你懂的| 亚洲人成在线影院| 欧美一区二区三区四区在线观看地址 | 亚洲精品美女在线| 欧美一级二区| 亚洲校园激情| 嫩草成人www欧美| 国产女主播一区二区三区| 亚洲精品欧美日韩专区| 欧美中文日韩| 午夜亚洲视频| 欧美日韩国产综合视频在线| 精品成人一区二区三区| 亚洲午夜av| 日韩视频二区| 久久综合色一综合色88| 国产精品一区二区黑丝| 亚洲精品在线观| 亚洲国产成人91精品| 欧美一区=区| 欧美三级中文字幕在线观看| 亚洲第一网站免费视频| 欧美一区二区三区在线| 午夜亚洲性色福利视频| 欧美午夜久久久| 亚洲日本中文字幕| 久久精品视频在线看| 久久国内精品自在自线400部| 欧美日韩亚洲综合一区| 亚洲国产高清高潮精品美女| 欧美伊人久久大香线蕉综合69| 亚洲欧美国产精品桃花| 欧美四级伦理在线| 亚洲精品1区| 亚洲国产精品毛片| 久久免费少妇高潮久久精品99| 国产精品红桃| 一区二区三区三区在线| 亚洲五月婷婷| 欧美视频手机在线| 亚洲精品在线免费观看视频| 亚洲精品一区中文| 欧美成人亚洲成人| 亚洲第一精品夜夜躁人人爽| 久久成人精品视频| 久久久噜噜噜久久人人看| 国产日韩欧美二区| 亚洲欧美日韩国产| 欧美在线视频免费| 国产美女精品在线| 亚洲欧美综合网| 欧美在线在线| 国产日韩一区二区三区| 校园春色国产精品| 久久精品亚洲精品| 国产一区二区av| 久久精品成人一区二区三区蜜臀| 久久久久9999亚洲精品| 国内精品模特av私拍在线观看| 久久精品道一区二区三区| 久久一区二区精品| 伊人影院久久| 亚洲精品一区在线观看| 欧美伦理在线观看| 一本色道综合亚洲| 亚洲男女自偷自拍图片另类| 国产精品欧美一区喷水| 亚洲欧美日韩国产综合| 久久久久国产精品一区二区| 激情小说亚洲一区| 亚洲精品久久在线| 欧美老女人xx| 在线视频你懂得一区| 午夜影院日韩| 国产午夜精品一区二区三区视频 | 美女免费视频一区| 亚洲国产精品免费| 在线亚洲欧美| 国产精品视频福利| 亚洲电影成人| 欧美日韩不卡一区| 亚洲视频碰碰| 久久久久www| 亚洲日本成人网| 欧美一级视频精品观看| 韩国自拍一区| 99国产精品久久久| 国产精品麻豆成人av电影艾秋| 先锋影音久久久| 欧美电影在线免费观看网站| 一区二区三区高清不卡| 欧美在线高清视频| 经典三级久久| 一区二区三区视频免费在线观看| 国产精品任我爽爆在线播放 | 亚洲综合日韩在线| 国产一区二区三区在线观看网站 | 正在播放亚洲一区| 国产亚洲精品福利| 亚洲美女中出| 国产精品五区| 亚洲人成小说网站色在线| 欧美四级在线观看| 亚洲第一网站| 国产精品白丝黑袜喷水久久久 | 亚洲国产精品综合| 国产精品国产a级| 亚洲国产成人精品久久| 欧美色网在线| 久久精品国产视频| 欧美性天天影院| 91久久精品www人人做人人爽| 国产精品美女久久久免费| 亚洲精品1区| 国产精品一区二区a| 99精品视频免费| 国产在线拍揄自揄视频不卡99| 99视频在线观看一区三区| 国产综合香蕉五月婷在线| 亚洲小视频在线| 亚洲国产成人在线播放| 欧美综合第一页| 99视频精品在线| 欧美 日韩 国产精品免费观看| 亚洲免费在线精品一区| 欧美日韩国产综合久久| 久久精品视频网| 国产精品一区二区久激情瑜伽| 一本综合精品| 在线观看视频一区| 欧美综合第一页|