用類/微驅(qū)動模型開發(fā)DSP視頻驅(qū)動程序
1 DSP的外設(shè)驅(qū)動開發(fā)模型
TI公司為開發(fā)DSP的外設(shè)驅(qū)動程序定義了標(biāo)準(zhǔn)的設(shè)備驅(qū)動模型,并將設(shè)備驅(qū)動分為類驅(qū)動和微驅(qū)動,即依賴于硬件層和不依賴于硬件層。兩層之間使用通用接口進(jìn)行數(shù)據(jù)通信,并提供了一系列的API接口,用戶應(yīng)用程序通過調(diào)用API來訪問相應(yīng)的外部設(shè)備。外設(shè)驅(qū)動開發(fā)模型的建立,提高了外設(shè)驅(qū)動程序的可重用性和模塊化程度,簡化了驅(qū)動程序的開發(fā)。外設(shè)開發(fā)模型如圖1所示。
?、?類驅(qū)動(class driver)。類驅(qū)動程序用來為應(yīng)用程序提供接口。這部分程序與所使用的硬件設(shè)備無關(guān),主要功能包括維護(hù)設(shè)備緩沖區(qū),向上提供API接口供應(yīng)用程序調(diào)用,向下提供適配層與微驅(qū)動層相連,實(shí)現(xiàn)API接口函數(shù)到微驅(qū)動層程序的映射。
?、?微驅(qū)動(mini driver)。微驅(qū)動程序與外部硬件設(shè)備相關(guān),所以設(shè)計(jì)微驅(qū)動程序是外設(shè)驅(qū)動開發(fā)的重點(diǎn)。微驅(qū)動程序
類驅(qū)動通過標(biāo)準(zhǔn)的微驅(qū)動接口調(diào)用微驅(qū)動控制硬件設(shè)備。到目前為止,TI共定義了3類驅(qū)動:①流輸入輸出模塊(SIO),為每個DSP/BIOS線程提供一個獨(dú)立的I/O機(jī)制,執(zhí)行點(diǎn)到點(diǎn)的數(shù)據(jù)傳送,支持動態(tài)創(chuàng)建,通過DIO適配模塊與IOM連接;②管道管理模塊(PIP),提供管理異步I/O的數(shù)據(jù)管道,每個管道對象都有一塊同樣大小的緩存,PIP模塊通過緩存進(jìn)行數(shù)據(jù)傳輸,通過PIO適配模塊與IOM通信;③通用輸入輸出模塊(GIO),基于流輸入/輸出模式的同步I/O,適合大流量數(shù)據(jù)的傳輸,更適合文件系統(tǒng)。在用戶應(yīng)用程序中可直接調(diào)用GIO的API函數(shù),GIO不需要額外的適配模塊,可直接與IOM進(jìn)行交互。GIO的這些優(yōu)點(diǎn)使得通過GIO模塊與外部設(shè)備進(jìn)行數(shù)據(jù)流傳輸,操作簡單、穩(wěn)定,所以在視頻采集的類驅(qū)動中采用了通用輸入輸出模塊GIO。
GIO模塊實(shí)現(xiàn)GIO的類驅(qū)動,用于提供一個模塊化的讀寫應(yīng)用程序接口到應(yīng)用程序。通過封裝這部分代碼,應(yīng)用程序可以通過GIO提供的應(yīng)用程序接口間接調(diào)用各種IOM微驅(qū)動來減小整體的代碼大小,如圖2所示。
GIO模塊提供下述功能:提供模塊化的讀寫應(yīng)用程序;用IOM接口與指定設(shè)備微驅(qū)動實(shí)現(xiàn)程序通信;支持多個設(shè)備驅(qū)動;支持雙向通道;允許用戶配置模塊化功能;支持應(yīng)用程序增加新的應(yīng)用領(lǐng)域(如視頻)。其中,最后一項(xiàng)功能很重要。GIO_submit函數(shù)對新增加的用戶定制的應(yīng)用程序接口(API)提供標(biāo)準(zhǔn)通道(如video)。這種用戶定制的類型包括用于文件系統(tǒng)的讀寫應(yīng)用程序接口模塊,例如UART、DSP視頻幀等的應(yīng)用。
傳統(tǒng)的文件系統(tǒng)用讀寫應(yīng)用程序接口來完成應(yīng)用程序與文件之間的數(shù)據(jù)傳輸,需要由GIO類驅(qū)動和IOM微驅(qū)動來完成所需的雙向通道。對GIO接口模塊的擴(kuò)展可以更加友好和高效地實(shí)現(xiàn)視頻抓取和視頻顯示。這種擴(kuò)展特別滿足了視頻設(shè)備存儲空間(例如指定的幀緩存)的分配,而且通過簡單的應(yīng)用程序調(diào)用來更新視頻幀緩存,提供視頻驅(qū)動與應(yīng)用程序之間最新的視頻數(shù)據(jù)的更新。GIO類驅(qū)動具有如下接口,在函數(shù)表中指定設(shè)備的操作模式:
微驅(qū)動IOM通常包括如下函數(shù):通道綁定函數(shù)(mdBindDev),通道創(chuàng)建函數(shù)(mdCreateChan),通道刪除函數(shù)(mdDeleteChan),I/O請求發(fā)送函數(shù)(mdSubitChan),通道解綁定函數(shù)(mdUnBindDev)和設(shè)備控制函數(shù)(mdControlChan)。類驅(qū)動通過調(diào)用這些底層函數(shù)完成相應(yīng)外部設(shè)備與應(yīng)用程序之間的數(shù)據(jù)傳送通道的創(chuàng)建,以及外部設(shè)備和內(nèi)存空間的分配,控制各個線程之間數(shù)據(jù)傳送的同步等。這些規(guī)定好的底層函數(shù)將放入微驅(qū)動的函數(shù)接口表(IOM——Fxns)中的相應(yīng)位置,供應(yīng)用程序通過適配模塊或直接由GIO類驅(qū)動調(diào)用。IOM接口表的結(jié)構(gòu)如下:
在調(diào)用IOM微驅(qū)動之前,必須要先在DSP/BIOSConfig中注冊。在Device Drivers中右擊選擇插入一個設(shè)備驅(qū)動,命名為VPlACAPTURE,并進(jìn)行各個屬性(如函數(shù)表指針、函數(shù)表類型和設(shè)備ID號等)的配置,指明IOM_Fxns函數(shù)表地址和設(shè)備參數(shù)地址,如圖3所示。
2 DM642芯片視頻驅(qū)動程序設(shè)計(jì)
視頻驅(qū)動程序的設(shè)計(jì)主要包括微驅(qū)動、類驅(qū)動和中間接口3方面的設(shè)計(jì)。為了最大程度的提高視頻驅(qū)動代碼的復(fù)用性和通用性,在視頻采集驅(qū)動程序?qū)嵗校贕IO類驅(qū)動程序基礎(chǔ)上進(jìn)一步封裝成FVID類。將微驅(qū)動細(xì)分為視頻端口類和指定的編解碼芯片微驅(qū)動,二者之間通過外部設(shè)備控制接口(EDC)實(shí)現(xiàn)對外圍芯片的打開、控制和關(guān)閉等操作。這樣一來,即使所使用的板長上集成了不同的視頻編解碼芯片,也只需改變特定編解碼芯片的微驅(qū)動。視頻采集驅(qū)動程序的類/微驅(qū)動模型如圖4所示。
例如,對VPORT_PortParams接口的說明屬于對VPORT端口類的說明,而對SAA7121接口的說明則屬于對特定編碼芯片的說明。如果把VPORT類用于不同的芯片,則只需對SAA712l進(jìn)行修改。對EDC的接
下面舉例說明對FVID類驅(qū)動的視頻應(yīng)用程序接口(video API)的操作。就應(yīng)用程序而言,對設(shè)備驅(qū)動程序的操作可分為3個階段:創(chuàng)建、處理和刪除。創(chuàng)建是在應(yīng)用程序與外部設(shè)備之間建立一個數(shù)據(jù)輸入/輸出的邏輯通道,對應(yīng)于FVID_create;處理是在應(yīng)用程序與外部設(shè)備之間進(jìn)行數(shù)據(jù)的傳送,并對外設(shè)進(jìn)行相應(yīng)的控制,對應(yīng)于FVID_control和FVID_alloc;外設(shè)使用完畢后,相應(yīng)地刪除原先所建立的通道,對應(yīng)于FVTD_delete。具體的調(diào)用函數(shù)如下:
結(jié) 語
本文介紹了TI公司開發(fā)的類/微驅(qū)動模型和改進(jìn)后DM642的視頻類/微驅(qū)動模型。實(shí)踐表明,DM642的視頻類/微驅(qū)動模型降低了系統(tǒng)中軟硬件之間的耦合性,提高了驅(qū)動程序的可重用性和可移植性,簡化了視頻驅(qū)動程序的開發(fā)。
評論