基于VxWorks的硬件加速技術探討
(1)BitBLT控制寄存器(BitBLT Control Register)。該寄存器控制2D加速引擎。最低位(Bit0)設置為1則開始2D BitBLT操作。Bitl6設置為1則源地址模式為線性,否則為矩形。Bit17設置目的地址模式。Bit18設置顏色模式,0表示8位顏色深度,1表示16位顏色深度。
(2)BitBLT狀態寄存器(BitBLT Status Register)。該寄存器可以查看2D操作當前狀態。最低位(Bit0)為1表示2D BitBlt操作進行中,0表示空閑。Bit4為1表示數據隊列已滿,為0則隊列未滿。Bit5為1表示隊列超過一半滿,否則不足一半。Bit6為1表示隊列中至少有一個數據,否則為空。Bit20~16指示了隊列中空項的數目,Bit28~24指示了隊列中正在使用的項的數目。
(3)BitBLT命令寄存器(BitBLT Command Register)。該寄存器設置光柵操作,顏色擴展及BitBLT操作選項。Bit3~0指示了BitBLT操作的類型:帶ROP的寫操作,讀操作,帶ROP的正向移動移動,帶ROP的反向移動,透明寫,透明移動,帶ROP的圖樣填充,透明的圖樣填充,顏色擴展,透明顏色擴展,帶顏色擴展的移動,帶顏色擴展的透明移動,固定圖樣填充。Bit19~16指定了ROP操作和顏色擴展選項。
(4)BitBLT源起始地址寄存器(BitBLT Source Start Address Registe)。計算公式為:源起始地址一模式基地址+模式行偏移+像素偏移。
(5)BitBLT目的起始地址寄存器(BitBLT Destination Start Address Register)。Bit20~0指定了BitBLt操作的目的起始地址。
(6)BitBLT內存地址偏移寄存器(BitBLT Memory Address Offset Register)。該寄存器僅用于計算機內存到幀緩沖的拷貝模式,Bit10~0用于設置第N行與第N+1行之間的地址偏移。
(7)BitBLT寬度寄存器(BitBLT Width Register)。用于設置地址模式為矩形時的寬度,Bit9~0設置為寬度像素-1。
(8)BitBLT高度寄存器(BitBLT Height Register)。用于設置地址模式為矩形時的高度,Bit9~0設置為高度像素-1。
(9)BitBLT背景色顏色寄存器(BitBLT Background Color Register)。若為8位顏色模式,則Bit7~0指示了背景色在顏色查找表中的索引;若為16位顏色模式,則Bit15~0指示了背景色在顏色查找表中的索引。
(10)BitBLT前景色顏色寄存器(BitBLT Foreground Color Register)。若為8位顏色模式,則Bit7~0指示了前景色在顏色查找表中的索引;若為16位顏色模式,則Bit15~0指示了前景色在顏色查找表中的索引。
(11)BitBLT數據寄存器(BitBLT Data Register)。Bit15~0指定了BitBLT的數據。
4 S1D13A05圖形驅動中的2D加速實現
下面以VxWorks為開發環境,基于WindML圖形開發包,對S1D13A05的圖形驅動開發中的硬件加速問題進行解析。
4. 1 初始化
初始化圖形設備時,通過一個宏定義來實現對硬件加速的開關。如果需要硬件加速,則讓圖形設備指針的bitmapBlt例程指向ug1Epson-8BitBitmapBlt函數。

評論