摘要:介紹一種基于M642的視頻無線傳輸系統(tǒng),在此基礎上重點探討了關于TS流傳輸的問題,提出了使用McBSP和GPIO方式分別實現TS流傳輸,并給出了一種改進的乒乓方式。實驗結果證明,采用McBSP和GPIO都可以解決TS流傳輸問題,但在速度和實現難度方面采用GPIO表現更好,改進型的乒乓結構也在一定程度上提高了程序的效率。
關鍵詞:TS流傳輸;DM642;視頻無線傳輸系統(tǒng);EDMA;McBSP;GPIO
引言
無線通信技術因其免去了使用實體接線,為生活帶來諸多便利,因此受到廣大消費者的青睞。其中短距離無線通信技術作為無線通信的一個發(fā)展趨勢,越來越受到人們的關注。數字圖像信息及其處理技術正在發(fā)揮著越來越重要的作用,在人們生活中的地位也將越來越高。原來的民用設計普遍采用ASIC方式,如STi5517、STi5518等,但由于禁運等原因無法達到工業(yè)級及以上的標準。本設計采用的DM642和FPGA靈活性高,升級優(yōu)化方便,且達到了工業(yè)級等級以上。本文主要介紹TS流傳輸的新方式,實現信源板中TS流實時傳輸到信道板上。
1 簡介
1.1 基于DVB-T無線視頻傳輸系統(tǒng)
無線視頻傳輸系統(tǒng)的硬件實現框圖如圖1所示。本系統(tǒng)硬件分為4個組成部分:信源編碼部分、信道編碼調制部分、射頻部分和接收機部分。
攝像頭采集視頻信號,并輸出PAL制的模擬電視信號。視頻解碼器將AV視頻信號數字化和解碼,轉化為YUV(4:2:2)格式輸出。TMS320DM 642將原始視頻以MPEG-2格式進行編碼,并且將編碼數據封裝為TS數據流。TS數據流以SPI并行數據格式傳遞給信道解碼部分。
信道編碼部分通過FPGA(EP3C55F484)對數據進行DVB-T編碼和中頻調制,調制信號經過模擬上變頻完成射頻調制。
接收機部分通過接收射頻信號并對其進行模擬下變頻,提取出感興趣的中頻信號,利用信道解調器對其進行信道解碼。解碼后的信源數據流以TS流格式傳送給TMS320DM642處理器。處理器先進行TS解包,再對MPEG-2數據流解壓縮。根據系統(tǒng)不同設置,可以通過PCI接口發(fā)送至PC端進行后端數據處理,或通過視頻編碼器將視頻信號還原為模擬電視信號。
1.2 傳送流(TS流)
TS流是由打包的視頻、音頻基本碼流再經過打包形成的復合碼流,每包長度為188字節(jié),或由PS流分段截取,適用于誤碼較大的應用環(huán)境。傳送流的系統(tǒng)層可分作兩個子層:一個是相應于特定數據流操作(PES分組層,可變長度),該層是為編解碼的控制而定義的邏輯結構,
PES頭包括流的性質、版權說明(該節(jié)目是原始節(jié)目還是復制節(jié)目)、加入時間標簽PTS和DTS、說明DSM的特殊模式等;另一個是相應于多路復用操作(TS分組層,188字節(jié)固定長度結構),該層是針對交換和互操作而定義的,在TS頭中加入同步、說明有無差錯、有無加擾,加入連續(xù)計數和不連續(xù)性指示(因為節(jié)目流的包相互交叉),加入節(jié)目參考時鐘PCR以及包識別PID等。兩個子層間的復用關系是將PES結構切割成一個個小包,作為TS包的凈荷嵌入到TS流結構中而建立起來的,這種結構可以很方便地實現直接從傳送流中解出原始音視頻數據,也可從一個或多個傳送流中抽取想要的基本流來進行解碼,或構造新的傳送流再次傳輸,還可以依據通信信道的質量在TS流與PS流間作切換。
1.3 數據在DM642接口的傳輸
I2C總線傳輸為140kb/s,速度慢,接口簡單,適合于各種芯片參數的配置或EEPROM訪問等數據量小的通信。視頻口傳輸為27M×20b/ s,數據較快,接口復雜,功能單一,一般只用于DSP與視頻編/解碼器之間的視頻數據傳輸。網口傳輸為10M/100M,通信協議復雜,若用FPGA實現,則接口也復雜,適合于DSP與PC機間的數據傳輸。McBSP傳輸為40 Mb/s,如果用FPGA實現接口較為簡單,適合于DSP與FPGA低速數據傳輸。GPIO傳輸為10M×n,n是GPIO的引腳數目,接口極其簡單,傳輸速度較快。如DM6437共有111個GPIO引腳,若用3個32位的GPIO則可達到960 Mb/s。即使用1個32位的GPIO bank也可以達到320 Mb/s,能夠滿足一般的數據傳輸需求。DM642有16個GPIO口,速度也可達到160 Mb/s,滿足設計要求。圖2即是GPIO方式傳輸TS流需要的時序。
如果利用任務或中斷的方式傳輸數據,因為數據量大,勢必增加CPU的負擔,這種負擔很有可能是CPU無法承受的。例如使用任務來傳輸,若數據為8 MB/s,則這個任務占用CPU 80%的時間,這是本應該占據大部分時問的圖像壓縮算法無法忍受的,并且時??赡鼙煌蝗缙鋪淼闹袛啻驍喽鴣G失數據。若利用中斷來同步傳輸,而使CPU大部分時間在中斷中,亦是不現實的。這里采用DSP中的增強型的DMA模塊(EDMA),在CPU不參與的情況下完成數據傳輸,只有傳輸完成才進入中斷,如此則解放出CPU,以使算法占用它。
[!--empirenews.page--]
2 TS流傳輸實現
2.1 McBSP實現
McBSP由數據通道和控制通道組成,可以與外部設備連接,進行數據通信。數據的接收與發(fā)送分別工作于不同的引腳上,因此數據通信是全雙工的。其他的4個引腳用于傳輸控制信號(時鐘和同步信號)。
這里采用EDMA進行McBSP與存儲器緩沖區(qū)之間的數據搬運。EDMA控制器讀取從外部設備接收到并保存在DRR(數據接收寄存器)的數據,或者將需要向外部設備發(fā)送的數據寫入DXR(數據發(fā)送寄存器)。被寫入DXR的數據經過XSR被移出到DX腳上。同理,接收的數據先被移入RSR,然后被拷貝到RBR,最后再被拷貝到DRR,這時就允許被EDMA訪問了。McBSP中內部數據的移出和外部數據的移入可以同時發(fā)生,即可以進行全雙工的數據通信。
以EDMA接收數據的配置為例,配置參數RAM。EDMA通道接收數據源地址為McBSP0的DRR寄存器,地址計數模式為不變模式。設置EDMA通道接收數據目的地址為DSP片內存儲區(qū)PingBuffer首地址,確保第一次傳輸數據是到PingBuffer,地址計數模式同樣為遞增模式。配置源地址計數索引值,由于源地址為McBSP0的DRR寄存器,固定不變;配置目的地址計數索引值,由于接收數據為32位,所以srcBidx=srcCidx=4,這是因為DSP內的最小計數單元為1個字節(jié),8bits;配置剩余的參數RAM傳輸參數,包括設置ACNT=4,BCNT=2 048,CCNT=1,采用一維傳輸A-SYN C。
接下來是ping-pong傳輸的程序實現。替ping-pong各自分配1個通道,于是一共有3個通道,對應3個參數RAM。ping通道的參數RAM與主通道的參數RAM完全一致,pong通道的參數RAM與主通道相比,只需將pong通道接收數據目的地址改為PongBuffer首地址。隨后調用EDMA_link三次,分別將主通道和ping通道連接,ping通道和pong通道相互連接。EDMA中斷設置與GPIO輸出任務一樣。
2.2 GPIO實現
TS流輸出任務采用1D到1D的傳輸模式。SUM=01,DUM=00,即源地址是188字節(jié)的Buffer,目的地址是GPIO[8:15]對應的寄存器,GP4的外部觸發(fā)EDMA傳輸,傳輸188字節(jié)產生1次EDMA中斷。隊列優(yōu)先級設置為緊急,來保證時序。以EXTINT5為EDMA觸發(fā)事件:
pong的參數RAM設置類似,只要將源地址改為pong,并將重載的參數RAM地址改為edmacfg_pong即可。
DM642中,EDMA的64個通道只產生一種中斷。當一個通道傳輸完成后,IPR(Interrupt Pending Register)寄存器里的相應位會被置1,EDMA中斷處理器通過查詢IPR寄存器,確定是哪個通道完成了傳輸,并調用相應的中斷服務程序,即tccCb(回調函數,即通道傳輸完成后所調用的中斷服務程序)。tccCb=edma_isr,該函數的作用是當一個接收Buffer被填滿時,在通道傳輸完成后發(fā)送一個旗語信號給信號處理程序,通知其對收到的數據進行處理。參數RAMOPT中TCINTEN位置1,以使能EDMA中斷。隨后,利用DSP/BIOS將EDMA中斷源和DSP的可屏蔽中斷5連接起來。編寫相應通道的EDMA中斷程序,傳輸完一個TS包后,檢查是否1幀圖像的TS流傳完,用以生成數據有效信號(Dvalid),通知接收方哪些是有用數據。由于選用了DM642的可屏蔽中斷5,還需使能IER寄存器里的對應位。
TS流輸入則只需要將SUM=00,DUM=01,目的地址和源地址交換,再將EDMA中斷程序中目的地址變更到188字節(jié)后的地址。采用GP4作EDMA同步事件(即SPI時鐘),GPIO[8:15]作數據輸入,GP7作同步,采用GP6作外部中斷,用作數據有效線。在外部中斷中重載,在傳輸完成中斷中改變目的地址。如此則可順利接收到TS流。[!--empirenews.page--]
采用Link的ping-pong方式,利用兩個參數RAM反復轉載得到TS流的數據:在此采用的雙緩沖結構,即在DSP緩沖區(qū)內開辟兩塊緩沖用于并行處理FPGA通過McBSP傳過來的數據。當EDMA往PingBuffer里傳輸數據時,CPU即可處理PongBuffer里的數據。當工作完成后,彼此交換緩沖區(qū),EDMA往PongBuffer里寫數據,CPU處理PingBuffer里的數據。為了實現雙緩沖結構,采用了EDMA提供的Link功能,如圖3所示,即將不同的EDMA傳輸參數RAM連接起來,組成一個傳輸鏈。在傳輸鏈中,一個傳輸的結束會導致自動從參數RAM中裝載下一個傳輸需要的事件參數。在具體程序中,只需將ping通道的參數RAM連接到pong通道,同時將pong通道的參數RAM連接到ping通道即可。[!--empirenews.page--]
2.3 ping-pong操作的改進
由于原來程序McBSP通過EDMA傳輸到ping或pong中,在EDMA傳輸完成中斷的過程中還需要復制數據(memcpy)到公共緩沖區(qū)。復制數據是一個很費時的過程,但程序不宜停留在中斷的時間過長,故而希望EDMA能直接傳到公共緩沖區(qū)中。
如圖4所示,在建立McBSP和EDMA通信時,將ping目的地址改變成公共緩沖池的首地址,將pong目的地址變?yōu)榫彌_池下一個緩沖區(qū)的首地址。再在EDMA傳輸完成中斷的過程中改變上一次用的PaRAM的目的地址,即ping完成,則中斷改變ping的目的地址。這樣對原程序改變較小,并且占用的參數RAM也較少。但要求ping,pong通道必須處在同一優(yōu)先級隊列中。當重新轉載其中一個時,才不會影響另一個通道。
3 測試結果
圖5是用連續(xù)自增的數在32 Mb/s的速度下以McBSP方式在FPGA的SignalTap II中看到的時序。
圖6是時鐘為9 MHz時TS輸出任務在FPGA的SignalTap II中看到的TS流時序。實測中,輸入任務在接收板DSP接收到TS流數據,數據率為9 MB/s,數據有效(Dvalid)上升沿來時,得同步頭0x47。
TS流在SDRAM存放的基地址為0x804DBC88,前4個字節(jié)(即0x47 0x40 0x45 0x10)是TS包的包頭,從包頭的定義規(guī)范可以看到,第1個字節(jié)0x47為TS包的同步字節(jié);第2個字節(jié)0x40說明這個TS包包含1個PES包的包頭,它傳輸的優(yōu)先級為0級,在這個包中不存在傳輸錯誤;第2個字節(jié)和第3個字節(jié)表明這個TS包的PID是0x45,是這個設計中的視頻包的PID;第4個字節(jié)說明在這個TS包中僅有有效載荷,沒有自適應區(qū)。188字節(jié)后再次出現同步字節(jié)0x47,0x00表示不是第1個TS包,PID也是0x45。再過188個字節(jié)還是同步字節(jié)0x47??梢姡琓S流的輸入輸出任務都較好地實現了它們的功能。
結語
本文介紹了一種基于DM642和EP3C55F484的無線視頻傳輸系統(tǒng)的實現方式,并就TS流傳輸進行了討論。測試結果證明,項目中提出的McBSP和GPIO結合EDMA方式都成功實現了TS流的輸入和輸出傳輸,GPIO方式速度較快,信道中直接采用GPIO的方式要比模擬McBSP接口簡單得多,并用改進的乒乓方式提高程序運行效率。





