基于CMX618的數(shù)字語音通信系統(tǒng)
2.2 系統(tǒng)的硬件設(shè)計與實現(xiàn)
基于CMX618的語音通信模塊主要由語音編解碼器CMX618和LPC2138組成,如圖2所示。本文引用地址:http://m.butianyuan.cn/article/152471.htm
該語音通信系統(tǒng)使用CMX618內(nèi)置的CODEC模塊,其內(nèi)部集成了A/D和D/A轉(zhuǎn)換、通道濾波、增益調(diào)節(jié)等功能,足以滿足對模擬語音的抽樣、量化等操作的指標要求。因此,無需再外接芯片,也節(jié)省了大量的物理空間,這在實際的開發(fā)設(shè)計中是十分重要的。
微控制器LPC2138通過C-BUS串行總線與CMX618連接。C-BuS是一個四線中斷一驅(qū)動串行系統(tǒng),可在主控制器和CMX618內(nèi)部寄存器間進行數(shù)據(jù)傳輸、控制或狀態(tài)信息的發(fā)送。
2.3 系統(tǒng)的軟件設(shè)計與實現(xiàn)
系統(tǒng)的軟件設(shè)計主要是編寫CMX618的驅(qū)動程序,以及對主控制器LPC2138進行編程實現(xiàn)對CMX618的控制。在上電后,首先應(yīng)初始化CMX618和LPC2138。對語音編解碼芯片,要配置其中的一些功能寄存器,這包括設(shè)置編解碼位速率、組幀結(jié)構(gòu)、增益大小、輔助功能選用以及開啟中斷標志位等;對主控制芯片,則要配置接口方式、中斷條件和傳輸速率等。
實際應(yīng)用中,為使編解碼過程中的糾錯能力達到最佳,在使用前向糾錯(FEC)編碼器處理語音編碼時??蛇x擇聲碼器幀以3×20 ms或4×20 ms的形式進行數(shù)據(jù)包傳輸。這種把多幀數(shù)據(jù)進行封裝、打包傳輸?shù)男问?,更有效地抑制了誤碼的產(chǎn)生。
這里,要注意CMX618語音編解碼芯片的狀態(tài)(state)寄存器(地址為MYM40)。編碼和解碼操作在狀態(tài)寄存器中都有對應(yīng)的標志位,當采用中斷方式編解碼時,每次要先讀出狀態(tài)寄存器中對應(yīng)標志位的值,只有當對應(yīng)標志位的值為“1”時,才會產(chǎn)生中斷,執(zhí)行相應(yīng)的操作,如圖3所示。
其中,在狀態(tài)(state)寄存器(地址為MYM40)中對應(yīng)的狀態(tài)標志有VDA,VDW,RDY。其中,VDA為編碼標志位;VDW為解碼標志位;RDY為等待配置標志位。
2.4 關(guān)鍵問題
(1)采用RALCWI算法時,由于存在算法抖動,會使編碼每一幀時花費的時間不同,這使微處理器對輸出數(shù)據(jù)的時間不好掌握。為解決此問題,在編碼時,會給微處理器一條指令,只要編碼可行,就會進行數(shù)據(jù)傳輸;在解碼時,則會增加一個初始延遲時間,避免CODEC因無采樣數(shù)據(jù)而產(chǎn)生時間空隙。
評論