



下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
基于framebuffer技術(shù)的DVI顯示驅(qū)動(dòng)程序的開發(fā)
引言
DVI是DigitalVisualInterface(數(shù)字視頻接口)的縮寫。在嵌入式電子領(lǐng)域,像DVI這樣的高清接口應(yīng)用越來越多,很多嵌入式產(chǎn)品采用H.264視頻編碼技術(shù),支持播放H.264格式的720P分辨率的視頻文件,這就需要至少1024×768分辨率的顯示輸出設(shè)備。
MX51是飛思卡爾半導(dǎo)體的基于ARMCortex-A8內(nèi)核的高端ARM嵌入式多媒體處理器,支持720P視頻多種格式的硬解碼,可以用來開發(fā)高清機(jī)頂盒、上網(wǎng)本等產(chǎn)品,很多情況下需要集成DVI這樣的高清視頻端子。
在嵌入式電子產(chǎn)品中,Linux操作系統(tǒng)占有越來越多的市場份額。本文采用Linux2.6.28內(nèi)核和MX51作為系統(tǒng)的軟、硬件平臺(tái),詳細(xì)論述了基于framebtffer技術(shù)開發(fā)DVI顯示驅(qū)動(dòng)程序的方法。1DVI概述
DVI接口只在一些高端顯示器上可以看到,一般常見的液晶顯示器只有VGA接口。VGA接口顯示的是模擬信號(hào),而DVI接口顯示的是數(shù)字信號(hào),它傳輸沒有經(jīng)過壓縮的數(shù)字信號(hào),最高速率可達(dá)4.9Gbps,對(duì)高清視頻顯示可以達(dá)到較好的保真度,減少模擬信號(hào)傳輸時(shí)的信號(hào)損失。
DVI基于TMDS(TransitionMinimizedDifferentialSignaling,轉(zhuǎn)換最小差分信號(hào))技術(shù)來傳輸數(shù)字信號(hào),TMDS運(yùn)用先進(jìn)的編碼算法把8位數(shù)據(jù)(R、G、B中的每路基色信號(hào))通過最小轉(zhuǎn)換編碼為10位數(shù)據(jù)(包含行場同步信息、時(shí)鐘信息、數(shù)據(jù)DE、糾錯(cuò)等),經(jīng)過DC平衡后,采用差分信號(hào)傳輸數(shù)據(jù)。DVI和LVDS、TTL相比有較好的電磁兼容性能,可以用低成本的專用電纜實(shí)現(xiàn)長距離、高質(zhì)量的數(shù)字信號(hào)傳輸。2硬件接口
本設(shè)計(jì)采用的硬件平臺(tái)是基于飛思卡爾半導(dǎo)體的MX51多媒體應(yīng)用處理器開發(fā)板。該處理器集成了多種外設(shè)接口,其中包括兩個(gè)液晶顯示控制器(LCDC)及其接口,可以連接各類LCD,分辨率最大支持1280×800像素。通過MX51的LCD1接口,外擴(kuò)德州儀器公司的TFP410芯片實(shí)現(xiàn)DVI視頻輸出,MX51的高清720P視頻解碼能力需要較大分辨率的顯示輸出設(shè)備。圖1為MX51的LCD1接口與TFP410的連接圖。
圖1中的TX2±、TX1±、TX0±、TXC±信號(hào)是DVI視頻輸出信號(hào)4對(duì),8個(gè)信號(hào)。DATA[23:0]是視頻數(shù)據(jù)輸入信號(hào),對(duì)應(yīng)MX51LCD1的DATA[23:0];DE、VSYNC、HSYNC、IDCK±等時(shí)鐘信號(hào)分別對(duì)應(yīng)LCD1的相應(yīng)的引腳。SCL、SDA是I2C總線時(shí)鐘和數(shù)據(jù)信號(hào),接MX51I2C接口的2個(gè)引腳。以上硬件電路連接,可實(shí)現(xiàn)MX51輸出高清視頻到DVI芯片,再通過外接LCD顯示。MX51處理器內(nèi)部集成的LCD控制器包括如下主要寄存器:
①LSSAR寄存器。設(shè)置顯示緩沖區(qū)的首地址。
②LSR寄存器。設(shè)置顯示緩沖區(qū)的大小。
③LPCR寄存器。設(shè)置像素時(shí)鐘頻率PCD、同步時(shí)鐘極性FB_SYNC_CLK_INVERT、OE信號(hào)極性FB_SYNC_OE_ACT_HIGH、垂直信號(hào)時(shí)鐘極性FB_SYNC_VERT_HIGH_ACT、水平信號(hào)時(shí)鐘極性FB_SYNC_HOR_HIGH_ACT。
④LHCR寄存器。設(shè)置行同步信號(hào)的hsync_len、left_margin和right_margin。
⑤LVCR寄存器。設(shè)置幀同步信號(hào)的vsync_len、upper_margin和lower_margin。
⑥LPCCR寄存器。設(shè)置屏幕的顯示亮度,LPCCR的低8位控制PWM的脈沖高電平占空比,調(diào)節(jié)范圍為0x00~0xFF。3Linux的幀緩沖設(shè)備
3.1framebuffer機(jī)制
framebuffer(幀緩沖)是出現(xiàn)在Linux2.2.xx之后版本內(nèi)核的一種驅(qū)動(dòng)程序接口,在Linux體系中它居于上層應(yīng)用程序和底層顯示設(shè)備之間。framebuffer屏蔽了不同顯示設(shè)備間的差異,將顯示設(shè)備抽象為幀緩沖區(qū),它是一種供用戶態(tài)實(shí)現(xiàn)直接寫屏的抽象設(shè)備。
framebuffer可以看成是顯存的一個(gè)映像,用戶通過內(nèi)存映射將其映射到進(jìn)程的地址空間后,通過對(duì)顯示緩沖區(qū)的讀寫操作可直接控制LCD的屏幕輸出。
frameBuffer設(shè)備驅(qū)動(dòng)主要基于linux/include/linux/fb.h和linux/drivers/video/fbmem.c這兩個(gè)文件。fb.h中包含了與幀緩沖設(shè)備相關(guān)的重要的數(shù)據(jù)結(jié)構(gòu)。fbmem.c是framebuffer機(jī)制的核心程序,它為上層應(yīng)用程序提供了通用接口,同時(shí)也為下層特定硬件提供了接口。其內(nèi)的函數(shù)可對(duì)具體硬件進(jìn)行操作,比如對(duì)寄存器進(jìn)行設(shè)置,對(duì)顯示緩沖進(jìn)行映射等。
3.2幾個(gè)重要的數(shù)據(jù)結(jié)構(gòu)
(1)structfb_info
這個(gè)結(jié)構(gòu)是Linux為幀緩沖區(qū)設(shè)備定義的驅(qū)動(dòng)層接口,它包含了關(guān)于幀緩沖設(shè)備屬性和操作的完整描述,部分成員定義如下:
其中,var記錄用戶可以修改的顯示控制器參數(shù),包括屏幕分辨率和每個(gè)像素的位寬等;fix記錄用戶不能修改的顯示控制器參數(shù);cmap為當(dāng)前的顏色表;fbops指向?qū)Φ讓佑布僮鞯暮瘮?shù)集;dev表示幀緩沖設(shè)備;screen_base為I/O映射的虛擬基地址。
(2)structfb_ops
該結(jié)構(gòu)提供了指向底層操作的函數(shù)指針,其成員函數(shù)最終與LCD控制器硬件打交道,這些函數(shù)需要驅(qū)動(dòng)開發(fā)者根據(jù)LCD控制器的硬件設(shè)置及LCD顯示屏的硬件參數(shù)進(jìn)行設(shè)計(jì)。該結(jié)構(gòu)部分成員定義如下:
其中,fb_check_var用于檢查可變的屏幕參數(shù),并調(diào)整其為硬件支持的值;fb_set_par根據(jù)屏幕參數(shù)設(shè)置具體讀寫LCD控制器的寄存器以使其進(jìn)入相應(yīng)的工作狀態(tài),fb_setcolreg設(shè)置color寄存器來實(shí)現(xiàn)偽顏色表和顏色表的填充。
(3)structfb_var_screeninfo
這是fb_info的成員結(jié)構(gòu)體。它記錄了幀緩沖設(shè)備和指定顯示模式的可修改信息,包括屏幕分辨率、每個(gè)像素的位寬、幀延時(shí)、行延時(shí)等。
(4)structfb_fix_screeninfo
這是fb_info的成員結(jié)構(gòu)體,它描述顯示卡的屬性,并且在系統(tǒng)運(yùn)行時(shí)不能被修改,例如緩沖區(qū)的首地址、長度等。當(dāng)一種模式被設(shè)定后,內(nèi)存信息由顯示卡硬件給出,內(nèi)存的位置等信息就不可修改。
MX51將LCD控制器直接嵌入到處理器芯片內(nèi)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 山東工商學(xué)院《水力學(xué)及橋涵水文》2023-2024學(xué)年第二學(xué)期期末試卷
- 寧夏職業(yè)技術(shù)學(xué)院《能源與動(dòng)力專業(yè)導(dǎo)論》2023-2024學(xué)年第二學(xué)期期末試卷
- 南通職業(yè)大學(xué)《交通設(shè)計(jì)》2023-2024學(xué)年第二學(xué)期期末試卷
- 四川科技職業(yè)學(xué)院《高級(jí)管理學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- 黑龍江工商學(xué)院《化工安全風(fēng)險(xiǎn)評(píng)估與防范》2023-2024學(xué)年第二學(xué)期期末試卷
- 咸陽職業(yè)技術(shù)學(xué)院《妨害社會(huì)管理秩序罪研究》2023-2024學(xué)年第二學(xué)期期末試卷
- 廣東南華工商職業(yè)學(xué)院《計(jì)算機(jī)組成與體系結(jié)構(gòu)實(shí)驗(yàn)》2023-2024學(xué)年第二學(xué)期期末試卷
- 寧夏葡萄酒與防沙治沙職業(yè)技術(shù)學(xué)院《環(huán)境科學(xué)前沿》2023-2024學(xué)年第二學(xué)期期末試卷
- 黔南民族醫(yī)學(xué)高等專科學(xué)?!夺樋椃b設(shè)計(jì)與工藝》2023-2024學(xué)年第二學(xué)期期末試卷
- 山西金融職業(yè)學(xué)院《高級(jí)物流學(xué)》2023-2024學(xué)年第二學(xué)期期末試卷
- T-SCSTA001-2025《四川省好住房評(píng)價(jià)標(biāo)準(zhǔn)》
- 西紅門鎮(zhèn)生活垃圾轉(zhuǎn)運(yùn)站及環(huán)衛(wèi)停車場工程報(bào)告表
- 2025年信息系統(tǒng)監(jiān)理師考試題(附答案)
- 農(nóng)村留守兒童教育支持體系構(gòu)建研究
- 車場管理考試試題及答案
- 福建省三明市2025年普通高中高三畢業(yè)班五月質(zhì)量檢測物理(三明四檢)
- 人教版(2024)七年級(jí)下冊(cè)Unit 3 Keep fit 素養(yǎng)檢測(含解析)
- 2025年四川省成都市成華區(qū)中考二診英語試題(含筆試答案無聽力音頻及原文)
- 綏化綏化市2025年度“市委書記進(jìn)校園”事業(yè)單位引才287人筆試歷年參考題庫附帶答案詳解
- 中國數(shù)據(jù)中心產(chǎn)業(yè)發(fā)展白皮書023年
- 醫(yī)院檢驗(yàn)科實(shí)驗(yàn)室生物安全程序文件SOP
評(píng)論
0/150
提交評(píng)論