《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 通信與網(wǎng)絡(luò) > 解決方案 > 用開源API處理DSP視頻

用開源API處理DSP視頻

2010-11-04
來源:電子工程專輯
關(guān)鍵詞: IPTV|VoIP API DSP

數(shù)字信號處理器(DSP)具有出色的多媒體性能。一般而言,它們運行編解碼器所需的周期只有通用處理器(GPP)內(nèi)核的40%到50%。DSP還能提供比ASIC大得多的靈活性和可重配置性。但迄今為止,要在數(shù)字視頻應(yīng)用中運用DSP,編程人員還不得不花費較多時間精力去學(xué)習(xí)相關(guān)專用語言。不過,隨著應(yīng)用編程接口(API)的出現(xiàn),已不再需要學(xué)習(xí)這些專用DSP語言了。在運行于GPP上的應(yīng)用中,API可以輕輕松松地充分發(fā)揮DSP的優(yōu)勢。

開源多媒體構(gòu)架在GPP上一般運行在Linux操作系統(tǒng)下,是這些API的理想對象。利用API可以卸載視頻編解碼器的計算負(fù)荷,大大減小DSP編程的復(fù)雜性。這種方案只要求編程人員具備基本的DSP知識即可,無需編寫代碼來整合DSP功能與那些運行在GPP上的功能。這種優(yōu)勢,加上利用免費開源插件和構(gòu)架提供的許多功能的能力,可以大幅度縮短新視頻產(chǎn)品的上市時間。

硬件平臺的選擇

在選擇運行編解碼器(壓縮傳輸或存儲的數(shù)字流,再解壓以供查看或編輯)的硬件平臺時,開發(fā)人員有幾種可選方案。ASIC是專門為數(shù)字視頻應(yīng)用而設(shè)計的,能在這類應(yīng)用中提供高性能和低功耗。它的缺點流片(NRE)費用很高。此外,ASIC若有變化,比如改動以適應(yīng)編解碼標(biāo)準(zhǔn),相關(guān)實現(xiàn)費用非常高昂。

另一方面,GPP內(nèi)核的流片費用相對較低,針對變動進(jìn)行重編程相當(dāng)容易。但由于它們在執(zhí)行計算密集的信號處理應(yīng)用時效率低下,故在應(yīng)用于數(shù)字視頻處理時性能較低。例如,GPP通過一系列移位和加法運算來實現(xiàn)乘法運算,而每一個移位和加法運算需要一個以上的時鐘周期。

DSP具有集上述二者之優(yōu)勢的潛力。不同于GPP,DSP是為數(shù)字視頻應(yīng)用中計算密集的信號處理應(yīng)用而優(yōu)化的。它具有單周期乘法器或乘法累加單元,能夠加快編解碼算法的執(zhí)行速度。更高性能的DSP還包含有幾個可以并行操作的獨立執(zhí)行單元,這使得它們能夠每條指令執(zhí)行好幾個操作。此外,DSP還提供完全的軟件編程能力,包括現(xiàn)場重編程能力。這就讓用戶可以先推出MPEG-2產(chǎn)品,以后再升級為H.264視頻編解碼器。DSP在數(shù)字視頻應(yīng)用中的主要局限是它們通常需要采用專用語言來編程,而熟悉DSP的編程人員遠(yuǎn)沒有熟悉流行的GPP架構(gòu)的來得多。

圖1:只含解碼器的范例中的多媒體框架職責(zé)和數(shù)據(jù)流程

組件集成的挑戰(zhàn)

數(shù)字視頻系統(tǒng)的開發(fā)人員還面臨著集成的挑戰(zhàn)。數(shù)字視頻系統(tǒng)包含了多個編碼器、解碼器、編解碼器、多種算法及其它軟件,這些組件都必須集成到一個可執(zhí)行映象(image)中,然后才能在系統(tǒng)上運行內(nèi)容。集成所有這些組件并確保其運行協(xié)調(diào)是一件很困難的任務(wù)。不同的系統(tǒng)可能需要截然不同的視頻、圖像、語音、音頻和其他多媒體模塊。手工集成每一個軟件模塊或算法的開發(fā)人員就被增值功能性(比如增加創(chuàng)新性功能)搞得頭痛不已。

