0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

基于類/微型驅(qū)動模型的視頻驅(qū)動設計解決方案

電子設計 ? 來源:郭婷 ? 作者:電子設計 ? 2019-05-08 08:08 ? 次閱讀

通過給外部設備編寫驅(qū)動程序是一種有效的控制外設的方法。隨著DSP的應用越來越廣泛,DSP實時系統(tǒng)的日趨復雜及新技術的出現(xiàn),DSP處理器所連接的外部設備也是種類繁多,各不相同,而每一個外設都需要一個特定的驅(qū)動程序來支持外設的正常工作,這就要為每一個外設編寫驅(qū)動程序,這是一項十分繁雜的工作。如何能夠使系統(tǒng)開發(fā)人員從這些編寫繁雜的驅(qū)動程序工作中解脫出來,進而能夠?qū)P耐度氲綉贸绦虻拈_發(fā)中呢?TI公司提出了基于DSP/BIOS的設備驅(qū)動模型,該模型分為兩層:類驅(qū)動即與硬件不相關的層和微型驅(qū)動即與硬件相關的層。使用這種結(jié)構(gòu),應用程序只需調(diào)用類驅(qū)動的API函數(shù),通過類驅(qū)動使用微型驅(qū)動,用微型驅(qū)動來控制外設。這種結(jié)構(gòu),將驅(qū)動程序合理分層,使得驅(qū)動程序模塊化,可移植性、復用性大大增強,縮短了驅(qū)動程序的開發(fā)時間。

1 DSP/BIOS設備驅(qū)動模型工

1.1 類/微型驅(qū)動模型

DSP/BIOS是TI公司所設計開發(fā)的一個尺寸可裁剪的實時多任務操作系統(tǒng)內(nèi)核,通過使用DSP/BIOS提供的豐富的內(nèi)核服務,開發(fā)者能快速地創(chuàng)建滿足實時性能要求的精細復雜的多任務應用程序。為了使開發(fā)設備驅(qū)動更加簡單方便,提出了DSP/BIOS DeviceDriver Kit,定義了標準的設備驅(qū)動模型,一種將設備驅(qū)動分為與硬件無關和與硬件相關的雙層結(jié)構(gòu),這樣就使開發(fā)驅(qū)動程序不像以前那樣復雜了,為開發(fā)者提供了便利。這兩層結(jié)構(gòu)稱為“類/微型驅(qū)動模型,它們每一層都有各自通用的接口,所以相似設備驅(qū)動程序的主要部分可以復用,驅(qū)動代碼的移植成為可能,使開發(fā)驅(qū)動的過程大大簡化。

與硬件無關的層稱為類驅(qū)動(Class Driver),它處在應用程序與微型驅(qū)動之間,提供對多線程I/O請求的串行化和同步,并且維護設備數(shù)據(jù)緩沖區(qū),向上提供API接口供應用程序調(diào)用,向下通過適配層與微型驅(qū)動相連,實現(xiàn)API接口函數(shù)到微型驅(qū)動層的映射。

與硬件相關的層稱為微型驅(qū)動(Mini-driver),它處在類驅(qū)動與芯片支持庫(Chip Support Library)之間,對于類驅(qū)動的接口是統(tǒng)一的,即每一個微型驅(qū)動都為類驅(qū)動和DSP/BIOS設備驅(qū)動管理提供了標準接口。微型驅(qū)動采用芯片支持庫(CSL)管理外圍設備的寄存器、內(nèi)存和中斷資源。但由于硬件是千差萬別的,所以微型驅(qū)動對底層硬件的操作是根據(jù)硬件的不同而不同的。對于完成同樣功能的不同外設,只需稍加修改微型驅(qū)動,而不需重新編寫驅(qū)動程序,就可以實現(xiàn)驅(qū)動程序的移植與復用,使驅(qū)動程序的開發(fā)過程大大簡化。類/微型驅(qū)動模型結(jié)構(gòu)如圖1所示。

