《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 設計應用 > 基于TMS320DM6437的OSD技術設計及應用舉例
基于TMS320DM6437的OSD技術設計及應用舉例
來源:微型機與應用2014年第3期
曾 凱,鄭力新,張 楓
(華僑大學 信息科學與工程學院,福建 廈門361021)
摘要: 以棒材計數系統中計數顯示系統為例,介紹了一種以TMS320DM6437為控制內核的OSD顯示技術。該方案將采集到的棒材圖像與棒材計數結果文字字符完成疊加,并通過VGA顯示器實時顯示。本方案在實際項目的系統中工作穩定,字符顯示位置可靈活修改,能方便應用于實時顯示。
關鍵詞: DSP TMS320DM6437 OSD VGA顯示
Abstract:
Key words :

摘  要: 以棒材計數系統中計數顯示系統為例,介紹了一種以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.

此內容為AET網站原創,未經授權禁止轉載。
主站蜘蛛池模板: 禁网站在线观看免费视频 | 日韩精品特黄毛片免费看 | 国产不卡在线蜜 | 黑人又大又粗又长又深受不了 | 日韩欧美成人乱码一在线 | 日韩欧美国产一区二区三区 | 亚洲精品国自产拍影院 | 亚洲欧美日韩成人网 | 国产区成人精品视频 | 欧美性生交xxxxx久久久 | 玖玖爱zh综合伊人久久 | 全免费a级毛片免费看 | 日韩 欧美 中文 | 成人在免费观看视频国产 | 天天爆操| bl男男全肉高h集合 bl男男全肉高h车 | 深夜免费福利 | 成品片a免费入口 | 日韩手机专区 | 亚洲欧美另类日韩 | 国产一级毛片午夜福 | 亚洲爆乳无码一区二区三区 | 免费一级毛片在线播放不收费 | 中文字幕一区二区三区在线不卡 | 欧美城天堂网 | 激情午夜网 | 亚洲欧美一区二区三区导航 | 你懂的在线观看网站 | 黄色一级大片视频 | 波多野结衣在线网站 | 亚洲 欧美 另类中文字幕 | 免费视频a| 久在线视频 | 免费日韩一级片 | 欧美一级片黄色片 | 日本黄色三级网站 | 免费高清特级毛片 | 最近更新中文字幕2019视频 | 第一色影院 | 91好色视频 | 波多野结衣中文字幕在线 |