許多數(shù)字視頻開發(fā)人員都開始采取開源途徑來構(gòu)建軟件。一種常用的方案是從開源獲得軟件的重要部分,而在可用性和硬件集成方面充分發(fā)揮內(nèi)部專業(yè)能力。開發(fā)人員常常參與開源技術(shù)開發(fā)項目,以滿足特定要求并把內(nèi)部開發(fā)的代碼和開源代碼集成在一起來創(chuàng)建新產(chǎn)品。

新的API

為了解決上述問題,德州儀器(TI)開發(fā)出了一款A(yù)PI,該產(chǎn)品能夠充分發(fā)揮開源多媒體框架中的GStreamer等DSP的優(yōu)勢。這款A(yù)PI使多媒體編程人員可以利用熟悉環(huán)境中的DSP編解碼引擎,把數(shù)字視頻編程人員從復(fù)雜的DSP編程中解放出來,讓ARM/Linux開發(fā)人員得以輕松利用DSP編解碼器的加速功能,無需具備相關(guān)硬件知識。該接口還能自動高效地在ARM和DSP間進(jìn)行工作劃分,從而不再需要為運行在DSP上和運行在GPP內(nèi)核上的功能間的協(xié)調(diào)而編寫代碼。該接口已由TI按照開源社群標(biāo)準(zhǔn)以GStreamer插件的形式開發(fā)成功。

圖2:GStreamer內(nèi)數(shù)據(jù)通過GstBuffer結(jié)構(gòu)進(jìn)行表征的方法與其它幾種操作系統(tǒng)及其相應(yīng)多媒體框架所采取的方法相一致。

GStreamer是一種媒體處理庫,提供了某種轉(zhuǎn)換過程的抽象模型,其通過管道的概念進(jìn)行工作,媒體在其中按照已定義的方向從輸入流到輸出。GStreamer能夠以一種簡化編程過程的方式來提取不同媒體的操作行為,在數(shù)字視頻編程社群中廣受歡迎。通過GStreamer,能夠編寫出一種能夠支持多種不同格式和網(wǎng)絡(luò)的通用視頻或音樂播放器。而且大部分操作由插件執(zhí)行,并非GStreamer內(nèi)核。GStreamer的基本功能性主要與注冊和加載插件有關(guān),并可提供基類,這些基類定義了GStreamer類的基本功能。

GStreamer過濾器

源過濾器負(fù)責(zé)從從數(shù)據(jù)源獲取原始的多媒體數(shù)據(jù)以供處理,這里的數(shù)據(jù)源可以是硬盤文件(比如文件源過濾器),或CD或DVD光盤,也可以是電視接收卡或網(wǎng)絡(luò)這種“實時”源。某些源過濾器只是簡單地把原始數(shù)據(jù)傳遞到剖析器(parser)或分離過濾器(splitter filter),同時其它源過濾器也執(zhí)行自己的剖析步驟。變換過濾器 (Transform filter)接收原始數(shù)據(jù)或部分經(jīng)過處理的數(shù)據(jù),進(jìn)一步處理后再傳遞到下一級過濾器。

變換過濾器有多種類型,剖析器即是一例。這種過濾器把原始字節(jié)流分離為多個樣本或幀、壓縮器或解壓縮器,以及格式轉(zhuǎn)換器。呈現(xiàn)過濾器(Renderer filter)一般接收完全處理過的數(shù)據(jù),并在系統(tǒng)顯示器上或通過揚聲器或某些外部設(shè)備進(jìn)行播放。這一類過濾器還包括“file writer (文件創(chuàng)建器)”過濾器和網(wǎng)絡(luò)傳輸過濾器,前者可以把數(shù)據(jù)保存到硬盤或其它持久穩(wěn)固的存儲設(shè)備上。

