摘 要: 以棒材計數系統中計數顯示系統為例,介紹了一種以TMS320DM6437為控制內核的OSD顯示技術。該方案將采集到的棒材圖像與棒材計數結果文字字符完成疊加,并通過VGA顯示器實時顯示。本方案在實際項目的系統中工作穩定,字符顯示位置可靈活修改,能方便應用于實時顯示。
關鍵詞: TMS320DM6437;OSD;VGA顯示
在工業生產和生活領域中,嵌入式數字視頻監控系統得到廣泛應用。而在屏顯示OSD(On Screen Display)技術可幫助工作人員方便檢測工業生產過程狀態變化。目前,工業領域實現OSD技術的方法可以利用專業用OSD芯片,如FUJITSU公司的MB90092芯片,其電路設計簡單,但需專門設計軟件和硬件;也可以利用附帶OSD功能的芯片,如SigmaDesigns公司的EM8511芯片,其不需要專門的硬件設計,使用方便,只是這類芯片目前功能還不夠強大,難以工作在信息處理量大和實時性要求高的平臺。TMS320DM6437及其系列芯片是當前視頻處理系統主流處理器之一,本文闡述了以軟件編程方式實現該芯片OSD技術,簡單實用,效果優良,很好地拓展了TMS320DM6437的顯示模塊功能。
1 OSD架構平臺
1.1 棒材計數硬件平臺
本文以棒材計數平臺上實現OSD技術為例,在實現OSD模塊信息和視頻信息疊加時,要處理的數據量大,為了滿足實時性的要求,需要選擇一款集成度高,運算速度快的芯片。TMS320DM6437是TI公司推出的定點Davinci DSP處理器,工作主頻可達700 MHz,處理性能最高達到5 600 MIPS,含有豐富的外設資源,芯片本身具有OSD功能,這樣就不需要增加額外的硬件設計,可以通過靈活的軟件編程來實現視頻和嵌入的圖片疊加,為用戶提供簡便的觀測信息。
棒材計數平臺主要由DSP圖像處理模塊、CMOS圖像傳感器模塊、存儲模塊(DDR2)和視頻輸出顯示模塊組成,硬件平臺如圖1所示。
1.2 TMS320DM6437的OSD內部數據傳輸架構
TMS320DM6437的OSD內部數據傳輸架構如圖2所示。OSD模塊從外部內存中讀入視頻數據,外部內存通常是DDR2,數據經處理轉化為YUV格式后送人VENC。OSD模塊可處理兩個獨立的Video窗口和兩個獨立的OSD窗口,OSD模塊的相關寄存器通過視頻解碼模塊產生的VD信號進行嵌位,來控制顯示窗口使能、窗口縮放以及窗口的顯示坐標。
以下兩個條件滿足時VPBE驅動程序有效。第一是在DSP/BIOS中創建一個VPBE驅動。主程序利用函數VENCHandle=FVID_create("/VPBE0",IOM_INOUT,NULL,NULL,&gioAttrs)打開一個VPBE0設備,并創建VENC通道。由于TI設計的GIO驅動模塊在DSP/BIOS上使用過程中存在缺陷,應用程序在對驅動程序的緩沖區進行數據處理后不能釋放緩沖區,針對這個問題可利用TI提出的FVID視頻處理模型,其能夠比較方便地分配緩沖區,因此,通過直接調用FVID_allocBuffer()函數和FVID_exchangeBuffer()函數申請分配和交換緩沖區,并在使用后利用FVID_deleteBuffer()函數重新釋放緩沖區。第二是設置DSP/BIOS中的硬件中斷。VPBE驅動程序的使用過程中,在TCF文件中設置HWI_INT8為1,配置參數為bios.HWI.instance("HWI_INT8").interruptSelectNumber=1,即VPBE驅動優先級為8,對應VENC每幀圖像處理結束后產生事件序列號為32~64之間的事件被中斷,這時事件接收器檢測到哪里引起了中斷。
2.2 窗口顯示模式選擇
每個窗口可以設置為幀模式和場模式。幀模式的特點是允許每幀圖像數據連續儲存在DDR2中,圖像顯示時按照奇偶場進行讀取。場模式特點是允許圖像數據單獨儲存在DDR2中,圖像顯示是根據VENC的工作模式窗口高度。處理芯片DM6437集成了DDR2內存控制器,支持JESD79D-2A標準,并提供32 bit DDR2接口。圖像數據存儲在DDR2中,當需要VENC連續從DDR2中讀取數據時,將OSD窗口設置為連續場模式,對應的寄存器位VIDWINMD.VFFO和OSDWIN0MD.OFF0使能。連續場數據讀取模式如圖4所示。
本文需要用到VIDWIN0和OSDWIN0將視頻圖像與文字字符疊加,VIDWIN0用于實時顯示采集的棒材圖像,OSDWIN0將棒材計數結果疊加到VIDWIN0窗口畫面。
(1)VIDWIN0窗口設置
CMOS圖像傳感器采集到的圖像經TVP5150轉化為YUV格式數字信號,并存儲在DDR2中,視頻后端處理子系統VPBE將數據從DDR2中讀出,并通過VIDWIN0窗口顯示。由于VIDWIN0對應寄存器配置參數的設置封裝在DM6437自帶的psp_vpbe.h頭文件中,調用結構體PSP_VPBEOsdConfigParams{}可以配置VIDWIN0窗口的工作模式、圖像的格式以及圖像在窗口中顯示位置。例如:
staticPSP_VPBEOsdConfigParamsVid0HandleParams=
{
……
FVID_FIELD_MODE,//連續場模式
FVID_BPP_BITS16,//圖像像素為16位
FVID_YCbCr422_INTERLEAVED,
//圖像存儲格式為YCbCr
(720*(16/8u)),//每行像素個數
0,//左邊界距離
0,//頂格邊界距離
720,//顯示的圖像寬度
480,//顯示的圖像高度
……
};
本文通過軟件編程的方式實現VIDWIN0窗口配置,在對結構體參數設置后,通過調用FVID_create()函數創建vid0Handle通道,FVID_alloc()函數為通道分配存儲空間,調用FVID_queue()函數將要顯示的數據從通道傳輸到VIDWIN0窗口顯示。其具體軟件編寫流程圖如圖6所示。
(3)OSDWIN0窗口設置
OSDWIN0用于顯示RGB565格式的字符和數字圖片,對應的寄存器配置參數的設置封裝在DM6437自帶的psp_vpbe.h頭文件中,配置參數的流程與配置VIDWIN0步驟一樣,調用結構體PSP_VPBEOsdConfigParams win0Params{}設置相應寄存器值,結構體中包含的參數需包含疊加的圖片和文字的顯示屬性,如混合模式、透明度和顏色等。
(4)VGA顯示驅動設計
本文通過修改PSP文件的相關參數設計VGA的顯示驅動,基于PSP(Platform Support Package)上的驅動程序可以直接實現S端子顯示和LCD屏幕顯示,同時驅動程序支持VENC編碼器的連續場輸出模式,但是程序存在缺陷不能直接用于VGA顯示,因此需要在驅動中增加VGA的顯示驅動程序。TI官方提供的基于PSP的視頻驅動程序建立在實時操作系統DSP/BIOS上,總共分為IOM層、DDC層和CSLR層3層。
本文利用的OSD技術產生的疊加效果通過VGA顯示,VPBE模塊為VGA圖像顯示提供了接口,VGA接口有3路基本輸出信號,分別用來顯示RGB 3個分量。VPBE模塊提供的模擬接口擁有4路的視頻DAC信號,通過設置寄存器DACSEL來選擇所需要的3路信號,寄存器DACSEL上的對應關系為:DAC_A位控制輸出R模擬信號,DAC_B位控制輸出G模擬信號,DAC_C位控制輸出B模擬信號,同時DM6437通過I2C總線接口輸出行同步信號HD和列同步信號VD,這5路信號組成了VGA接口輸出信號。
在DDC層中修改一個PSP聲明,并添加LLC_setVGAdisplay()顯示函數對5路信號使能,LLC_setVGAdisplay()代碼如下:
VoidLLC_setVGAdisplay()
{
CSL_FINST(VENCRegs->DACSEL,
VENC_DACSEL_DA0S,PR_R);//R模擬信號輸出使能
CSL_FINST(VENCRegs->DACSEL,
VENC_DACSEL_DA1S,PY_G);//G模擬信號輸出使能
CSL_FINST(VENCRegs->DACSEL,
VENC_DACSEL_DA2S,PB_B);//B模擬信號輸出使能
CSL_FINST(VENCRegs->SYNCCTL,
VENC_SYNCCTL_SYEH,ON);//HD同步信號使能
CSL_FINST(VENCRegs->SYNCCTL,
VENC_SYNCCTL_SYEV,ON);//VD同步信號使能
}
(5)運行效果
VGA 5路信號使能后,程序運行后OSD疊加技術的最終效果如圖9所示。
本文利用TMS320DM6437芯片自帶的OSD模塊,通過軟件編程實現OSD疊加技術,并以在鋼鐵生產中的棒材計數結果與視頻疊加為例,OSD界面上的漢字、數字或其他特殊字符可根據工作人員的要求修改,并在窗口任意位置動態顯示,其設計原理具有通用性。OSD模塊實現的動態棒材視頻圖像與棒材計數結果疊加,方便了人機對話,可以應用在工業生產實踐中。
參考文獻
[1] TI. TMS320DM643x DMP video processing back end (VPBE)[Z].2007.
[2] 合眾達.SEED-DEC6437用戶指南[Z].2008.
[3] TI. How to use the VPBE and VPFE Driver on TMS320DM643x devices [Z].2007.
[4] TI. TMS320DM643x DMP inter-integrated circuit(I2C) module user′s guide (Rev. A)[Z].2007.
[5] TI. TMS320DM643x DMP DDR2 memory controller user′s guide (Rev. B)[Z].2007.
[6] TI. TMS320C64x+ image-video processing library programmer′s reference[Z]. 2007.