通過開源API進行DSP視頻處理
數字信號處理器(DSP)具有出色的多媒體性能。一般而言,它們運行編解碼器所需的周期只有通用處理器(GPP)內核的40%到50%。DSP還能提供比ASIC大得多的靈活性和可重配置性。但迄今為止,要在數字視頻應用中運用DSP,編程人員還不得不花費較多時間精力去學習相關專用語言。不過,隨著應用編程接口(API)的出現,已不再需要學習這些專用DSP語言了。在運行于GPP上的應用中,API可以輕輕松松地充分發揮DSP的優勢。
本文引用地址:http://www.104case.com/article/150196.htm開源多媒體構架在GPP上一般運行在Linux操作系統下,是這些API的理想對象。利用API可以卸載視頻編解碼器的計算負荷,大大減小DSP編程的復雜性。這種方案只要求編程人員具備基本的DSP知識即可,無需編寫代碼來整合DSP功能與那些運行在GPP上的功能。這種優勢,加上利用免費開源插件和構架提供的許多功能的能力,可以大幅度縮短新視頻產品的上市時間。
硬件平臺的選擇
在選擇運行編解碼器(壓縮傳輸或存儲的數字流,再解壓以供查看或編輯)的硬件平臺時,開發人員有幾種可選方案。ASIC是專門為數字視頻應用而設計的,能在這類應用中提供高性能和低功耗。它的缺點流片(NRE)費用很高。此外,ASIC若有變化,比如改動以適應編解碼標準,相關實現費用非常高昂。
另一方面,GPP內核的流片費用相對較低,針對變動進行重編程相當容易。但由于它們在執行計算密集的信號處理應用時效率低下,故在應用于數字視頻處理時性能較低。例如,GPP通過一系列移位和加法運算來實現乘法運算,而每一個移位和加法運算需要一個以上的時鐘周期。
DSP具有集上述二者之優勢的潛力。不同于GPP,DSP是為數字視頻應用中計算密集的信號處理應用而優化的。它具有單周期乘法器或乘法累加單元,能夠加快編解碼算法的執行速度。更高性能的DSP還包含有幾個可以并行操作的獨立執行單元,這使得它們能夠每條指令執行好幾個操作。此外,DSP還提供完全的軟件編程能力,包括現場重編程能力。這就讓用戶可以先推出MPEG-2產品,以后再升級為H.264視頻編解碼器。DSP在數字視頻應用中的主要局限是它們通常需要采用專用語言來編程,而熟悉DSP的編程人員遠沒有熟悉流行的GPP架構的來得多。

圖1:只含解碼器的范例中的多媒體框架職責和數據流程
組件集成的挑戰
數字視頻系統的開發人員還面臨著集成的挑戰。數字視頻系統包含了多個編碼器、解碼器、編解碼器、多種算法及其它軟件,這些組件都必須集成到一個可執行映象(image)中,然后才能在系統上運行內容。集成所有這些組件并確保其運行協調是一件很困難的任務。不同的系統可能需要截然不同的視頻、圖像、語音、音頻和其他多媒體模塊。手工集成每一個軟件模塊或算法的開發人員就被增值功能性(比如增加創新性功能)搞得頭痛不已。
許多數字視頻開發人員都開始采取開源途徑來構建軟件。一種常用的方案是從開源獲得軟件的重要部分,而在可用性和硬件集成方面充分發揮內部專業能力。開發人員常常參與開源技術開發項目,以滿足特定要求并把內部開發的代碼和開源代碼集成在一起來創建新產品。
新的API
為了解決上述問題,德州儀器(TI)開發出了一款API,該產品能夠充分發揮開源多媒體框架中的GStreamer等DSP的優勢。這款API使多媒體編程人員可以利用熟悉環境中的DSP編解碼引擎,把數字視頻編程人員從復雜的DSP編程中解放出來,讓ARM/Linux開發人員得以輕松利用DSP編解碼器的加速功能,無需具備相關硬件知識。該接口還能自動高效地在ARM和DSP間進行工作劃分,從而不再需要為運行在DSP上和運行在GPP內核上的功能間的協調而編寫代碼。該接口已由TI按照開源社群標準以GStreamer插件的形式開發成功。

圖2:GStreamer內數據通過GstBuffer結構進行表征的方法與其它幾種操作系統及其相應多媒體框架所采取的方法相一致。
GStreamer是一種媒體處理庫,提供了某種轉換過程的抽象模型,其通過管道的概念進行工作,媒體在其中按照已定義的方向從輸入流到輸出。GStreamer能夠以一種簡化編程過程的方式來提取不同媒體的操作行為,在數字視頻編程社群中廣受歡迎。通過GStreamer,能夠編寫出一種能夠支持多種不同格式和網絡的通用視頻或音樂播放器。而且大部分操作由插件執行,并非GStreamer內核。GStreamer的基本功能性主要與注冊和加載插件有關,并可提供基類,這些基類定義了GStreamer類的基本功能。
GStreamer過濾器
源過濾器負責從從數據源獲取原始的多媒體數據以供處理,這里的數據源可以是硬盤文件(比如文件源過濾器),或CD或DVD光盤,也可以是電視接收卡或網絡這種“實時”源。某些源過濾器只是簡單地把原始數據傳遞到剖析器(parser)或分離過濾器(splitter filter),同時其它源過濾器也執行自己的剖析步驟。變換過濾器 (Transform filter)接收原始數據或部分經過處理的數據,進一步處理后再傳遞到下一級過濾器。
變換過濾器有多種類型,剖析器即是一例。這種過濾器把原始字節流分離為多個樣本或幀、壓縮器或解壓縮器,以及格式轉換器。呈現過濾器(Renderer filter)一般接收完全處理過的數據,并在系統顯示器上或通過揚聲器或某些外部設備進行播放。這一類過濾器還包括“file writer (文件創建器)”過濾器和網絡傳輸過濾器,前者可以把數據保存到硬盤或其它持久穩固的存儲設備上。
數據處理在plug-in_chain() 或 plug-in_loop()函數中進行。該函數可能像元件縮放那么簡單,也可能像真實的MP3解碼器那么復雜。數據被處理后,利用一個gst_pad_push()函數從GStreamer元件(element)的源襯墊(pad)發送出去,由此把數據傳遞到管道鏈的下一個元件。
GStreamer緩沖器
在GStreamer中,緩沖器是數據傳輸的基本單元。GstBuffer(實例)類提供了把一個存儲區定義為流媒體的一部分所必需的全部狀態。經由GstBuffer結構,Gstreame內部的數據表示遵循幾種其它操作系統及其各自的多媒體構架所采用的方法(比如,Microsoft DirectShow中的媒體采樣概念)。此外,還支持次級緩沖器,允許緩沖器的一小部分成為它自己的緩沖器,利用這種處理機制確保了存儲空間不會過早釋放。

圖3:復用已分配在驅動器上且在物理上是連續的緩沖的一種有效途徑。
緩沖器通常利用gst_buffer_new()來創建。創建好一個緩沖器之后,一般是為它分配存儲器,設置緩沖器數據的大小。下面給出了一個緩沖器創建的例子,該緩沖器能夠保存具有給定寬度、高度和每像素位的視頻幀。
評論