在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > 基于DSP的DMA控制技術(shù)概述

            基于DSP的DMA控制技術(shù)概述

            作者: 時間:2012-05-17 來源:網(wǎng)絡 收藏

            本文引用地址:http://www.biyoush.com/article/257504.htm

            4 軟件編程

            實現(xiàn)控制方式的軟件編程主要包括控制器8237-5的初始化、的HOLD操作以及外設初始化相關(guān)設置等三部分。根據(jù)所實現(xiàn)的具體功能不同,各部分的一些細節(jié)可能有所區(qū)別。

            下面給出控制方式在以為核心的語言學習系統(tǒng)中的一個具體應用。它可以實現(xiàn)DMA方式的采樣和回放,用于兩個人之間的全雙工會話功能。所用外設是聲卡。由于要同時進行采樣和回放,所以8237-5需要使用兩個DMA通道。

            4.1 8237-5的初始化

            8237-5初始化的一般內(nèi)容可參閱參考文獻[2],關(guān)鍵在于方式寄存器和命令寄存器的規(guī)定。根據(jù)全雙工會話功能的具體要求,本例程的方式寄存器和命令寄存器初始化如下:

            splk #0049h,60h ;方式寄存器,通道1,讀傳送,

            out 60h,dma_mode_res 地址增,單字節(jié)傳送,禁止自動預置。

            splk #0047h,60h ;方式寄存器,通道3,寫傳送,

            out 60h,dma_mode_res 地址增,單字節(jié)傳送,禁止自動預置。

            splk #0000h,60h ;命令寄存器,禁止存儲器

            out 60h,dma_command_res 到存儲器傳送,禁止通道0地址保持,允許芯片工作,正常時序,固定優(yōu)先級,滯寫入選擇,DREQ高電平有效,DACK低電平有效。

            4.2 聲卡初始化中的相關(guān)設置

            聲卡一般默認DMA0=1為回放通道、DMA1=3為采樣通道,這在其PNP初始化中規(guī)定。I9寄存器用于禁止聲卡并行傳送方式,啟動DMA方式:

              splk #0049h,60h ;select I9 ,MCE=1。

              out 60h,534h

              splk #001bh,60h ;全校準,禁止PIO方式,允許DMA采樣和回放。

              out 60h,535h

            聲卡還有幾個與DMA操作有關(guān)的寄存器:I14、I15、I30、I31。I14、I15用于設定DMA回放的計數(shù)基值,I30、I31則用于設定DMA采樣的計數(shù)基值。它可以產(chǎn)生一個中斷以方便用戶做相應處理。

            4.3 的HOLD操作中斷服務子程序

            inpt1: in dsp_icr,icr ;讀 DSP 中斷控制寄存器。

               bit dsp_icr,11 ;測試MODE位,判斷是否是HOLD 操作。

               bcnd skip_int1,tc ;如果MODE=1,則退出中斷服務子程序。

              /以下幾句完成DMA操作/

            ready:

            lacl imr ;保護中斷屏蔽寄存器。

            splk #0001h,imr ;屏蔽除HOLD/INT1之外的所有可屏蔽中斷。

            idle ;進入HOLD操作。發(fā)出/HOLDA,外部總線被置為高阻狀態(tài),等待HOLD/INT1引腳上的上升沿。

            splk #1,ifr ;HOLD操作已完成(即完成一次DMA傳送)。清HOLD/INT1中斷標志防止再次進入HOLD方式。

            sacl imr ;恢復中斷屏蔽寄存器內(nèi)容。

              /針對全雙工會話功能的必要處理/

            int1_one_speech1:

            in temp0,dma_state_res ;讀8237與DMA狀態(tài)寄存器判斷是哪個通道的DMA,從而保證DMA采樣與回放交替進行。

            bit temp0,14

            bcnd unmask3,tc

            bit temp0,12

            bcnd unmask1,tc

            b skip_int1

            unmask3:

            splk #0007h,60h ;屏蔽采樣DMA。

            out 60h,000fh

            b skip_int1

            unmask1:

            splk #000dh,60h ;屏蔽回放 DMA 。

            out 60h,000fh

            skip_int1:

            clrc INTM

            ret

            DMA控制方式在DSP中的成功運用解決了系統(tǒng)中存儲器與外設之間數(shù)據(jù)傳送的速度問題,大大減輕了CPU的負擔,實現(xiàn)了DSP對聲卡DMA方式的錄音與回放、立體聲及全雙工操作,從而可以方便地實現(xiàn)全數(shù)字化語言學習系統(tǒng)的各項功能。


            上一頁 1 2 下一頁

            關(guān)鍵詞: DSP DMA TMS320F206

            評論


            相關(guān)推薦

            技術(shù)專區(qū)

            關(guān)閉