摘 要: 介紹了基于SoPC平臺(tái),利用Nios II軟核處理器和μClinux操作系統(tǒng)實(shí)現(xiàn)的具備網(wǎng)絡(luò)點(diǎn)播功能的音頻系統(tǒng),,詳細(xì)說明了其硬件電路的構(gòu)建和應(yīng)用軟件的設(shè)計(jì),,并結(jié)合DE2-70開發(fā)平臺(tái)加以驗(yàn)證。得到的系統(tǒng)能夠播放本地音頻文件,,同時(shí)具有實(shí)時(shí)的網(wǎng)絡(luò)點(diǎn)播功能,。
關(guān)鍵詞: 網(wǎng)絡(luò)點(diǎn)播;音頻,;SoPC,;Nios II;μClinux
傳統(tǒng)的音頻設(shè)備主要是基于單片機(jī)實(shí)現(xiàn)的音頻編碼和解碼,,由于單片機(jī)資源限制,,且資源定制的靈活性較差,對(duì)設(shè)備的升級(jí)和功能擴(kuò)展造成了一定困難,。隨著互聯(lián)網(wǎng)技術(shù)的快速發(fā)展,,網(wǎng)絡(luò)化已經(jīng)成為音頻設(shè)備重要功能之一,網(wǎng)絡(luò)點(diǎn)播功能的實(shí)現(xiàn)不但可以提高系統(tǒng)的實(shí)時(shí)性和便捷性,,同時(shí)對(duì)于增強(qiáng)系統(tǒng)的競(jìng)爭(zhēng)力也大有益處,。
本文基于SoPC平臺(tái),開發(fā)了具有網(wǎng)絡(luò)點(diǎn)播功能的音頻系統(tǒng),,介紹了開發(fā)的主要流程和其中的關(guān)鍵技術(shù),,對(duì)嵌入式網(wǎng)絡(luò)設(shè)備的開發(fā)具有一定的幫助作用。
1 基于SoPC平臺(tái)的開發(fā)流程
隨著SoPC技術(shù)日趨成熟,,SoPC應(yīng)用領(lǐng)域越來越廣,。相比之下,基于SoPC平臺(tái)的Nios II-μClinux開發(fā)具有更加明顯的優(yōu)勢(shì)。Nios II軟核處理器是Altera公司推出的一款模塊化,、硬件可編程的嵌入式處理器,,具有非常強(qiáng)大的硬件定制功能,通過定制Altera和第三方公司的IP核以及系統(tǒng)所需其他外設(shè),,可以迅速構(gòu)建出系統(tǒng)所需的硬件平臺(tái),,這樣的硬件平臺(tái)能夠獲得完全符合系統(tǒng)需求的硬件資源,同時(shí)對(duì)于降低系統(tǒng)的開發(fā)周期也是十分有利的[1],。加之μClinux系統(tǒng)的移植,,使得整個(gè)系統(tǒng)的性能更加優(yōu)越,μClinux是一種非常優(yōu)秀的嵌入式操作系統(tǒng),,雖然體積小,,卻繼承了Linux操作系統(tǒng)穩(wěn)定、可移植性強(qiáng),、網(wǎng)絡(luò)功能強(qiáng)大等諸多優(yōu)點(diǎn),,此外μClinux還擁有豐富的硬件驅(qū)動(dòng)資源,通過對(duì)驅(qū)動(dòng)程序的修改和移植,,使得頂層應(yīng)用的開發(fā)變得更為輕松[2],。
開發(fā)基于SoPC的Nios II-μClinux的嵌入式系統(tǒng),需要使用Altera的SoPC開發(fā)工具SoPC Builder和Quartus II兩款軟件,,它們分別完成系統(tǒng)定制工作和硬件電路的構(gòu)建,。系統(tǒng)的軟件設(shè)計(jì)則需要借助運(yùn)行Linux操作系統(tǒng)的計(jì)算機(jī),完成交叉編譯以生成μClinux系統(tǒng)和頂層應(yīng)用程序,,然后移植到開發(fā)板上,。開發(fā)板將作為系統(tǒng)定制、硬件設(shè)計(jì)和軟件設(shè)計(jì)的檢驗(yàn)平臺(tái),,從而指導(dǎo)系統(tǒng)定制,、硬件和軟件設(shè)計(jì)的修改和完善[3]。其開發(fā)流程可以分為4個(gè)階段:系統(tǒng)定制,、硬件設(shè)計(jì),、軟件設(shè)計(jì)、系統(tǒng)綜合,,其具體開發(fā)流程如圖1所示,。
系統(tǒng)定制和軟件設(shè)計(jì)階段相對(duì)復(fù)雜,包含了本設(shè)計(jì)的核心思想以及相關(guān)問題的解決方案,,下文對(duì)此給予重點(diǎn)介紹,。
2 系統(tǒng)定制
該階段的主要任務(wù)是定制硬件系統(tǒng),本設(shè)計(jì)選取友晶公司(Terasic)推出的一款嵌入式開發(fā)平臺(tái)(DE2-70),,通過調(diào)用相應(yīng)IP核迅速構(gòu)建出符合系統(tǒng)需求的硬件平臺(tái),,如圖2所示。
其中Audio模塊采用友晶公司的配套IP核,。該IP核提供了Verilog HDL的硬件描述和相應(yīng)的HAL驅(qū)動(dòng)程序,,實(shí)現(xiàn)了Codec時(shí)鐘匹配、FIFO,、時(shí)序控制以及數(shù)據(jù)傳輸控制,。由于采用硬件描述語言實(shí)現(xiàn),該IP具有很強(qiáng)的靈活性和高效性,。
DM9000A是一款高速以太網(wǎng)接口芯片,,集成了10/100 M自適應(yīng)收發(fā)器,通過調(diào)用DM9000A的IP核,,使其掛載到Avalon總線上,,該模塊是實(shí)現(xiàn)網(wǎng)絡(luò)點(diǎn)播功能的核心硬件資源。
本地音頻的播放是以SD卡,、U盤等移動(dòng)存儲(chǔ)介質(zhì)作為音頻文件的載體,,SD Card socket有兩種工作模式:SD模式和SPI模式。本設(shè)計(jì)采用SPI模式,,該模式下通過四線方式就可以完成所有的數(shù)據(jù)交換,,大大簡(jiǎn)化了硬件電路設(shè)計(jì),USB形式的其他移動(dòng)存儲(chǔ)介質(zhì)調(diào)用了ISP13632的IP核,,將音頻文件拷貝到移動(dòng)存儲(chǔ)介質(zhì),,掛載到μClinux嵌入式系統(tǒng),就能完成本地音頻文件的讀取與解碼,。
3 硬件設(shè)計(jì)
該階段主要任務(wù)是完成硬件設(shè)計(jì)工作,,其中頂層文件的編寫采用Verilog HDL代碼形式,借鑒DE2-70官方的DE2_70_TOP.v文件來編寫本設(shè)計(jì)的Verilog頂層文件,,其中SD卡對(duì)應(yīng)代碼必須確保準(zhǔn)確,,否則可能導(dǎo)致SD卡的永久性毀壞,正確的Verilog代碼如下:
.MISO_to_the_mmc_spi (oSD_DAT),
.MOSI_from_the_mmc_spi (SD_CMD),
.SCLK_from_the_mmc_spi (SD_CLK),
.SS_n_from_the_mmc_spi (SD_DAT3),
而后進(jìn)行引腳分配與時(shí)序分析,,進(jìn)而編譯生成硬件,。這一階段關(guān)鍵工作是對(duì)時(shí)序分析和編譯過程中的錯(cuò)誤進(jìn)行準(zhǔn)確的分析判斷,以便在SoPC Builder中調(diào)整已定制系統(tǒng),,確保生成的硬件符合設(shè)計(jì)要求,。
4 軟件設(shè)計(jì)
該階段的工作量相對(duì)較大,是本設(shè)計(jì)最為重要的環(huán)節(jié),。
4.1 建立交叉編譯環(huán)境
(1)通過虛擬機(jī)安裝Ubuntu10.10(可以選擇其他Linux系統(tǒng)),。
(2)從Altera官方FTP上下載μClinux開發(fā)包和交叉編譯器,解壓到指定文件夾,。
(3)修改Linux系統(tǒng)環(huán)境變量,,實(shí)現(xiàn)Nios II交叉編譯環(huán)境的支持。
4.2 μClinux移植
在Linux環(huán)境下針對(duì)SoPC Builder生成的ptf文件對(duì)μClinux進(jìn)行配置,這樣做的目的是保證μClinux編譯的結(jié)果能夠成功運(yùn)行到DE2-70開發(fā)板上,。通過make emenuconfig命令對(duì)內(nèi)核進(jìn)行必要的配置,,編譯生成zImage鏡像文件,編譯過程中將隨之生成一個(gè)名為nios2.h的文件,,該文件描述的內(nèi)容與系統(tǒng)定制階段SoPC Builde中的硬件描述完全一致,,同時(shí)驗(yàn)證了ptf文件對(duì)μClinux的配置已經(jīng)成功,將硬件sof文件和鏡像zImage文件下載到開發(fā)板,,檢驗(yàn)μClinux能否成功移植,。圖3為成功移植后,調(diào)試終端顯示的結(jié)果,。
4.3 驅(qū)動(dòng)程序移植
通過make menuconfig命令進(jìn)行內(nèi)核配置,,將網(wǎng)卡(DM9000A)、SD卡(SPI模式),、USB(ISP1362)的驅(qū)動(dòng)程序編譯進(jìn)內(nèi)核,,選擇支持的文件系統(tǒng)(本設(shè)計(jì)使用DOS FAT文件系統(tǒng)),其中網(wǎng)卡驅(qū)動(dòng)(dm9000.c)要進(jìn)行必要的修改,,否則無法獲取MAC地址,,在dm9000_probe函數(shù)中添加兩處語句:
(1)在函數(shù)體的開頭添加:
static char net_mac_addr[]=
{0x00,0xe0,0x3d,0xf4,0xdd,0xf7}; // MAC地址設(shè)置
(2)添加:
for(i=0;i<6;i++)
{
ndev->dev_addr[i]=net_mac_addr[i];
}
4.4 應(yīng)用程序移植
為了使系統(tǒng)能夠播放本地和網(wǎng)絡(luò)音頻文件,選用mpg123播放器進(jìn)行移植,。mpg123是一個(gè)快速的MPEG 播放器和解碼器,,支持 MPEG 1.0/2.0/2.5 layers 1,2 and 3,,具有高質(zhì)量和低CPU占用率的優(yōu)點(diǎn),,更為關(guān)鍵的是可以輕松地移植到μClinux平臺(tái)[4]。為了使mpg123在開發(fā)板上正常工作,,需要修改dummy.c文件以便將數(shù)據(jù)寫入AUDIO模塊:
static int write_dummy(audio_output_t *ao,
unsigned char *buf,int len)
{
unsigned short int i=0,Tmp1=0;
for(i = 0; i < len; i+=2)
{
if (!readw(0x09605180)
//0x09605180是AUDIO模塊的基地址
{
writew(Tmp1, 0x09605180);
}
}
return len;
}
4.5 編譯,、連接、調(diào)試
該過程將對(duì)定制的μClinux進(jìn)行編譯,、連接,、調(diào)試,對(duì)出現(xiàn)的錯(cuò)誤進(jìn)行逐一分析,、排查,、糾正,最終生成zImage鏡像文件,。
5 系統(tǒng)綜合
建立Shoutcast server服務(wù),,經(jīng)路由器使得開發(fā)板與計(jì)算機(jī)工作在同一局域網(wǎng)內(nèi),將系統(tǒng)的sof文件和zImage文件下載到開發(fā)板,,運(yùn)行Nios II-terminal調(diào)試終端,,執(zhí)行mpg123-@http://192.168.1.1:8000命令,,通過耳機(jī)就可以聽到網(wǎng)絡(luò)服務(wù)器上的音頻文件,本地播放需將移動(dòng)存儲(chǔ)介質(zhì)通過mnt命令掛載到系統(tǒng)上,,進(jìn)入所在文件夾,,直接執(zhí)行mpg123 *.mp3就能夠欣賞到本地的音頻文件。
本設(shè)計(jì)基于SoPC平臺(tái),,綜合了Nios II軟核處理器和μClinux嵌入式操作系統(tǒng)的優(yōu)勢(shì),,實(shí)現(xiàn)的系統(tǒng)具有本地音頻播放和網(wǎng)絡(luò)音頻點(diǎn)播功能,。該設(shè)計(jì)具有開發(fā)周期短,,硬件設(shè)計(jì)可升級(jí),軟件系統(tǒng)可維護(hù),,網(wǎng)絡(luò)功能強(qiáng)大等諸多優(yōu)點(diǎn),,對(duì)于設(shè)備的系統(tǒng)化、網(wǎng)絡(luò)化具有一定的幫助,。
參考文獻(xiàn)
[1] 潘松,,黃繼業(yè),曾毓,,等.SoPC技術(shù)實(shí)用教程[M].北京:清華大學(xué)出版社,,2005.
[2] 周立功.SoPC嵌入式系統(tǒng)基礎(chǔ)教程[M].北京:航空航天大學(xué)出版社,2006.
[3] 馮新宇,,蔣洪波,,祁紅巖.基于Nios Ⅱ的音頻播放器設(shè)計(jì)與驅(qū)動(dòng)開發(fā)[J].現(xiàn)代電子技術(shù),2010(4):97-101.
[4] Lu Zongqing,,Zhang Xiong,,Sun Chuiliang.An embedded system with μClinux based on FPGA[C].Nanjing:2008 IEEE Pacific-Asia Workshop on Computational Intelligence and Industrial Application,2008.