基于類/微型驅(qū)動模型的視頻驅(qū)動設計解決方案

1.2 類驅(qū)動

通過將應用軟件,驅(qū)動程序分層之后,可以看到,位于頂層的應用程序并不直接與微型驅(qū)動產(chǎn)生聯(lián)系,而是通過類驅(qū)動與微型驅(qū)動連接。每一種類驅(qū)動向上層應用程序提供一個API接口,并且與微型驅(qū)動接口進行通信。

DSP/BIOS定義了三種類驅(qū)動:流輸入輸出模塊(SIO),管道管理模塊(PIP),通用輸入輸出模塊(GIO)。其中,SIO和PIP分別需要使用適配器DIO和PIO來與微型驅(qū)動進行通信。SIO/DIO是基于流的I/O模型,使用異步方式來操作I/O,對于數(shù)據(jù)的讀寫、處理可以同時進行。PIP/PIO是基于管道的I/O模型,每個管道維護著一個被劃分為多個大小相同的幀的緩沖區(qū)。GIO類驅(qū)動采用基于流的同步I/O數(shù)據(jù)傳輸模式,適合大流量數(shù)據(jù)的傳輸,更適合文件系統(tǒng)。與SIO/DIO和PIP/PIO不同,GIO包含內(nèi)置的IOM(I/OManager輸入輸出管理)適配層,可以直接與微型驅(qū)動進行通信。

GIO模塊與其他兩個模塊相比,有一個很重要的特性,就是可以擴展API函數(shù)支持新的應用領域,這樣就實現(xiàn)了對GIO類驅(qū)動的擴展。這種可擴展API的特性正好可以用在視頻驅(qū)動開發(fā)方面。例如這種擴展可以滿足視頻設備存儲區(qū)的需要。另外,在提供了視頻驅(qū)動和應用程序之間的視頻數(shù)據(jù)同步機制之后,這種擴展也能夠允許使用一個單獨的調(diào)用來“交換”視頻緩沖區(qū)。這種交換緩沖區(qū)的機制對于實時視頻信號的采集與顯示是十分重要的。所以,在視頻驅(qū)動中,我們采用通用輸入輸出模塊GIO。應用程序可以直接地調(diào)用GIO API函數(shù)和IOM微型驅(qū)動程序進行交互,這些GIO API就可以看作是類驅(qū)動。GIO類驅(qū)動接口如圖2所示。

GIO_create會為一個特定的IOM通道實例創(chuàng)建一個GIO對象,這是類驅(qū)動使用微型驅(qū)動的第一步,首先創(chuàng)建對象及IOM通道,然后在此通道上進行數(shù)據(jù)傳輸工作。其結(jié)構(gòu)體類型為GIO_Obj:

基于類/微型驅(qū)動模型的視頻驅(qū)動設計解決方案

1.3 微型驅(qū)動

微型驅(qū)動主要通過一些函數(shù)來完成對外部設備的直接控制。只要微型驅(qū)動創(chuàng)建了規(guī)定的函數(shù),應用程序就可以方便地通過DIO適配模塊、PIo適配模塊或(和)GIO類驅(qū)動調(diào)用。

例如:GIO_create被調(diào)用時,會運行mdCreate-Chan來創(chuàng)建一個通道。

