版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、<p><b> 目 錄</b></p><p><b> 目 錄I</b></p><p><b> 摘要II</b></p><p><b> 第1章 概述1</b></p><p><b> 1.1設計目的1
2、</b></p><p><b> 1.2設計要求1</b></p><p><b> 1.3設計環(huán)境1</b></p><p> 第2章 系統(tǒng)硬件設計方案2</p><p> 2.1 TMS320VC5416芯片的基本原理2</p><p>
3、2.2 語音編碼芯片的選擇4</p><p> 2.3 系統(tǒng)硬件設計4</p><p> 2.3.1 音頻控制接口4</p><p> 2.3.2 音頻數(shù)據(jù)接口5</p><p> 2.3.3 語音數(shù)據(jù)存儲模塊5</p><p> 2.3.4 液晶屏顯示模塊6</p><p&g
4、t; 第3章 軟件設計6</p><p> 3.1 MCBSP 的配置6</p><p> 3.2 AIC23 的初始化7</p><p> 3.3 DSP 上電自舉7</p><p> 第4章 課程設計總結8</p><p><b> 參考文獻9</b></p>
5、;<p> 附錄:源程序代碼10</p><p><b> 摘要</b></p><p> 信息技術和超大規(guī)模集成電路工藝的不斷發(fā)展,極大地推動了 DSP 的發(fā)展。DSP 技術的應用領域也越來越廣,尤其在音頻處理領域。目前,在很多語音處理系統(tǒng)中都用到了語音錄放模塊,采集現(xiàn)場的聲音并存儲起來供以后回放。語音處理系統(tǒng)的實時性、功耗、體積、以及對語音信
6、號的保真度都是很影響系統(tǒng)性能的關鍵因素。本設計采用的高速54x DSP 芯片,最高頻率能達到160MIPS,能夠很好的解決系統(tǒng)的實時性;采用的數(shù)字編解碼芯片TLV320AIC23(以下簡稱AIC23)具有16~32 位采樣精度,錄音回放模式下僅23mW 的功耗。因此,該音頻編解碼芯片與54x DSP 的結合是可移動數(shù)字音頻錄放系統(tǒng)、現(xiàn)場語音采集系統(tǒng)的理想解決方案。</p><p> 經(jīng)過實驗表明,本設計實現(xiàn)的基
7、于定點 DSP 的語音錄放系統(tǒng)具有如下優(yōu)點:</p><p> 1) 音頻數(shù)據(jù)占用資源少</p><p><b> 2) 聲音保真度高</b></p><p><b> 3) 開發(fā)難度低</b></p><p> 4) 語音芯片與DSP 接口電路簡單</p><p>
8、<b> 5) 體積小</b></p><p><b> 第1章 概述</b></p><p><b> 1.1設計目的</b></p><p> 在CCS環(huán)境下基于TMS320VC5416芯片的語音采集壓縮存儲與回放。通過這次課程設計,加深對CCS集成開發(fā)環(huán)境,熟悉DSP 54X同步串口原理
9、,了解音頻編解碼芯片TLV320AIC23原理,了解存儲芯片NAND FLASH原理,掌握DSP54X中斷原理 以及DSP試驗系統(tǒng)箱的使用。鍛煉邏輯思維能力、動手能力以及獨立解決問題的能力,對以后更深入地學習和應用數(shù)字信號處理及相關知識作準備。</p><p><b> 1.2設計要求</b></p><p> ?。?)了解DSP開發(fā)工具及其安裝過程</p&g
10、t;<p> ?。?)熟悉DSP開發(fā)軟件CCS使用</p><p> (3)熟悉工程文件的建立方法、匯編程序開發(fā)調(diào)試過程</p><p> (4)熟悉常用C5416系列指令的用法</p><p> ?。?)通過McBSP1設置AIC23工作模式,通過McBSP0控制AIC23編碼和解碼,語音信號可由MIC輸入和LINEIN輸入,采集的語音數(shù)據(jù)存儲在
11、NAND FLASH上,語音的回放方式可以為BYPASS和LOOP-BACK。</p><p><b> 1.3設計環(huán)境</b></p><p> 計算機、DSP仿真器、DSP 54X EVM板,CCS軟件,EVM54庫文件,NAND FLASF,TLV320AIC23。</p><p> 第2章 系統(tǒng)硬件設計方案</p>
12、<p> 2.1 TMS320VC5416芯片的基本原理</p><p> TMS320VC5416 數(shù)字信號處理器是TI公司為實現(xiàn)低功耗,高速實時信號處理而專門設計的16位定點數(shù)字信號處理器,采用改進的哈佛結構,具有高度的操作靈活性和運行速度,適用于遠程通信等實時嵌入式應用的需要。廣泛應用于電子測試、電子設計、模擬仿真、通信工程中。</p><p> TMS320VC54
13、16具有的主要優(yōu)點如下:</p><p> (1) 圍繞一組程序總線、三組數(shù)據(jù)總線和四組地址總線而建立的改進哈佛結構,提高了系統(tǒng)的多功能性和操作的靈活性。</p><p> (2) 具有高度的并行性和專用硬件邏輯的CPU設計,提高了芯片的性能。</p><p> (3) 具有完善的尋址方式和高度專業(yè)化指令系統(tǒng),更適用于快速算法的實現(xiàn)和高級語言編程的優(yōu)化。<
14、;/p><p> (4) 模塊化結構設計,使派生器件得到了更快的發(fā)展。</p><p> (5) 采用先進的IC制造工藝,降低了芯片的功耗,提高了芯片的性能。</p><p> (6) 采用先進的靜態(tài)設計技術,進一步降低了功耗,使芯片具有更強的應用能力。</p><p> TMS320VC5416主要有中央處理器CPU,特殊功能寄存器,數(shù)
15、據(jù)存儲器RAM,程序存儲器ROM,I/O接口功能,串行口,主機通信接口HPI,定時器,中斷系統(tǒng)等10部分組成。</p><p><b> 各部分功能如下:</b></p><p> (1) 中央處理器(CPU)</p><p> 它是DSP芯片的核心,它有以下特點:</p><p> (a) 采用多總線結構,通過
16、一組程序總線、三組數(shù)據(jù)總線和四組地址總線來實現(xiàn)。</p><p> (b) 40位算術邏輯運算單元ALU,包括一個40位的桶形移位寄存器和兩個獨立的40位累加器。</p><p> (c) 17×17位并行乘法器,與40位專用加法器相連,可用于進行非流水線的單周期乘法—累加運算。</p><p> (d) 比較、選擇、存儲單元,可用于Viterbi譯
17、碼器的加法-比較-選擇運算。</p><p> (e) 指數(shù)編碼器,是一個支持單周期指令EXP的專用硬件??梢栽谝粋€周期內(nèi)計算40位累加器數(shù)值的指數(shù)。</p><p> (f) 配有兩個地址生成器,包括8個輔助寄存器和2個輔助寄存器運算單元。</p><p> (2)數(shù)據(jù)存儲器RAM</p><p> TMS320VC5416有兩種片
18、內(nèi)數(shù)據(jù)存儲器:</p><p> (a) 雙尋址RAM:在一個指令周期內(nèi),可對其進行兩次存取操作,一次讀出和一次寫入;</p><p> (b) 雙尋址RAM:在一個指令周期內(nèi),只能進行一次存取操作。</p><p> (3) 程序存儲器ROM</p><p> TMS320VC5416的程序存儲器可由ROM和RAM配置而成,程序空間
19、可以定義在ROM上,也可以定義在ROM上。當需要高速運行程序時,可以將片外ROM中的程序調(diào)入到片內(nèi)RAM中,以提高程序運行速度。降低對外部ROM的要求,增強系統(tǒng)整體抗干擾性能。</p><p><b> (4) I/O口</b></p><p> TMS320VC5416芯片只有兩個通用I/O引腳BIO和XF,BIO主要用來監(jiān)測外部設備工作狀態(tài),而XF用來發(fā)信號給
20、外部設備。 </p><p> 另外,芯片還配有主機接口HPI,同步串行口和64K字的I/O空間,HPI和串行口通過控制,用做通用I/O口使用。而64K字I/O空間可通過外加緩沖器或鎖存電路,配合外部I/O讀寫控制時序構成片外外設的控制電路。</p><p><b> (5) 定時器</b></p><p> 定時器是一個軟件可編程計數(shù)器
21、,用來產(chǎn)生定時中斷。定時器主要由定時寄存器TM,定時周期寄存器PRD,定時控制寄存器TCR及相應的邏輯控制電路組成。其中寄存器TIM、PRD和TCR都是存儲映象寄存器,它們在數(shù)據(jù)存儲器中的地址分別為0024H、0025H和0026H。TIM是一個減1寄存器。PRD用來存放定時時間常數(shù)。TCR中包含定時器的控制位和狀態(tài)位。</p><p><b> (6) 中斷系統(tǒng)</b></p>
22、;<p> TMS320VC5416的中斷系統(tǒng)具有硬件中斷和軟件中斷。 </p><p> 硬件中斷:由外圍設備引起的中斷分為片外外設所引起的中斷和片內(nèi)外設所引起的中斷。</p><p> 軟件中斷:有程序指令INTR、TRAP和RESET所引起的中斷。中斷管理優(yōu)先級為11—16個固定級,有4種工作方式。</p><p> (7) 主機接口HP
23、I</p><p> HPI是一個與主機通信的并行接口,主要用于DSP與其他總線或CPU進行通信,信息可通過TMS320VC5416的片內(nèi)存儲器與主機進行數(shù)據(jù)交換。不同型號的器件配置不同的HPI口,可分為8位標準HPI口、8位增強型HPI接口和16位增強型HPI接口。</p><p><b> (8) 指令系統(tǒng)</b></p><p>
24、支持單指令重復和塊指令重復;支持存儲器塊傳送指令;支持32位長操作數(shù)指令;具有支持2操作數(shù)或3操作數(shù)的讀指令;具有能并行存儲和并行加載的算術指令;支持條件存儲指令及中斷快速返回指令。</p><p><b> (9) 片外圍電路</b></p><p> 具有軟件可編程等待狀態(tài)發(fā)生器;設有可編程分區(qū)轉換邏輯電路;帶有內(nèi)部震蕩器或外部時鐘源的片內(nèi)鎖相環(huán)發(fā)生器;支持全
25、雙工操作的串行口,可進行8位或16位串行通信。</p><p> 2.2 語音編碼芯片的選擇</p><p> 從適應語音信號頻率、滿足實時性、降低成本、簡化設計的要求出發(fā),本系統(tǒng)選擇TLV320AIC23。AIC23 工作電壓3.3 伏特,能在數(shù)字和模擬電壓下工作,與TMS320VC5416的I/O 電壓相兼容,其控制接口和數(shù)字接口與DSP 的MCBSP 端口能夠無縫連接。AIC23
26、的模數(shù)轉換(ADCs)和數(shù)模轉換(DACs)部件高度集成在芯片內(nèi)部,采用了先進的Sigma-delta 過采樣技術,可以在8K 到96K 的頻率范圍內(nèi)提供16bit、20bit、24bit 和32bit 的采樣,ADC 和DAC 的輸出信噪比分別可以達到90dB 和100dB[1]。</p><p> 2.3 系統(tǒng)硬件設計</p><p> AIC23 有獨立的控制接口和數(shù)字接口??刂?/p>
27、口用于接收控制器的命令字,數(shù)據(jù)接口與DSP 完成語音數(shù)據(jù)的交換。AIC23 的工作時鐘由外接的一個11.2896M 的晶振提供,同時該晶振也為DSP 提供工作時鐘。DSP 的工作時鐘是5 倍頻后的時鐘:56.488M。本系統(tǒng)用到了利用DSP 的MCBSP0 和MCBSP1,分別與AIC23 的控制和數(shù)據(jù)接口相連。DSP 與AIC23的接口電路如圖2</p><p> 2.3.1 音頻控制接口</p>
28、<p> MCBSP1 接 AIC23 的控制接口。AIC23 提供SPI 和I2C 兩種控制接口方式。該器件的模式終端狀態(tài)(MODE)決定了控制接口的形式。本設計將MODE 引腳接高,選擇SPI 方式。AIC23 的控制口主要是為了接收DSP 的控制字,因此這里DSP 的MCBSP1 作為主器件。AIC23 有許多可編程特性,其內(nèi)部有11 個9 位可編程控制寄存器,DSP 通過MCBSP1 來訪問這些控制寄存器。SDI
29、N 為串行數(shù)據(jù)輸入端,它接收DSP 串行數(shù)據(jù),數(shù)據(jù)字長16 位,其中高7 位為地址信息,低9 位為AIC23 的命令字。SCLK 為控制端口串行數(shù)據(jù)時鐘輸入, DSP串口的采樣率發(fā)生器對CPU 時鐘分頻后得到串口的發(fā)送時鐘BCLKX1=225.952KHz,產(chǎn)生的時鐘通過SCLK 引腳驅動AIC23。</p><p> 2.3.2 音頻數(shù)據(jù)接口</p><p> DSP 與AIC23
30、的數(shù)據(jù)交換是通過串口0 實現(xiàn)的。其中MCBSP 多通道緩沖串口數(shù)據(jù)的接收是通過三級緩沖完成的[2],即引腳DR 上的數(shù)據(jù)先到達移位寄存器RSR,當收到一個滿字之后數(shù)據(jù)被裝載到數(shù)據(jù)接收寄存器RBR 中,最后數(shù)據(jù)才被拷貝到接收數(shù)據(jù)寄存器DRR中。DSP 通過串口0 接收AIC23 采集的語音數(shù)字信號,并且在回放模式下,通過串口將語音信號傳送給AIC23。這時音頻芯片為主器件,給DSP 提供幀同步和時鐘信號。</p><p
31、> AIC23 芯片與數(shù)字系統(tǒng)的接口有右判斷模式、左判斷模式、I2S 模式和DSP 模式四種數(shù)據(jù)格式。數(shù)字音頻接口由時鐘信號BCLK、數(shù)據(jù)信號DIN 和DOUT、同步信號LRCIN 和LRCOUT 組成。由于DSP 的MCBSP 接口與該芯片的DSP 模式相兼容,因此該音頻模塊采用了DSP 模式。現(xiàn)對DSP 模式進行說明。該音頻處理模塊采用的是DSP 作為從設備,AIC23為主設備。DSP 模式下的數(shù)據(jù)格式為:發(fā)送、接收幀長度為
32、2 個字,每個字長16 位。幀同步信號有效后跟著是兩個數(shù)據(jù)字。</p><p> AIC23 作為數(shù)據(jù)接口的主器件,為DSP 提供發(fā)送接收時鐘,以及幀同步信號,在幀同步信號的下降沿開始傳送數(shù)據(jù),左通道數(shù)據(jù)組成了首先傳送的數(shù)據(jù)字,緊接著傳送右通道的數(shù)據(jù)。傳送字長32 位,其中左通道數(shù)據(jù)16 位,右通道數(shù)據(jù)16 位。BCLK 在主動方式下是輸出,而在從動方式下是輸入。在LRCIN 或LRCOUT 的下降沿開始數(shù)據(jù)傳
33、輸。DSP 為了接收正確的語音數(shù)據(jù),應該將串口的數(shù)據(jù)格式配置為與AIC23 相同。幀同步脈沖高電平有效。接收、發(fā)送時鐘CLKR、幀同步信號由外部時鐘驅動。其中幀同步信號寬度是1 個BCLK時鐘寬度。幀周期為32 個BCLK 時鐘。在CLKR 的上升沿,發(fā)送或采樣接收數(shù)據(jù)。DSP 模式下的數(shù)據(jù)傳輸時序入下:</p><p> 2.3.3 語音數(shù)據(jù)存儲模塊</p><p> 考慮到存儲器芯
34、片的容量、系統(tǒng)供電、以及對語音信號的讀取速率。本系統(tǒng)采用了具有32MX8 位存儲空間的K9F5608 Nandflash。Nandflash 以容量大價格低的優(yōu)勢被廣泛應用在便攜式設備中。同時Nandflash 存儲器在寫入時需要復雜的操作命令,這樣確保了數(shù)據(jù)寫入的正確性。K9F5608 有8 位I/O 端口,地址、命令字以及數(shù)據(jù)復用這8 位I/O 端口。它采用復雜的操作順序來區(qū)分地址、命令、數(shù)據(jù)信息。DSP 采集到的32 位語音數(shù)據(jù)通
35、過外部數(shù)據(jù)總線的低8 位分4 次,從左聲道的高8 位到右聲道的低8 位依次寫入Nandflash。</p><p> 2.3.4 液晶屏顯示模塊</p><p> 對于 DSP 來講LCD 是典型的慢速設備,如果僅僅靠設置DSP 等待周期寄存器,在訪問外部I/O 時最多只能插入14 個等待周期,這點延時對DSP 來說是遠遠不夠的。因此,需要在DSP 與LCD 之間加入時序控制電路。與N
36、andflash 模塊類似,液晶屏、Nandflash 與DSP 的接口電路由CPLD 來完成,液晶屏占用DSP 兩個I/O 地址,分別是命令和數(shù)據(jù)地址。DSP 對I/O 空間的操作由地址線、數(shù)據(jù)線和三根信號線IOSTRB、R/W 和IS 來完成[4] 。CPLD根據(jù)DSP 給出的讀寫信號以及地址信號,產(chǎn)生液晶屏的片選、讀寫信號、以及鍵盤的掃描信號。</p><p><b> 第3章 軟件設計<
37、/b></p><p> 系統(tǒng)的軟件開發(fā)環(huán)境是 TI 公司的DSP 集成開發(fā)環(huán)境CCS 2.0。CCS 提供了軟件開發(fā)、程序調(diào)試和系統(tǒng)仿真環(huán)境。CCS 不但能支持匯編語言,而且還支持C/C++語言進行軟件開發(fā)。CCS 提供的C 編譯器能優(yōu)化代碼,提高C 程序的運行效率。系統(tǒng)有兩種工作方式,一種是現(xiàn)場采集并播放,即系統(tǒng)采集現(xiàn)場的線路輸入信號或麥克語音信號,并存儲在NandFlash中,在采集的過程中,同時通
38、過耳機播出。另一種是播放錄制的語音數(shù)據(jù),即不采集現(xiàn)場語音信號,直接播放已經(jīng)存儲在NandFlash 中的語音數(shù)據(jù)。這兩種工作方式可以在系統(tǒng)初始化工程時通過按鍵選擇。具體的程序代碼段設計主要包括MCBSP 口的配置、AIC23 的初始化、NandFlash 燒寫、DSP 上電自舉,這四個部分。其中現(xiàn)場采集、播放的流程圖如下:</p><p> 3.1 MCBSP 的配置</p><p>
39、 5416 提供的MCBSP 口是一種高速、雙向、多通道帶緩沖的串行接口。它可以與其他C54x DSP 器件、編碼器或其他串行接口器件通信。MCBSP 的硬件部分是基于標準串行接口的[3]。MCBSP 的控制模塊包括幀同步信號發(fā)生器、內(nèi)部時鐘發(fā)生器、以及它們的控制電路和多通道選擇。與MCBSP 有關的控制寄存器是通過子地址尋址來訪問的,它有28 個子寄存器只占用一個DSP 內(nèi)存地址。MCBSP 的子地址寄存器(SPSA)用來指向這些使用
40、同一個內(nèi)存地址的寄存器中的某一個。MCBSP 子數(shù)據(jù)寄存器(SPSDx)用來訪問選中的寄存器。由于配置每個寄存器的代碼段相同,首先指定子地址寄存器地址,接著給數(shù)據(jù)。為了保證程序的簡潔與可讀性,這里采用調(diào)用函數(shù)的方法來替代這些重復代碼,代碼具體實現(xiàn)如下:</p><p> #define MCBSP1_SET(add,data)</p><p> MCBSP1_SPSA = add, M
41、CBSP1_SPSD = data // 定義一個宏函數(shù),第一個參數(shù)add 為子地址寄存器的地址,data 為子地址寄存器的值</p><p> MCBSP1_SET( SPCR1, 0x1801)</p><p> // SPCR1=0x1801</p><p> MCBSP1_SET( SPCR2, 0x03C1)</p><p>
42、 // SPCR2=0x03C1</p><p> 3.2 AIC23 的初始化</p><p> AIC23 具有8 個可編程的內(nèi)部寄存器,通過軟件編程能隨時控制AIC23 的采樣頻率,高、低通濾波器的截止頻率,模擬輸入及輸出的增益。DSP 通過串口1 完成對AIC23 的初始化工作。程序中把對AIC23 的初始化命令寫在一個數(shù)組中,采用循環(huán)方式將這些命令通過串口發(fā)送出去。<
43、/p><p> codec[10]={0x1e00,0x0c00,0x0811,0x0a04,0x0e43,0x102c,0x1201,0x0117,0x05ff, 0x07ff};</p><p> MCBSP1_DXR1=codec[i];</p><p> 3.3 DSP 上電自舉</p><p> 當軟硬件設計工作完成后,需要系統(tǒng)
44、能夠脫離PC 機獨立運行。這就需要將調(diào)試好的.out燒寫到外部Flash 中,并要求目標系統(tǒng)上電后可自行啟動并執(zhí)行用戶軟件代碼,這就需要用到DSP 的自舉引導(Bootloader)技術。這里采用的是16 位并行Flash 引導方式。使用Hex500.exe 將.out 文件轉換成16 進制的自舉表文件,通過燒寫器將這個自舉表文件燒寫到flash 中。然而,這種脫機燒寫不能燒寫貼片封裝的芯片,系統(tǒng)的靈活性受到很大的限制。本設計采用了一種
45、新的一次裝載程序并燒寫的在線燒寫方法。用 Hex500.exe 生成好自舉表文件后,另外跟據(jù)Flash 的編程方法,編寫燒寫代碼,并讀取自舉表文件。在C 程序源碼中讀取的自舉表文件是ASCII 值,因此需要在程序中加一段格式轉換代碼,將數(shù)據(jù)轉換成二進制文件,并且去掉自舉表的表頭和表尾。轉換時采用一個4 次循環(huán),先讀取4 位16進制數(shù)的最高位,把這個ASCII 值轉換成二進制數(shù)字,將其左移4 位,接著讀取次高位。循環(huán)4 次便得到了可以直接
46、燒寫的數(shù)據(jù)。系統(tǒng)脫機工時,通過外部并行總線,用DMA 方式將這些代碼從數(shù)據(jù)空間搬移到程序</p><p> 第4章 課程設計總結</p><p> 通過這次的DSP課程設計,讓我充分認識到了我的不足。我雖然學習過C語言的編程,但一旦將它應用到實際的比較專業(yè)的問題上,我所學的知識就變得完全不夠用了,為了這次課程設計我查詢了大量的資料,無論是C語言方面的還是壓縮算法方面的都讓我們花費了很多
47、時間,查詢到了需要的資料我們又對它們進行了整理,提取出我們需要的a律壓縮和μ律壓縮的算法和原理,并且努力去理解其中的知識,使其能為我們所用,盡管如此我們?nèi)匀粵]能成功的編出屬于我們自己的程序,因此我們找到了一份編好的程序,用我們已經(jīng)理解的知識去分析它,理解這份程序的原理,并根據(jù)我們的實際對它進行一些修改,從而我們才得出我們現(xiàn)在的程序。雖然程序編寫成功了但我們在調(diào)試上又遇到了很多的問題,比如在CCS環(huán)境下我們要如何觀察波形,波形有代表什么等
48、等,為此我們又不斷的翻閱課件和資料,才最終解決了所有的問題,我的課程設計才算基本完成了。</p><p> 整個課程設計過程中,我在不斷的查閱資料和開動腦筋過程中,鍛煉了我的資料采集能力,也鍛煉了我的分析整理能力,為以后做畢業(yè)設計打下了基礎;同樣在實驗過程中我遇到很多困難,而這些困難則鍛煉了我的耐心和分析解決問題的能力;通過編程鍛煉了我的編程能力,使我對C語言,匯編語言更加熟悉,讓我能更好的運用它們;同時也鍛煉
49、了我們的團結協(xié)作能力,為將來走入社會能更好的工作打下了基礎。</p><p> 總之通過這次的實驗,讓我認識到了自己的不足,同時又通過這次的實驗讓我們學到了讓我們受用一生的知識。</p><p><b> 參考文獻</b></p><p> [1]戴明楨等編著.TMS320C54X DSP 結構原理及應用. 北京:航空航天大學出版社,第2
50、版,2007;</p><p> [2]彭啟琮編著.DSP技術的發(fā)展與應用.北京:高等教育出版社,2002;</p><p> [3]胡廣書編著.數(shù)字信號處理理論、算法與實現(xiàn).北京:清華大學出版社,2005;</p><p> [4]北京合眾達電子技術有限公司編著.SEED-DTK系列實驗手冊.北京合眾達電子技術有限公司出版,2007。</p>
51、<p> [5]鄒彥主編.DSP原理及應用.電子工業(yè)出版社,2012.1</p><p><b> 附錄:源程序代碼</b></p><p> #include <stdio.h></p><p> #include "mmdrv.h"</p><p> #includ
52、e "mcbsp.h"</p><p> #include "cpu_reg.h" </p><p> #include "lcd_86.h"</p><p> ioport unsigned portefff;</p><p> #define IO_374 p
53、ortefff</p><p> void init_exint1_interrupt();</p><p> void init_GPIO(void); </p><p> void mic_bypass(void);</p><p> void line_in_bypass(void);</p><p>
54、; void mic_record(void);</p><p> void line_in_record(void);</p><p> void codec_play(void);</p><p> void DEAL_RX(unsigned int i);</p><p> unsigned int DEAL_TX(void)
55、;</p><p> void stop_interrupt(); //stop receive & tranmit interrupt</p><p> unsigned int flag=0xffff;</p><p> unsigned long secter_num;</p><p> unsigned int p
56、ing_buf1[0x2000]; </p><p> unsigned int ping_buf2[0x2000];</p><p> unsigned int enc_flag=0; </p><p> unsigned int input_flag =0;</p><p> unsigned int rl_flag=0;
57、 </p><p> unsigned int count1=0 ;</p><p> #define max_secter_num33</p><p> #define init_secter_num0</p><p> void main(void)</p&
58、gt;<p><b> {</b></p><p> unsigned int i,j;</p><p> unsigned int key_val;</p><p> SWWSR = 0x7fff;</p><p> SWCR = 0x0001;</p><p>
59、BSCR = 0x8006; </p><p> CLKMD = PLL_DIV_INIT;</p><p> waitloop( 0x0400 );</p><p> CLKMD = PLL_LOCK_INIT_X(9);</p><p> waitloop( 0x0400 ); </p><
60、p> PMST = 0x0168;</p><p> Init_MCBSP_codec();</p><p> init_codec_linein();</p><p> init_exint1_interrupt();</p><p> init_GPIO(); </p><p> init_l
61、cd();</p><p> LCD_clear(0);</p><p> cur_row=2; </p><p> cur_col=20; </p><p> LCD_pr_chars("RECORD_PLAY TEST",16);</p><p> cur_
62、row=3; </p><p> cur_col=1; </p><p> LCD_pr_chars("=======================",23);</p><p> IO_374=0xffff;//374 enable</p><p> Close_LED_Data(
63、);</p><p> Close_LED_Traf();</p><p> Close_LED_sign();</p><p> waitloop( 0x0400 ); </p><p><b> while(1)</b></p><p> {i=Get_Key();&l
64、t;/p><p> waitloop( 0x04000 );</p><p> j=Get_Key();</p><p><b> if(i==j)</b></p><p><b> {</b></p><p> flag=0xffff;</p><
65、;p> key_val=j;/*Save key_val*/ </p><p> switch(key_val)</p><p><b> {</b></p><p><b> default: </b></p><p><b> break;
66、</b></p><p><b> case 1:</b></p><p> cur_row=4; </p><p> cur_col=10; </p><p> LCD_pr_chars(" Mic_Bypass ",17);</p&g
67、t;<p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars(" ",17);</p><p> mic_bypass(); </p><p><b> b
68、reak;</b></p><p><b> case 2:</b></p><p> cur_row=4; </p><p> cur_col=10; </p><p> LCD_pr_chars(" Line_In_Bypass ",17);<
69、;/p><p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars(" ",17);</p><p> line_in_bypass(); </p><p><
70、;b> break;</b></p><p><b> case 3:</b></p><p> cur_row=4; </p><p> cur_col=10; </p><p> LCD_pr_chars("Mic_Rec_Loopback "
71、;,17);</p><p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars(" ",17);</p><p> mic_record();</p><p><
72、b> break;</b></p><p><b> case 4:</b></p><p> cur_row=4; </p><p> cur_col=10; </p><p> LCD_pr_chars("Line_Rec_Loopback"
73、,17);</p><p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars(" ",17);</p><p> line_in_record();</p><p>&
74、lt;b> break;</b></p><p><b> case 6:</b></p><p> cur_row=4; </p><p> cur_col=10; </p><p> LCD_pr_chars(" codec_play &qu
75、ot;,17);</p><p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars(" ",17);</p><p> codec_play();</p><p>&l
76、t;b> break;</b></p><p><b> }</b></p><p><b> } </b></p><p><b> }</b></p><p><b> }</b></p><p&g
77、t; void init_exint1_interrupt() </p><p><b> {</b></p><p> IFR =0xffff;</p><p> IMR =0x0002;//EXINT1=IMR.1</p><p> asm("\trsbx\tintm ");
78、</p><p><b> } </b></p><p> void init_tx_interrupt() //transmit interrupt</p><p><b> {</b></p><p> IFR =0xffff;</p><p> I
79、MR =0x22;//BXINT0=IMR.5=1, BXINT0=IMR.4=0,EXINT1=IMR.1=1</p><p> asm("\trsbx\tintm ");</p><p><b> } </b></p><p> void init_re_interrupt() //receive
80、interrupt</p><p><b> {</b></p><p> IFR =0xffff;</p><p> IMR =0x12;//BXINT0=IMR.5=0, BXINT0=IMR.4=1,EXINT1=IMR.1=1</p><p> asm("\trsbx\tintm &quo
81、t;);</p><p><b> } </b></p><p> void stop_interrupt() //stop receive & tranmit interrupt</p><p><b> {</b></p><p> IFR =0xffff;</p>
82、;<p> IMR =0x0002;//EXINT1=IMR.1</p><p> asm("\trsbx\tintm ");</p><p><b> } </b></p><p> interrupt void BRINT0_isr(void)</p><p>
83、<b> {</b></p><p> unsigned int i; </p><p> i = MCBSP0_DRR1; /* DRR1 = txdata */ </p><p> MCBSP0_DXR1 = i; </p><p> DEAL_RX(i);</p><
84、p><b> } </b></p><p> interrupt void BXINT0_isr()</p><p><b> {</b></p><p> MCBSP0_DXR1 = DEAL_TX(); </p><p> }
85、 </p><p> interrupt void EXINT1_isr()</p><p><b> {</b></p><p> unsigned int i;</p><p> IO_374=0xffff;//374 enable</p><p> Close_LED_Dat
86、a();</p><p> Close_LED_Traf();</p><p> Close_LED_sign();</p><p> IFR =0xffff;</p><p> //while(!(GPIOSR&0x01))</p><p><b> {</b></p&
87、gt;<p> asm("\tnop");</p><p> asm("\tnop");</p><p><b> }</b></p><p> flag=0;//~flag;</p><p> cur_row=5; </p>
88、<p> cur_col=15; </p><p> LCD_pr_chars("Codecr_Stop_play ",17);</p><p> for(i=0;i<8;i++)</p><p><b> {</b></p><p> Disp_LED_sig
89、n(0,i);</p><p><b> }</b></p><p><b> }</b></p><p> void init_GPIO(void) </p><p><b> {</b></p><p> GPIOCR =0xfffe;
90、 //EXINT1=GPIO.0=input=0,nand_cs=GPIO.6=output=1</p><p> GPIOSR =0x0040; //GPIO.6=output=1</p><p><b> } </b></p><p> void mic_bypass(void) </p><
91、;p><b> {</b></p><p> unsigned int data;</p><p> Init_MCBSP_codec();</p><p> init_codec_mic();</p><p> while(flag)</p><p><b> {&
92、lt;/b></p><p> data=mcbsp0_codec_rx_data();</p><p> mcbsp0_codec_tx_data(data);</p><p><b> }</b></p><p> init_codec_linein(); </p><p>
93、<b> } </b></p><p> void line_in_bypass(void)</p><p><b> {</b></p><p> unsigned int sign_bit=0;</p><p> unsigned int sign_state=1;//1<
94、/p><p> unsigned int data;</p><p> // Init_MCBSP_codec();</p><p> //init_codec_linein();</p><p> while(flag)</p><p><b> {</b></p>&
95、lt;p> data=mcbsp0_codec_rx_data();</p><p> mcbsp0_codec_tx_data(data);</p><p> Disp_LED_sign((sign_state&0x01),sign_bit);</p><p> sign_bit++;</p><p> if(si
96、gn_bit==0x7f0)</p><p><b> {</b></p><p> sign_bit=0; </p><p> sign_state =~sign_state;</p><p><b> } </b></p><p><b> }
97、</b></p><p><b> } </b></p><p> void mic_record(void)</p><p><b> {</b></p><p> unsigned int sign_bit=0;</p><p> uns
98、igned int sign_state=1;</p><p> Init_MCBSP_codec();</p><p> init_codec_mic();</p><p> init_re_interrupt(); //receive interrupt</p><p> enc_flag=0; </p>&l
99、t;p> secter_num=init_secter_num; </p><p> count1 =0;</p><p> MCBSP0_DXR1 = MCBSP0_DRR1;/* DRR1 = txdata */ </p><p> while(flag)</p><p><b> {</b&g
100、t;</p><p> if(enc_flag)</p><p><b> {</b></p><p> Disp_LED_sign((sign_state&0x01),sign_bit);</p><p> sign_bit++;</p><p> if(sign_bit==8
101、)</p><p><b> {</b></p><p> sign_bit=0;</p><p> sign_state =~sign_state;</p><p><b> } </b></p><p> enc_flag=0;</p><p
102、> if(input_flag)</p><p><b> {</b></p><p> erase_nand_flash(secter_num);</p><p> Write_nand_flash_block(secter_num,ping_buf2,0);</p><p><b> }&
103、lt;/b></p><p><b> else</b></p><p><b> {</b></p><p> erase_nand_flash(secter_num);</p><p> Write_nand_flash_block(secter_num,ping_buf1,0);
104、</p><p><b> }</b></p><p> secter_num +=32;</p><p> if(secter_num>32*max_secter_num)</p><p> { </p><p> asm("\tnop&
105、quot;);</p><p> asm("\tnop");</p><p> asm("\tnop");</p><p> secter_num=init_secter_num;</p><p><b> break;</b></p><p>&l
106、t;b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> Close_LED_Data();</p><p> Close_LED_Traf();</p><p> Close_LED_s
107、ign();</p><p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars("Codecr_Stop_play ",17);</p><p> stop_interrupt(); //stop receive &am
108、p; tranmit interrupt</p><p> init_codec_linein();</p><p><b> }</b></p><p> void line_in_record(void)</p><p><b> {</b></p><p>
109、unsigned int sign_bit=0;</p><p> unsigned int sign_state=1;</p><p> enc_flag=0; </p><p> secter_num=init_secter_num; </p><p> count1 =0;</p><p> Init
110、_MCBSP_codec();</p><p> //init_codec_linein();</p><p> init_re_interrupt(); //receive interrupt</p><p> MCBSP0_DXR1 = MCBSP0_DRR1;/* DRR1 = txdata */</p><p>
111、while(flag)</p><p><b> {</b></p><p> if(enc_flag)</p><p><b> {</b></p><p> Disp_LED_sign((sign_state&0x01),sign_bit);</p><p&
112、gt; sign_bit++;</p><p> if(sign_bit==8)</p><p><b> {</b></p><p> sign_bit=0;</p><p> sign_state =~sign_state;</p><p><b> } </b&g
113、t;</p><p> enc_flag=0;</p><p> if(input_flag)</p><p><b> {</b></p><p> erase_nand_flash(secter_num);</p><p> Write_nand_flash_block(secter
114、_num,ping_buf2,0);</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> erase_nand_flash(secter_num);</p><p
115、> Write_nand_flash_block(secter_num,ping_buf1,0);</p><p><b> }</b></p><p> secter_num +=32;</p><p> if(secter_num>32*max_secter_num)</p><p> {
116、 </p><p> asm("\tnop");</p><p> asm("\tnop");</p><p> asm("\tnop");</p><p> secter_num=init_secter_num;</p><p&
117、gt;<b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p><b> }</b></p><p> Close_LED_Data();</p><p>
118、 Close_LED_Traf();</p><p> Close_LED_sign();</p><p> cur_row=5; </p><p> cur_col=15; </p><p> LCD_pr_chars("Codecr_Stop_play ",17);</p&g
119、t;<p> stop_interrupt(); //stop receive & tranmit interrupt</p><p><b> }</b></p><p> void codec_play(void)</p><p><b> {</b></p><p
120、> unsigned int sign_bit=0;</p><p> unsigned int sign_state=1;</p><p> enc_flag=0; </p><p> secter_num=init_secter_num+32; </p><p> input_flag = 1;
121、 </p><p> count1 =0;</p><p> Init_MCBSP_codec();</p><p> read_nand_flash_block(secter_num,ping_buf2,0);</p><p> secter_num
122、 +=32; </p><p> count1 =0;</p><p> //init_tx_interrupt(); </p><p> MCBSP0_DXR1 = 0;/* DRR1 = txdata */</p><p> while(flag) </p><p><b>
123、 {</b></p><p> mcbsp0_codec_tx_data(DEAL_TX());</p><p> if(enc_flag)</p><p><b> {</b></p><p> Disp_LED_sign((sign_state&0x01),sign_bit);</
124、p><p> sign_bit++;</p><p> if(sign_bit==8)</p><p><b> {</b></p><p> sign_bit=0;</p><p> sign_state =~sign_state;</p><p><b>
125、; } </b></p><p> enc_flag=0;</p><p> if(input_flag)</p><p><b> {</b></p><p> read_nand_flash_block(secter_num,ping_buf2,0);</p><p>
126、<b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> read_nand_flash_block(secter_num,ping_buf1,0);</p><p><b> }</b
127、></p><p> secter_num +=32;</p><p> if(secter_num>32*max_secter_num)</p><p> { </p><p> asm("\tnop");</p><p> asm("
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- dsp課程設計--數(shù)字信號處理的最小系統(tǒng)
- dsp最小系統(tǒng)課程設計
- dsp數(shù)字信號處理課程設計報告-- 語音壓縮與回放
- dsp最小系統(tǒng)課程設計
- 數(shù)字信號處理(dsp)課程設計報告
- 數(shù)字信號課程設計--數(shù)字信號處理
- dsp數(shù)字信號處理課程設計報告8
- 數(shù)字信號課程設計--語音數(shù)字信號處理與分析及matlab實現(xiàn)
- 數(shù)字信號處理課程設計--語音信號的處理與濾波
- 數(shù)字信號處理課程設計---語音信號的處理與濾波
- 數(shù)字信號處理課程設計---語音信號的處理與濾波
- 數(shù)字信號處理課程設計--語音信號的處理與濾波
- 基于dsp_builder數(shù)字信號處理課程設計
- 數(shù)字信號課程設計---語音信號的處理與濾波
- dsp最小系統(tǒng)課程設計---tms320lf2407a最小系統(tǒng)的設計
- dsp數(shù)字信號處理課程設計報告-- ad接口設計
- 數(shù)字信號處理課程設計--語音信號濾波去噪
- dsp數(shù)字信號處理課程設計報告-- 步進電機
- 數(shù)字信號處理課程設計---基于matlab的語音信號濾波處理
- 數(shù)字信號處理課程設計
評論
0/150
提交評論