基于FPGA的音頻編解碼芯片接口設計應用
WM873l是一款功能強大的低功耗立體聲24位音頻編解碼芯片,其高性能耳機驅動(dòng)器、低功耗設計、可控采樣頻率、可選擇的濾波器使得WM8731芯片廣泛使用于便攜式MP3,CD,PDA的場(chǎng)合。其結構框圖如圖1所示。
wM8731包含2個(gè)線(xiàn)路輸入和1路麥克風(fēng)輸入并可以進(jìn)行音量調節;內置片上ADC(模擬數字轉換器)及可選擇的高通數字濾波器;采用高品質(zhì)過(guò)采樣率結構的DAC(數字模擬轉換器);線(xiàn)路輸出和耳機輸出;內置晶體振蕩器以及可配置的數字音頻接口和2或3線(xiàn)可選的微處理器控制接口等??刂破骺赏ㄟ^(guò)控制接口(Control Interface)對WM8731進(jìn)行配置,然后通過(guò)數字音頻接口(Digtal Audio Interface)讀寫(xiě)數據音頻信號。本文設計了一種基于FPGA的驅動(dòng)模塊,將WM8731的控制接口與數字音頻接口轉換為控制器通用的總線(xiàn)接口,使控制器可以像讀寫(xiě)外部寄存器一樣對WM8731芯片進(jìn)行控制使用。
2 WM8731芯片接口時(shí)序介紹
2.1 控制接口時(shí)序
WM8731的控制接口有4根引腳,分別為:MODE(控制接口選擇線(xiàn))、CSB(片選或地址選擇線(xiàn))、SDIN(數據輸入線(xiàn))和SCLK(時(shí)鐘輸入線(xiàn))。它具有2線(xiàn)和3線(xiàn)兩種模式。2線(xiàn)為MPU接口,3線(xiàn)為兼容SPI接口。對控制接口的配置選擇可通過(guò)設置MODE腳的狀態(tài)完成。選擇MODE為0時(shí)為2線(xiàn)模式,1時(shí)為3線(xiàn)模式。本文采用2線(xiàn)模式對WM8731進(jìn)行控制。其時(shí)序圖如圖2所示。
2.2 數字音頻接口時(shí)序
WM8731的數字音頻接口有5根引腳,分別為:BCLK(數字音頻位時(shí)鐘)、DACDAT(DAC數字音頻數據輸入)、DACIRC(DAC采樣左/右聲道信號)、ADC-DAT(ADC數字音頻信號輸出)、ADCLRC(ADC采樣左/右聲道信號)。
數字音頻接口可以工作在主模式和從模式下。地址為0000111的寄存器的第6位設置數據的主/從模式:“1”為主模式,“0”為從模式。ADCDAT、/DACDAI和ADCLRC/DACLRC與位時(shí)鐘BCIK同步,在每個(gè)BCLK的下降沿進(jìn)行一次傳輸。BCLK和ADCLRC/DACLRC在主模式時(shí)為輸出信號,從模式下為輸入信號。DAC-DAT始終為輸入信號,ADCDAT始終為輸出信號。
數字輸出支持4種音頻數據模式:右對齊、左對齊、I2S和DSP模式。通過(guò)對寄存器的不同配置,可以設置傳輸的數據格式。寄存器配置值如下:
寄存器地址0000111的1~0位設置音頻格式:“11”時(shí)為DSF’格式,“10”為I2S格式,“01”為左對齊格式,“00’’為右對齊格式。
3~2位設置字長(cháng):“11”時(shí)為32位,“10”為24位,“01”為20位,“00’’為16位。
這四種音頻格式都是高位(MSB)在前,16~32位。但32位數據不支持右對齊模式。
本文采用主模式的左對齊數據格式,左對齊數據格式傳輸如圖3:左對齊格式時(shí),MSB在BCLK的第一個(gè)上升沿有效,緊接著(zhù)是一個(gè)ADCLRC或DACLRC傳輸。
3 WM8731芯片驅動(dòng)的FPGA設計
3.1 驅動(dòng)器的總體設計方案
本文設計驅動(dòng)器在使用時(shí)的框圖如圖4所示。雙口RAM和驅動(dòng)器一同連接在控制器的數據總線(xiàn)和地址總線(xiàn)上,控制器只需提供少量的控制線(xiàn)即可完成對音頻編解碼芯片wM8731的控制及數據交換功能。
驅動(dòng)器內部結構框圖如圖5所示??刂撇糠痔峁寗?dòng)器與控制器之間的接口(包含有數據總線(xiàn)信號、地址總線(xiàn)信號和控制信號),同時(shí)產(chǎn)生控制字轉換單元和數字音頻接口單元的控制信號;內部寄存器緩存控制字和狀態(tài)字;控制字轉化單元負責將控制字串行發(fā)送給WM8731,同時(shí)效驗傳送信號;數據音頻接口單元完成WM8731與外部雙口RAM的串并轉換,實(shí)現對數字音頻信號的發(fā)送和接收功能。
3.2.2 控制字轉換單元
當START控制位置‘1’時(shí),將控制字寄存器中的數據串行發(fā)送給WM8731,當傳輸出現錯誤時(shí),將狀態(tài)寄存器中的ACK位置1。如圖6所示。
3.2.3 數字音頻接口單元
當讀入數字音頻標志位C1為‘1’,接收WM873l芯片傳來(lái)的數字音頻數據并將其存入外部雙口RAM中,當輸出數字音頻數據標志位C2為‘1’時(shí),將雙口RAM中的音頻數據發(fā)送給wM8731。如圖7所示。
3.3 系統仿真
下面給出控制器通過(guò)該驅動(dòng)模塊對WM8731寫(xiě)控制字的時(shí)序仿真如圖8所示。圖中各引腳定義如表2所示。
4 結 語(yǔ)
利用FPGA對音頻編解碼芯片WM8731進(jìn)行接口電路的設計,實(shí)現了控制接口與數字音頻接口的統一控制,簡(jiǎn)化了對音頻編解碼芯片WM8731的使用步驟,具有擴展性好、使用簡(jiǎn)單方便、易于升級等優(yōu)點(diǎn),對其他芯片的接口設計也有一定的參考意義。
數字濾波器相關(guān)文章:數字濾波器原理
評論