這些微型驅(qū)動函數(shù)包括:mdBindDev/mdUBind-Dev(綁定/刪除通道函數(shù)):在程序建立接口時調(diào)用,完成設備的初始化硬件設備/在程序結(jié)束時調(diào)用,卸載設備。mdCreateChan/mdDeleteChan(創(chuàng)建/刪除通道):需要在應用程序與設備實例之間創(chuàng)建一個邏輯通信通道,用于交換驅(qū)動數(shù)據(jù)。應用程序可創(chuàng)建一個或多個邏輯通道,微型驅(qū)動用通道對象來代表這些通道。這兩個函數(shù)就是用來分配和釋放通道對象。mdSubmitChan(遞交I/O請求):該函數(shù)處理傳遞給它的IOM_Pack-et結(jié)構(gòu)體中的命令代碼(cmd),根據(jù)命令代碼,完成相應的處理或返回錯誤代碼。ISR(服務設備中斷并完成I/O操作):IOM微型驅(qū)動在中斷的ISR中將以處理完的IOM_Packet請求出隊,啟動下一次傳輸或服務請求,調(diào)用類驅(qū)動的回調(diào)函數(shù)與應用程序進行同步,并返回出隊的IOM_Packet。mdControlChan(控制設備):用來操作外部設備。

這些微型驅(qū)動的函數(shù)入口放在接口表(IOM_Fxns)中,供適配模塊或GIO類驅(qū)動調(diào)用。

2 TMS320DM642視頻驅(qū)動

下面以TMS320DM842芯片為例,介紹有關TMS320DM642視頻采集與顯示的驅(qū)動程序的開發(fā)。通過編寫驅(qū)動程序,完成視頻信號的實時采集與顯示功能。TMS320DM642是TI公司推出的一款專門用于視頻/圖像處理的定點數(shù)字信號處理器,它基于C64x內(nèi)核,帶有3個可配置的視頻端口,與視頻采集芯片直接相連,無需外加邏輯電路或FIFO緩存,只需編寫相關解編碼芯片的驅(qū)動程序,就可以完成視頻信號的采集與顯示。在這里使用的解碼、編碼芯片分別為PHILIPS SAA7115和SAA7105。

2.1 視頻類驅(qū)動

在視頻驅(qū)動程序結(jié)構(gòu)中,為了最大程度地提高視頻驅(qū)動代碼的復用性和通用性,將類驅(qū)動又劃分為兩層結(jié)構(gòu),其中上層為FVID模型,它是在DSP/BIOS GIO類驅(qū)動之上的簡單封裝,下層是GIO類驅(qū)動程序。GIO類驅(qū)動提供獨立的、一般的API函數(shù)集并且為微型驅(qū)動提供廣泛的服務,而上層的FVID模型向上層的視頻采集、顯示結(jié)構(gòu)提供定制的API函數(shù)。

在視頻驅(qū)動中,主要是通過調(diào)用FVID模塊函數(shù)來完成類驅(qū)動代碼的編寫工作。FVID主要有以下幾個API函數(shù):FVID_create:分配并初始化通道對象;FVID_control:向微型驅(qū)動發(fā)送控制命令;FVID_al-loc:向應用程序分配視頻端口緩沖區(qū);FVID_ex-change:交換緩沖區(qū);FVID_free:釋放緩沖區(qū);FVID_delete:刪除通道對象。

在配備視頻接口的設備驅(qū)動時,至少指定它要開設3個以上的視頻緩沖區(qū)(FVID模型中,默認分配3個緩沖區(qū)),幀緩沖區(qū)通過FVID_alloc(),F(xiàn)VID_free(),F(xiàn)VID_exchange()三個函數(shù)在應用程序與驅(qū)動之間交換。

2.2 視頻微型驅(qū)動

視頻微型驅(qū)動也分為兩層結(jié)構(gòu),上層為通用視頻端口層部分,下層為指定編解碼芯片微驅(qū)動層部分,它們通過外部設備控制接口(External Device Control,EDC)實現(xiàn)對外圍芯片的操作。這種微驅(qū)動結(jié)構(gòu)的好處是,當使用不同的芯片時,只需修改指定編解碼芯片微驅(qū)動那一部分,不需將整個微驅(qū)動重新編寫,使得驅(qū)動的復用性大大增強。

視頻驅(qū)動程序模型如圖3所示。

基于類/微型驅(qū)動模型的視頻驅(qū)動設計解決方案

2.3 TMS320DM642視頻驅(qū)動設計步驟

