基于PXA270的LCD顯示系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
3.1 幀緩沖器的初始化
主要數(shù)據(jù)結(jié)構(gòu)如下:
struct pxafb_info:主要用于幀緩沖區(qū)設(shè)備驅(qū)動(dòng)框架的搭建,也是Linux為幀緩沖設(shè)備定義的驅(qū)動(dòng)層接口。它不僅包含了底層函數(shù),而且還記錄了幀緩沖器設(shè)備的全部信息。每個(gè)幀緩沖設(shè)備都必須與一個(gè)fb_info結(jié)構(gòu)相對(duì)應(yīng)。其中成員變量modename為設(shè)備名稱,fontname為顯示字體,fbops為指向底層操作的函數(shù)的指針。
struct pxafb_fix_screeninfo:記錄用戶不能修改的顯示控制器參數(shù)。它包括屏幕緩沖區(qū)的物理地址和長(zhǎng)度。
struct pxafb_var_screeninfo:記錄用戶可以修改的顯示控制器參數(shù)。它包括顯示屏幕的分辨率、每個(gè)像素的比特?cái)?shù)和一些時(shí)序變量。其中變量xres定義了屏幕一行所占的像素?cái)?shù),yres定義了屏幕一列所占的像素?cái)?shù),bits_per_pixel定義了每個(gè)像素用多少個(gè)位來(lái)表示。
幀緩沖區(qū)的初始化函數(shù)在/drivers/video/pxafb.c文件中,結(jié)構(gòu)如下:
int __init pxafb_init(void)
{
struct pxafb_info *fbi;
int ret;
…………
fbi = pxafb_init_fbinfo(); //初始化一些重要的數(shù)據(jù)結(jié)構(gòu)
…………
/* Initialize video memory */
ret = pxafb_map_video_memory(fbi); //在內(nèi)存中創(chuàng)建一個(gè)圖像緩存區(qū)
…………
pxafb_set_var(fbi->fb.var, -1, fbi->fb);
…………
ret = register_framebuffer(fbi->fb); //登記,使畫(huà)面緩沖區(qū)與控制臺(tái)設(shè)備驅(qū)動(dòng)的高層掛鉤
…………
/ * Ok, now enable the LCD controller */
set_ctrlr_state(fbi, C_ENABLE);
…………
return ret;
}
首先是pxafb_init_fbinfo()的調(diào)用,目的在于對(duì)幾個(gè)數(shù)據(jù)結(jié)構(gòu)進(jìn)行初始化,并設(shè)置有關(guān)的基本的參數(shù),例如所用的字體、顯示屏的規(guī)格等,還有為了搭建幀緩沖器的設(shè)備驅(qū)動(dòng)框架做一些準(zhǔn)備。接著通過(guò)pxafb_map_video_memory()函數(shù)在內(nèi)存中創(chuàng)建幀緩沖區(qū),實(shí)際上是為一個(gè)內(nèi)存區(qū)間另外建立一個(gè)映射。這里分配用于幀緩沖區(qū)的內(nèi)存區(qū)間應(yīng)該是不經(jīng)高速緩存、不加寫(xiě)緩沖的,這樣才可以一經(jīng)寫(xiě)入便立即反映在顯示屏上,而無(wú)需先對(duì)高速緩存進(jìn)行刷新。
pxafb_set_var()函數(shù)是為控制臺(tái)設(shè)備驅(qū)動(dòng)的高層提供一個(gè)驅(qū)動(dòng)幀緩沖區(qū)的界面。同時(shí)也確定一些與畫(huà)面緩沖區(qū)有關(guān)的參數(shù),并記錄在一個(gè)fb_var_screeinfo數(shù)據(jù)結(jié)構(gòu)中。確定了這些參數(shù)以后,如果目標(biāo)幀緩沖區(qū)屬于當(dāng)前選定的控制臺(tái)設(shè)備,就通過(guò)pxa_activate_var()函數(shù)把這些參數(shù)分門(mén)別類(lèi)地組合生成PXA270各有關(guān)寄存器的映像,并最終設(shè)置到PXA270的各個(gè)LCD控制寄存器中。
這里用到6個(gè)寄存器:
- DBAR1:DMA通道1的基地址寄存器,用于調(diào)色板;
- DBAR2:DMA通道2的基地址寄存器,用于畫(huà)圖;
- LCCR0:黑白/彩色模式選擇,單畫(huà)面/雙畫(huà)面顯示方式、被動(dòng)/主動(dòng)顯示模式選擇;
- LCCR1:控制著水平方面的掃描,包括每行的像素、水平同步脈沖寬度、在水平掃描行的開(kāi)頭和末尾各空出幾個(gè)像素等參數(shù);
- LCCR2:控制著垂直方面的掃描,包括每個(gè)畫(huà)面的行數(shù)、垂直同步脈沖寬度、在畫(huà)面的頂部和底部各空出幾行等參數(shù);
- LCCR3:控制著像素時(shí)鐘的頻率以及各種同步脈沖的極性。
評(píng)論