數(shù)據(jù)處理在plug-in_chain() 或 plug-in_loop()函數(shù)中進(jìn)行。該函數(shù)可能像元件縮放那么簡單,也可能像真實的MP3解碼器那么復(fù)雜。數(shù)據(jù)被處理后,利用一個gst_pad_push()函數(shù)從GStreamer元件(element)的源襯墊(pad)發(fā)送出去,由此把數(shù)據(jù)傳遞到管道鏈的下一個元件。

GStreamer緩沖器

在GStreamer中,緩沖器是數(shù)據(jù)傳輸?shù)幕締卧stBuffer(實例)類提供了把一個存儲區(qū)定義為流媒體的一部分所必需的全部狀態(tài)。經(jīng)由GstBuffer結(jié)構(gòu),Gstreame內(nèi)部的數(shù)據(jù)表示遵循幾種其它操作系統(tǒng)及其各自的多媒體構(gòu)架所采用的方法(比如,Microsoft DirectShow中的媒體采樣概念)。此外,還支持次級緩沖器,允許緩沖器的一小部分成為它自己的緩沖器,利用這種處理機制確保了存儲空間不會過早釋放。

圖3:復(fù)用已分配在驅(qū)動器上且在物理上是連續(xù)的緩沖的一種有效途徑。

緩沖器通常利用gst_buffer_new()來創(chuàng)建。創(chuàng)建好一個緩沖器之后,一般是為它分配存儲器,設(shè)置緩沖器數(shù)據(jù)的大小。下面給出了一個緩沖器創(chuàng)建的例子,該緩沖器能夠保存具有給定寬度、高度和每像素位的視頻幀。

緩沖器創(chuàng)建

基于DaVinci技術(shù)的DM644x器件上ARM926的MMU(存儲器管理單元)具有虛擬/物理尋址能力。然而,C64x+DSP內(nèi)核只能夠處理物理地址。因此,用于DSP處理的輸入和輸出緩沖器必須駐存在物理上連續(xù)的存儲器中。

虛擬到物理地址的轉(zhuǎn)換由編解碼引擎處理。通過復(fù)用(指針指向)某些由驅(qū)動器分配的緩沖器,可獲得物理上連續(xù)的存儲器,這里使用了Linux中的一些技術(shù),比如dma_alloc_coherent(),來在內(nèi)核空間中分配這類存儲器。由TI開發(fā)的庫/內(nèi)核模塊CMEM,允許從用戶空間應(yīng)用來分配物理上連續(xù)的存儲器。

例如,我們利用前面提到的CMEM驅(qū)動器來分配物理上連續(xù)的“輸出”緩沖器。編解碼引擎對幀進(jìn)行解碼,并把解碼后的幀放在輸出緩沖器中。

接下來,指向輸出緩沖器的指針被傳遞給fbvideosink(通過 GstBuffer)。這個videosink必須把解碼后的數(shù)據(jù)memcpy(復(fù)制)到幀緩存中,然后才能顯示。由于memcpy操作是一種成本很高的GPP使用,這種方法使得ARM 和DDR接口的負(fù)載很重,因而增加了功耗,且效率極低。

這種技術(shù)對非常小的緩沖器是可行的,但在開發(fā)人員使用D1(和更高)大小的緩沖器時,將開始降低系統(tǒng)性能。一種更有效的方案是復(fù)用已經(jīng)驅(qū)動器分配了的物理連續(xù)緩沖器,并在編解碼器引擎和videosink插件之間把指向這些緩沖器的指針來回傳遞。幸運的是,GStreamer提供了一個便于這類交互作用的API。