2.3.1 注冊微型驅(qū)動

由于應用程序、類驅(qū)動最終都是要通過微型驅(qū)動的函數(shù)來完成對外部設備的直接控制,所以驅(qū)動程序設計的第一步就是要在DSP/BIOS Config中的Input/Output->Device Drivers->Uger-Defined Devices項目添加設備并注冊微驅(qū)動,進行屬性的設置,并指明IOM_Fxns函數(shù)表地址和設備參數(shù)地址,如圖4所示。

DSP/BIOS會在內(nèi)部維護一個“設備表”,其中包含User-Defined Devices對象進行配置的設備實例。

2.3.2 編寫類驅(qū)動代碼

FVID函數(shù)會在設備表中查找已注冊的微驅(qū)動,并調(diào)用微驅(qū)動函數(shù)完成對外部設備的操作控制。

通常,首先利用FVID_create函數(shù)完成分配并初始化通道對象,返回值為設備實例句柄,這個句柄用于后續(xù)其他FVID函數(shù)調(diào)用這個已經(jīng)創(chuàng)建的通道。然后調(diào)用FVID_control函數(shù)向微型驅(qū)動發(fā)送控制命令,如配置編解碼器,發(fā)送開始采集或顯示圖像的控制命令。然后利用FVID_alloc分配緩沖區(qū),接著應用程序?qū)⒕彌_區(qū)的數(shù)據(jù)進行復制的搬移工作,當應用程序完成對緩沖區(qū)數(shù)據(jù)的采集后,調(diào)用FVID_exchange來交換緩沖區(qū),保證視頻數(shù)據(jù)能夠?qū)崟r地、源源不斷地供應用程序使用。

過程的流程圖如圖5所示。

基于類/微型驅(qū)動模型的視頻驅(qū)動設計解決方案

下面是簡單的視頻采集顯示驅(qū)動的部分實現(xiàn)代碼:

3 結(jié) 語

本文介紹了基于TI公司的類/微型驅(qū)動模型進行視頻驅(qū)動設計的原理及主要方法,利用這兩層的驅(qū)動模型不僅簡化了驅(qū)動程序的編寫過程,縮短了開發(fā)時間,而且使代碼的復用性和可移植性大大提高,稍加改動相應的底層接口就可以用于其他的DSP系統(tǒng)中,真正使視頻驅(qū)動的開發(fā)過程得到簡化。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • dsp
    dsp
    +關注

    關注

    552

    文章

    7920

    瀏覽量

    347647
  • ti
    ti
    +關注

    關注

    112

    文章

    7948

    瀏覽量

    211921
  • 視頻
    +關注

    關注

    6

    文章

    1925

    瀏覽量

    72719
