基于μC/OS-II的多窗口LED大屏幕控制器

2013-08-30 15:54 來源:電子信息網 作者:鈴鐺

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

1 系統(tǒng)總體設計

采用SOPC技術在FPGA上構建Nios II軟核作為LED顯示控制系統(tǒng)的處理器,實現(xiàn)32位的嵌入式系統(tǒng)操作。通過基于μC/OSII的嵌入式操作系統(tǒng)的軟件設計,完成對DVI視頻顯示數據的接收和預處理。掃描電路接收視頻數據后進行存儲,同時將數據進行再組織并送往掃描屏。

1.1 系統(tǒng)硬件結構

1


圖1 系統(tǒng)結構框圖

計算機顯卡數據通過DVI接口將數據傳送給顯示屏控制系統(tǒng)的解碼電路部分,DVI解碼芯片將獲得的視頻數據解碼,得到RGB視頻數據和控制信號??刂菩盘栔邪袙呙栊盘柡蛨鰭呙栊盘枺@示屏控制系統(tǒng)根據場掃描信號判斷采集1幀視頻數據是否結束,并將視頻數據寫入發(fā)送系統(tǒng)的數據存儲器RAM進行緩存。FPGA從RAM存儲器中讀取數據,將該數據按照灰度級分為8個區(qū)域模塊進行重新組織、轉換,然后通過移位串行時鐘送入LED顯示屏進行顯示。本系統(tǒng)的數據處理模塊、數據存儲模塊、掃描控制模塊3部分均在FPGA上實現(xiàn)。

1.2 軟件總體設計

全彩色LED大屏幕數據量大,本設計將顯示屏從邏輯上劃分為多個窗口,軟件部分基于μC/OSII嵌入式操作系統(tǒng)編程實現(xiàn)。μC/OSII操作系統(tǒng)的任務調度算法比較先進,在顯示系統(tǒng)中,可以將每個窗口的顯示操作都交給某個任務來執(zhí)行,這樣可以從很大程度上提高整個系統(tǒng)的運行速度和軟件的可靠性。

軟件基于Nios II IDE開發(fā)完成,應用程序基于μC/OSII實時操作系統(tǒng)實現(xiàn)。軟件主要由2個任務和1個定時器中斷服務程序組成,任務間采用信號量的方式進行通信。計算機系統(tǒng)的顯卡數據經DVI解碼模塊解碼后得到RGB視頻數據。任務1接收RGB視頻信息,并對視頻信息進行濾波、數據的位組合、數據存儲區(qū)的重新組合等處理操作。任務2從內存中讀取數據,并進行分析處理,把分析處理完的數據送往掃描控制模塊。利用μC/OSII的實時性和多任務的特點,采用嵌入式文件系統(tǒng)進行數據管理。

2 控制器的硬件部分設計方案

2.1 視頻數據解碼模塊分析

采取從顯卡的DVI接口獲取數據,經過視頻控制系統(tǒng)進行適當的數據變換,再發(fā)送到LED顯示屏上顯示。此模塊用來獲取視頻源數據,完成對顯卡DVI接口傳輸的TMDS編碼數據的接收。通過TMDS解碼,實現(xiàn)對RGB視頻數據和像素時鐘CLOCK、像素有效信號DE、行同步信號HSYN、場同步信號VSYN、同步檢測信號SCDT等視頻顯示控制信號的恢復。

計算機顯卡輸出的DVI差分信號不能直接作為LED的掃描數據信號,需要經過解碼,將該信號恢復為數字視頻數據RED[7..0]、GREEN[7..0]、BLUE[7..0]等像素信息,還需要恢復控制信號,如行同步信號HSYNC、場同步信號VSYNC、數據使能信號DE和時鐘CLK等控制信息。需要一個解碼電路對DVI差分信號進行解碼,本設計采用TFP401A DVI解碼芯片實現(xiàn)該功能,解碼后的數據信息用于提供給LED屏控制器使用。

2.2 數據的存儲組織模塊分析

數據寫入SRAM存儲器中的組織方式有兩種:位平面法和組合像素法。位平面法是指像素的每一位分別存放在不同的存儲設備中;組合像素法是指畫面上每個像素的所有位均集中存放在單個存儲設備中。LED屏像素數據每一位的權值是不同的,高位的權值高,也就意味著高位為1時LED的點亮時間要長。根據兩種存儲結構的特點,對于LED屏,采用位平面結構有利于提高LED屏的顯示效果,從而更容易實現(xiàn)D/T(data to time)轉換。位平面法的數據需要重新組織,利用位平面結構有利于提高LED屏的顯示效果。數據重構示意圖如圖2所示。

2


圖2 數據重構示意圖

數據重構后,通過QuartusⅡ軟件編譯,得出如圖3所示仿真波形。其中,當col為1時,表示已寫完上面8個地址的數據,此時讀地址計數器開始計數。datain為串行輸入數據,dout為串行輸出數據。

3


圖3 數據重構模塊的仿真波形

2.3 掃描控制模塊

將數字視頻信號進行緩存處理,并將RGB信號通過脈寬調制(PWM)轉換為供LED顯示所需的信號送往掃描模塊。掃描控制模塊由用戶自定義的PWM IP核和顯存組成,顯存采用1片SRAM實現(xiàn),用來保存當前顯示的1幀點陣信息數據。PWM模塊通過Avalon總線和Nios II CPU連接,將從CPU接收到的數據按指定地址寫入顯存,然后再按一定的尋址方式從顯存中讀取點陣信息數據進行掃描。

2.4 其他功能模塊

串口控制器、定時器、存儲器控制器通過SOPC Builder軟件定制集成IP核自動生成。

3 控制系統(tǒng)軟件部分設計

該操作系統(tǒng)利用高效任務調度算法調度每個任務,而每個窗口的顯示由單個任務完成。

3.1 數據結構

數據在存儲器中的存儲形式直接影響數據的存取速度和控制的復雜度,本系統(tǒng)對顯存中的數據和緩存區(qū)的數據均重新組織,降低了數據處理和掃描控制復雜度。

3.1.1 顯存數據的組織

LED顯示屏的每個像素點都包括紅、綠、藍3種基色,每種顏色的灰度級均為256級,即由8位數據對像素點灰度級進行編碼,故每個像素點需要占用3字節(jié)的存儲空間。顯示時,每個像素的紅管、綠管、藍管是同時點亮的,也就是說,3種顏色的數據是并行上屏的。據此,可將紅綠藍3種顏色對應的數據分開存儲,以方便操作。數據存儲方式如圖4所示。每種顏色的數據

4


圖4 存儲器分區(qū)圖

1 2 > 
LED 控制器 μC/OS-II

相關閱讀

暫無數據

一周熱門