這個API替代方案利用gst_buffer_new()來創(chuàng)建新的緩沖器。當(dāng)元件獲知它將在哪一個源襯墊上推動數(shù)據(jù)時,就對gst_pad_alloc_buffer()函數(shù)進(jìn)行調(diào)用。這允許對應(yīng)的元件為調(diào)用元件的工作提供特殊的“硬件”緩沖器,故而減少了系統(tǒng)所需的memcpys數(shù)量。

視頻解碼器插件(變換過濾器,通過編解碼器引擎API能夠充分利用DSP的優(yōu)勢)將把從視頻呈現(xiàn)過濾器獲得的緩沖器用作視頻解碼器和執(zhí)行解碼的輸出緩沖器。一旦解碼完成,這個輸出緩沖器將被推動(即指針被傳遞)給視頻呈現(xiàn)過濾器插件。由于解碼后的圖像已經(jīng)存在于視頻驅(qū)動存儲器中,就不再需要memcpy了,在幀被顯示時,視頻呈現(xiàn)過濾器將只需把目前的顯示緩沖器轉(zhuǎn)換為這種特定的緩沖器就可以了。

AV同步處理

播放期間的音頻/視頻(AV)同步處理一般需要三類決策:一是重復(fù)幀的決策。一般在媒體流的幀的顯示時間比幀間隔時間更大時采用。二是顯示幀的決策。一般在媒體流的幀的顯示時間在最小和最大閾值之間時采用。三是跳幀決策。一般在幀的顯示時間落后顯示時間至少兩個幀時采用。這樣,跳過當(dāng)前幀,處理下一個幀,以期彌補下一個幀間隔。持續(xù)這樣做直到下一個幀被顯示或不再剩有幀可供比較。

另外,管道中的所有元件都使用共同的時鐘,以便于這些活動的進(jìn)行。幸運的是,所有這些決策都由GStreamer內(nèi)核庫中的音頻視頻sink基類來完成。這樣一來,AV同步的復(fù)雜性大部分都在用戶那里被轉(zhuǎn)移了。

以插件形式開發(fā)的接口

TI開發(fā)了一種GStreamer變換過濾器插件,它利用DSP來進(jìn)行視頻解碼,運行于ARM上,使用Linux操作系統(tǒng)。TI還提供有Linux外設(shè)驅(qū)動器,在驅(qū)動器接口和編解碼引擎API方面符合標(biāo)準(zhǔn)開源機構(gòu)的要求,后者注意了DSP編程的相當(dāng)大部分的復(fù)雜性。由硬件制造商提供的API,事先已針對硬件實現(xiàn)做了優(yōu)化。如果改用新的硬件,無需改變應(yīng)用代碼就可直接替以新的驅(qū)動器。這種方案大幅度降低了視頻開發(fā)的成本和交付周期。

硬件的計算資源以一種最優(yōu)方式被執(zhí)行,無需任何匯編編程。其中包括很多復(fù)雜的操作,比如DSP資源的最佳利用,和基于硬件的加速引擎;鏈接模式(chained mode)下增強型直接存儲器訪問(Enhanced Direct Memory Access)外設(shè)的使用,

以提高數(shù)據(jù)傳輸效率;以及中斷模式和tasklet模式的數(shù)據(jù)包處理,以靈活滿足不同應(yīng)用的要求。

由于GStreamer是一種非常流行、廣為人知的架構(gòu),它已成為數(shù)字視頻開發(fā)的一種標(biāo)準(zhǔn),在這種環(huán)境中充分利用 DSP優(yōu)勢的能力使得編程人員不再需要學(xué)習(xí)專用DSP編程語言。

該方案還易于把DSP的功能和GPP內(nèi)核上運行的典型應(yīng)用的一些其他要求集成在一起。利用其他GStreamer插件,可以把解碼編碼與數(shù)字視頻應(yīng)用所需的其他操作相結(jié)合。這種多媒體架構(gòu)通過把各種本來需要手工編碼的操作整合在一起來實現(xiàn)集成。