收藏 人收藏

    評論

    相關推薦

    驅(qū)動電機解決方案

    就像每個MOSFET需要一個柵極驅(qū)動器來切換它,每個電機后面總是有一個驅(qū)動力。根據(jù)復雜程度和系統(tǒng)成本、尺寸和性能要求,驅(qū)動電機的方式多樣。最簡單和離散的解決方案是由兩個晶體管組成的圖騰
    發(fā)表于 03-08 06:45

    基于signoff驅(qū)動的PrimeECO解決方案

    業(yè)內(nèi)首個signoff驅(qū)動的PrimeECO解決方案發(fā)布
    發(fā)表于 11-23 14:28

    怎么實現(xiàn)基于/微驅(qū)動模型視頻采集驅(qū)動程序?

    本文針對自行研制的基于TMS320DM642(以下簡稱DM642)DSP的視頻處理板卡,使其在C64x系列DSP的實時操作系統(tǒng)DSP/BIOS的環(huán)境下運行,實現(xiàn)基于/微驅(qū)動模型
    發(fā)表于 06-08 06:03

    怎樣利用/微驅(qū)動模型去開發(fā)DSP視頻驅(qū)動程序?

    怎樣利用/微驅(qū)動模型去開發(fā)DSP視頻驅(qū)動程序?
    發(fā)表于 06-08 06:07

    安森美LED照明驅(qū)動解決方案

    安森美LED照明驅(qū)動解決方案
    發(fā)表于 04-14 15:50 ?57次下載
    安森美LED照明<b class='flag-5'>驅(qū)動</b><b class='flag-5'>解決方案</b>

    LED驅(qū)動解決方案

    英飛凌的LED驅(qū)動方案講解,包括Buck架構(gòu)驅(qū)動、PWM架構(gòu)驅(qū)動、PFC控制、Flyback架構(gòu)
    發(fā)表于 12-17 11:48 ?4次下載

    關于LCD直接驅(qū)動解決方案的介紹

    LCD直接驅(qū)動解決方案
    的頭像 發(fā)表于 07-23 05:04 ?4743次閱讀

    /微驅(qū)動模型開發(fā)DSP視頻驅(qū)動程序的方法

    關鍵詞:dsp , 驅(qū)動程序 , 驅(qū)動模型 , 視頻 近年來,DSP運算能力的不斷增強,使其在電子設備方面得到了廣泛的應用。DSP/BIOS是TI公司推出的一個實時操作系統(tǒng),與TI的C
    發(fā)表于 01-09 16:45 ?382次閱讀

    基于DSP的視頻采集驅(qū)動程序的實現(xiàn)

    ,基于DSP的海量視頻數(shù)據(jù)的實時處理的關鍵則是實時、合理的視頻數(shù)據(jù)采集。本文針對自行研制的基于TMS320DM642(以下簡稱DM642)DSP的視頻處理板卡,使其在C64x系列DSP的實時操作系統(tǒng)DSP/BIOS的環(huán)境下運行,
    發(fā)表于 02-03 00:09 ?514次閱讀

    基于TMS320DM642視頻采集驅(qū)動開發(fā)

    采集驅(qū)動的原理。 結(jié)合TMS320DM642芯片/微型驅(qū)動模型,提供了按幀采集ITU-R BT.656數(shù)據(jù)
    發(fā)表于 02-03 00:13 ?482次閱讀

    /微驅(qū)動模型開發(fā)DSP視頻驅(qū)動程序

    關鍵詞:dsp , /微 , 驅(qū)動程序 , 驅(qū)動模型 , 視頻 近年來,DSP運算能力的不斷增強,使其在電子設備方面得到了廣泛的應用。DS
    發(fā)表于 02-09 22:58 ?512次閱讀

    高性能伺服驅(qū)動解決方案展示

    視頻展示高性能伺服驅(qū)動解決方案。 其中討論了硬件、參考設計和支持模型,并介紹了ADI公司聯(lián)合Avnet、Xilinx、MathWorks開發(fā)的Zynq智能
    的頭像 發(fā)表于 06-13 06:17 ?4656次閱讀
    高性能伺服<b class='flag-5'>驅(qū)動</b>的<b class='flag-5'>解決方案</b>展示

    泰克變頻驅(qū)動測試解決方案

    泰克變頻驅(qū)動測試解決方案免費下載。
    發(fā)表于 06-21 10:44 ?7次下載

    電機驅(qū)動方案調(diào)研

    框架 根據(jù)上表的電機方案, 按照MCU硬件架構(gòu)分類可以分成兩,一是帶驅(qū)動,另一是不帶驅(qū)動
    發(fā)表于 03-16 14:08 ?3次下載
    電機<b class='flag-5'>驅(qū)動</b><b class='flag-5'>方案</b>調(diào)研

    電機控制和驅(qū)動設計解決方案

    電子發(fā)燒友網(wǎng)站提供《電機控制和驅(qū)動設計解決方案.pdf》資料免費下載
    發(fā)表于 11-17 10:43 ?10次下載
    電機控制和<b class='flag-5'>驅(qū)動</b>設計<b class='flag-5'>解決方案</b>