嵌入式Linux下的AU1200MAE驅動(dòng)程序設計
MAE前端的輸入數據是一系列的數據宏塊,宏塊數據以及頭信息、系數矩陣、運動(dòng)向量等都以DMA的方式傳送給MAE。所以在程序中首先要定義指針maefe_dmadscr[PTR]來(lái)描述DMA。并把maefe_dreadbell[DB]寄存器設置為1來(lái)啟動(dòng)DMA控制器。頭信息一共包含4個(gè)word,每個(gè)word有32 b,這4個(gè)word分別保存到AU 1200寄存器mae_hdr0到mae_hdr3中,這些word包含了關(guān)于編碼宏塊的信息,如量化參數,運動(dòng)補償參數,變換運算等信息。
驅動(dòng)程序首先要把每一幀的地址寫(xiě)入MAE的相關(guān)寄存器中,在每處理一幀后,上述宏塊信息都要及時(shí)更新。MAE的前端對宏塊數據進(jìn)行反量化,其結果輸入至逆變換單元進(jìn)行逆變換運算。逆變換運算單元通過(guò)查看maefe_config寄存器的COD標志位來(lái)決定采用哪種標準的視頻Cod-ec,從而執行相應的運算。逆變換運算完成后,數據送入運動(dòng)補償單元。運動(dòng)補償單元根據運動(dòng)向量計算出參考像素值,并把它們插入當前幀中,從而完成一次解碼。以上過(guò)程通過(guò)編寫(xiě)函數fe_process_mb來(lái)實(shí)現,該函數的幾個(gè)參數分別是:
mae_fe_cfg:MAE前端的配置信息;mb_in:輸入的宏塊數據;cur_y_frame:當前幀Y分量;cur_cb_frame:當前幀Cb分量;cur_cr_fr-ame:當前幀Cr分量;mb_num:表示宏塊數據的序號。該函數的流程圖如圖3所示。
函數中的關(guān)鍵部分及說(shuō)明注釋如下所示:
3.2 驅動(dòng)軟件測試
將以上程序交叉編譯,生成mae-driver.ko,動(dòng)態(tài)加載到Linux內核:#insmod - f mae-driver.ko。用MAIplayer驗證是否可以正常工作:?jiǎn)?dòng)minicom,進(jìn)入MAIplayer所在路徑,該路徑下有編譯好的播放器應用程序及各種視頻解碼庫。執行視頻文件播放命令MYM./maipl-ayer auto-a-l jolin.mpg。播放效果如圖4所示。經(jīng)測試,MAIplayer可正常播放多媒體視頻,說(shuō)明MAE已被驅動(dòng)起來(lái)完成視頻解碼工作。
4 結語(yǔ)
本文給出了AU 1200 MAE驅動(dòng)程序開(kāi)發(fā)的流程,包括開(kāi)發(fā)環(huán)境的搭建及驅動(dòng)程序的編寫(xiě)。MAE作為AU 1200片上專(zhuān)用于圖像、視頻的外部設備,相當于一個(gè)視頻協(xié)處理器。它的使用大大提高了MIPS核的工作效率,而以AU 1200為核心的多媒體終端具有更低的成本,因此。其市場(chǎng)前景將更加廣闊。
linux操作系統文章專(zhuān)題:linux操作系統詳解(linux不再難懂)
評論