總而言之,這一新接口能夠利用GStreamer Linux多媒體構(gòu)架來充分發(fā)揮TI的DaVinci處理器平臺的軟件基礎(chǔ)架構(gòu)的優(yōu)勢。這種整合型的基礎(chǔ)架構(gòu)提供了靈活的構(gòu)架,能夠適應(yīng)新一代多媒體編解碼器的要求。

該軟件架構(gòu)可以實現(xiàn)各式廣泛的視頻產(chǎn)品的設(shè)計。利用這種開源結(jié)構(gòu),能為視頻設(shè)備設(shè)計人員提供社群支持、穩(wěn)健的基礎(chǔ)架構(gòu),從而縮短上市時間。

本站內(nèi)容除特別聲明的原創(chuàng)文章之外,轉(zhuǎn)載內(nèi)容只為傳遞更多信息,并不代表本網(wǎng)站贊同其觀點。轉(zhuǎn)載的所有的文章、圖片、音/視頻文件等資料的版權(quán)歸版權(quán)所有權(quán)人所有。本站采用的非本站原創(chuàng)文章及圖片等內(nèi)容無法一一聯(lián)系確認(rèn)版權(quán)者。如涉及作品內(nèi)容、版權(quán)和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當(dāng)措施,避免給雙方造成不必要的經(jīng)濟(jì)損失。聯(lián)系電話:010-82306118;郵箱:aet@chinaaet.com。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
亚洲国产精品一区在线观看不卡 | 亚洲欧美自拍偷拍| 国产一区二区高清| 国产精品爱久久久久久久| 欧美激情精品久久久久久久变态 | 国产日韩欧美三区| 国产精品一区二区久久精品| 欧美小视频在线| 欧美三区在线| 欧美视频在线观看免费| 欧美日韩美女在线观看| 欧美精品99| 欧美乱大交xxxxx| 欧美另类变人与禽xxxxx| 欧美福利一区二区| 欧美精品不卡| 欧美日韩a区| 欧美四级在线观看| 国产精品久久久久99| 国产精品久久久久久久久免费樱桃 | 美女被久久久| 欧美电影免费观看高清| 欧美福利专区| 欧美日韩国产综合久久| 欧美性做爰猛烈叫床潮| 国产精品久久久久毛片软件| 国产精品国产精品国产专区不蜜| 国产精品大片免费观看| 国产麻豆日韩欧美久久| 国产伊人精品| 亚洲国产日日夜夜| 99精品视频一区二区三区| 这里只有视频精品| 午夜视频一区| 亚洲精品久久久久| 亚洲视频免费在线观看| 午夜一区二区三区不卡视频| 欧美自拍偷拍| 牛夜精品久久久久久久99黑人 | 亚洲自拍三区| 性高湖久久久久久久久| 亚洲第一中文字幕| 99国产麻豆精品| 亚洲欧美在线播放| 久久婷婷国产综合国色天香| 欧美电影在线播放| 国产精品成人久久久久| 国产夜色精品一区二区av| 亚洲第一精品久久忘忧草社区| 亚洲精选在线| 香蕉成人伊视频在线观看| 亚洲日本欧美日韩高观看| 亚洲女女女同性video| 久久久精品午夜少妇| 欧美激情精品久久久久久蜜臀| 国产精品电影在线观看| 狠狠色综合网| 一本久道久久久| 久久国产加勒比精品无码| 亚洲免费观看高清完整版在线观看熊 | 99re这里只有精品6| 亚洲欧美在线网| 99re热精品| 久久精品国产欧美激情| 欧美精品国产精品| 国产日韩欧美一区二区三区在线观看 | 国产精品永久免费观看| 亚洲电影自拍| 亚洲欧美福利一区二区| 最新热久久免费视频| 亚洲免费网址| 免费不卡亚洲欧美| 国产精品进线69影院| 1204国产成人精品视频| 亚洲一区成人| 一本色道久久精品| 久久亚洲精品伦理| 国产精品欧美日韩一区| 最新日韩在线视频| 亚洲成在线观看| 亚洲女爱视频在线| 欧美精品在线一区二区三区| 国产视频精品xxxx| 中日韩视频在线观看| 亚洲国产一区二区三区a毛片| 午夜精品理论片| 欧美精品一区二区在线观看| 国产一区二区成人久久免费影院| 一本色道久久综合一区| 亚洲人成人99网站| 久久久久.com| 国产伦精品一区二区三区免费迷| 亚洲精品美女91| 91久久精品国产91性色tv| 欧美一级一区| 国产精品成人免费视频| 亚洲精品婷婷| 亚洲精品免费在线观看| 噜噜爱69成人精品| 国产婷婷精品| 亚洲欧美日韩成人| 亚洲欧美另类久久久精品2019| 欧美精品免费看| 亚洲高清在线视频| 亚洲黄页一区| 免费观看成人鲁鲁鲁鲁鲁视频| 国产在线精品成人一区二区三区 | 国产精品久久久亚洲一区 | 亚洲五月六月| 欧美日韩亚洲在线| 亚洲精品乱码久久久久| 亚洲精品字幕| 欧美成人久久| 亚洲国产导航| 亚洲精品在线观看视频| 欧美成人69av| 91久久嫩草影院一区二区| 亚洲国产网站| 欧美国产三区| 亚洲国产精品高清久久久| 亚洲欧洲精品一区二区三区 | 99视频精品在线| 欧美激情一区二区三区高清视频| 亚洲电影免费| 亚洲日韩欧美一区二区在线| 免费成人黄色片| 亚洲国产毛片完整版| 亚洲人成在线播放| 欧美精品18+| 亚洲精品欧洲精品| 国产精品99久久久久久人| 欧美日韩国产综合新一区| 亚洲美女黄网| 亚洲一区尤物| 国产乱码精品1区2区3区| 午夜精品成人在线| 久久久久久久综合| 在线精品福利| 99av国产精品欲麻豆| 欧美午夜电影在线| 亚洲小视频在线观看| 先锋资源久久| 国产在线不卡视频| 最新亚洲激情| 欧美视频国产精品| 亚洲欧美中文另类| 老司机精品久久| 亚洲精品久久久久中文字幕欢迎你| 亚洲午夜精品网| 国产精品一香蕉国产线看观看| 欧美一区二视频| 欧美.日韩.国产.一区.二区| 亚洲精品免费在线观看| 亚洲小说欧美另类社区| 国产精自产拍久久久久久| 久久精品国产91精品亚洲| 欧美大片在线看| 一区二区免费在线播放| 香蕉久久久久久久av网站| 国语自产在线不卡| 亚洲美女黄色| 国产精品美女黄网| 亚洲第一偷拍| 欧美系列亚洲系列| 久久精品国产久精国产爱| 欧美人与禽猛交乱配视频| 亚洲永久免费精品| 欧美成人精品在线视频| 制服丝袜亚洲播放| 狂野欧美激情性xxxx欧美| 亚洲美洲欧洲综合国产一区| 欧美一二三视频| 亚洲福利精品| 亚欧成人在线| 亚洲激情影院| 久久av资源网站| 亚洲精品一区二区在线观看| 先锋影院在线亚洲| 最近中文字幕日韩精品| 欧美一级黄色网| 亚洲日韩视频| 久久亚洲不卡| 亚洲一区免费看| 欧美激情第8页| 欧美一区二区在线看| 欧美午夜激情小视频| 亚洲国产婷婷香蕉久久久久久| 国产精品欧美风情| 一本色道久久综合亚洲精品不卡 | 亚洲国产免费| 国产精品一二一区| 一区二区三区.www| 又紧又大又爽精品一区二区| 性欧美video另类hd性玩具| 亚洲精品乱码久久久久久蜜桃91 | 日韩视频久久| 免费观看30秒视频久久| 亚洲欧美视频| 欧美三级第一页| 亚洲伦理自拍|