Framebuffer對應的源文件在linux/drivers/video/目錄下。總的抽象設備文件為fbcon.c,在這個目錄下還有與各種顯卡驅動相關的源文件。
(一)、分析Framebuffer設備驅動
需要特別提出的是在INTEL平台上,老式的VESA1.2卡,如CGA/EGA卡,是不能支持Framebuffer的,因為Framebuffer要求顯卡支持線性幀緩沖,即CPU可以訪問顯緩沖中的每一位, 但是VESA1.2 卡只能允許CPU一次訪問64K的地址空間。
FrameBuffer設備驅動基於如下兩個文件:
1) linux/include/linux/fb.h
2) linux/drivers/video/fbmem.c 下面分析這兩個文件。
1、fb.h
幾乎主要的結構都是在這個中文件定義的。這些結構包括:
1)fb_var_screeninfo
【Linux公社 http://www.linuxidc.com 】
這個結構描述了顯示卡的特性:
- struct fb_var_screeninfo
- {
- __u32 xres; /* visible resolution */
- __u32 yres;
- __u32 xres_virtual; /* virtual resolution */
- __u32 yres_virtual;
- __u32 xoffset; /* offset from virtual to visible resolution */
- __u32 yoffset;
- __u32 bits_per_pixel; /* guess what */
- __u32 grayscale; /* != 0 Gray levels instead of colors */
- struct fb_bitfield red; /* bitfield in fb mem if true color, */
- struct fb_bitfield green; /* else only length is significant */
- struct fb_bitfield blue;
- struct fb_bitfield transp; /* transparency */
- __u32 nonstd; /* != 0 Non standard pixel format */
- __u32 activate; /* see FB_ACTIVATE_* */
- __u32 height; /* height of picture in mm */
- __u32 width; /* width of picture in mm */
- __u32 accel_flags; /* acceleration flags (hints) */
- /* Timing: All values in pixclocks, except pixclock (of course) */
- __u32 pixclock; /* pixel clock in ps (pico seconds) */
- __u32 left_margin; /* time from sync to picture */
- __u32 right_margin; /* time from picture to sync */
- __u32 upper_margin; /* time from sync to picture */
- __u32 lower_margin;
- __u32 hsync_len; /* length of horizontal sync */
- __u32 vsync_len; /* length of vertical sync */
- __u32 sync; /* see FB_SYNC_* */
- __u32 vmode; /* see FB_VMODE_* */
- __u32 reserved[6]; /* Reserved for future compatibility */
- };