基于DSP芯片TMS320C5402的數(shù)字壓縮語音錄放系統(tǒng)
系統(tǒng)簡介
本系統(tǒng)的主要功能是通過對語音信號進行壓縮,以實現(xiàn)高效率數(shù)字錄音,可用于電話留言,語聲應(yīng)答等場合。采用磁帶錄音實現(xiàn)電話留言,雖然錄音的時間較長,但不便于查找和保存。數(shù)字錄音可以克服磁帶錄音的缺點,不僅查找速度快,而且對錄音信息進行編輯整理也非常方便,更為方便的是數(shù)字錄音信息可以轉(zhuǎn)存在計算機硬盤或光盤上以便長期保存。但是數(shù)字錄音的缺點是要實現(xiàn)長時間錄音需要很大的存儲空間,因此本系統(tǒng)一方面采用存儲量為16MB的單片閃速存儲器KM29N160,另一方面采用2.0Kb/s的速率對語音進行壓縮,采用這兩種方法后,可以實現(xiàn)2小時以上的數(shù)字錄音。
系統(tǒng)硬件設(shè)計
整個硬件設(shè)計包括三個部分,一是TMS320C5402 DSP處理系統(tǒng),包括TMS320C5402、程序存儲器、數(shù)據(jù)存儲器、模數(shù)轉(zhuǎn)換電路等;二是閃速存儲器及其與TMS320 C5402的接口部分;三是AT89C51主處理器部分,包括AT89C51處理器、鍵盤顯示電路及AT89C51與TMS320C5402接口。圖1是整個硬件系統(tǒng)的示意框圖。
圖1 數(shù)字壓縮語音錄放系統(tǒng)硬件示意圖
DSP處理系統(tǒng)
TMS320C5402 DSP處理系統(tǒng)主要完成語音的壓縮和解壓縮功能。系統(tǒng)主要由TMS320C5402、EPROM 27C256-15(1片)、高速RAM CY7C199-10(2片)、譯碼電路、晶體振蕩器、模數(shù)轉(zhuǎn)換電路等構(gòu)成。其中,EPROM存儲引導(dǎo)信息和程序代碼,其地址為數(shù)據(jù)空間的8000H"FFFFH,DSP芯片加電運行時將EPROM中的程序代碼搬移到高速RAM中。高速RAM的存取時間為10ns,可以全速執(zhí)行,地址為0000H"7FFFH,共32K字,程序和數(shù)據(jù)均可訪問。ADC采用Motorola公司的PCM編解碼器MC14LC5480,這個芯片集語音A/D、D/A及抗混疊濾波于一體,采用單5V供電方式,TMS320C5402提供了可與PCM編碼器等串行器件接口的串行口,因而只需將相應(yīng)的引腳一一連接即可。其接口電路如圖2所示。
圖2 dsp與ADC的接口電路
主從系統(tǒng)設(shè)計
整個系統(tǒng)由AT89C51和TMS320C5402兩個處理器以主從方式連接,其中AT89C51作為系統(tǒng)主機,完成系統(tǒng)的人機接口和對TMS320C5402的控制。單片機與DSP之間通過HPI-8連接,標(biāo)準(zhǔn)的HPI-8口是一個8位的并行端口,可以用來實現(xiàn)DSP和主設(shè)備或主處理器接口,雙方通過共享TMS320C5402的片上存儲器完成通信。單片機為主控部分,采用端口方式直接訪問HPI口。HPI口主要由地址寄存器(HPIA)、控制寄存器(HPIC)、數(shù)據(jù)寄存器(HPID)、HPI存儲器和HPI控制邏輯組成。對HPI口進行數(shù)據(jù)讀寫需要三個步驟:設(shè)置控制寄存器、寫地址寄存器和讀寫數(shù)據(jù)寄存器。單片機和DSP的HPI口硬件接口如圖3所示。
圖3 單片機與DSP的HPI口硬件接口連接方法
[!--empirenews.page--]
系統(tǒng)軟件設(shè)計
TMS320C5402的軟件設(shè)計
TMS320C5402的軟件包括EPROM引導(dǎo)程序和系統(tǒng)軟件兩部分。其中,EPROM引導(dǎo)程序比較簡單,其作用是將系統(tǒng)軟件從低速EPROM搬移到高速RAM中。系統(tǒng)軟件由三部分組成:即主程序、串行中斷服務(wù)程序和INT0中斷服務(wù)程序。
主程序完成系統(tǒng)的初始化,包括從閃速存儲器中讀取已經(jīng)存入的語音段數(shù)及數(shù)字音量等信息。完成初始化過程后,TMS320C5402就等待從AT89C51主處理器發(fā)來的各種命令,根據(jù)不同命令調(diào)用相應(yīng)的處理程序。
串行中斷服務(wù)程序完成語音的輸入/輸出和數(shù)據(jù)格式的轉(zhuǎn)化功能,由于PCM編解碼器輸出的數(shù)據(jù)是8位m律數(shù)據(jù),因此需將m律數(shù)據(jù)轉(zhuǎn)化為線性格式的數(shù)據(jù)以便TMS320C5402進行處理。同樣,TMS320C5402輸出的線性數(shù)據(jù)也需轉(zhuǎn)化為8位m律才能送至PCM編解碼器進行D/A變換。
INT0中斷服務(wù)程序主要用來接收從AT89C51送來的各種命令,并且設(shè)置相應(yīng)的命令標(biāo)志以便TMS320C5402在主程序中識別并調(diào)用相應(yīng)的子程序。
AT89C51的軟件設(shè)計
AT89C51軟件主要包括初始化程序、主程序、定時中斷服務(wù)程序和INT0中斷服務(wù)程序。在初始化程序中,完成AT89C51的初始化、TMS320C5402的復(fù)位、從TMS320C5402獲得已存入閃速存儲器的語音段數(shù)和數(shù)字音量等。主程序主要是按鍵處理程序。定時器中斷服務(wù)程序每隔10ms中斷一次,增加程序所需的各種計數(shù)器的值,并置各種定時到達標(biāo)志以便主程序判斷使用。
結(jié)語
本文已經(jīng)給出了硬件平臺和軟件設(shè)計思路,只要制作出硬件平臺,并將仿真好的程序移植到dsp平臺上就可以實現(xiàn)數(shù)字壓縮語音錄放,經(jīng)試用具有很好的語音錄放效果。