新聞中心

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

        基于DSP的DMA控制技術

        作者: 時間:2009-03-26 來源:網絡 收藏

        可見,當8237-5任一通道的DREQ被置為有效電平且相應通道的屏蔽位被清除時,就使HRQ信號變?yōu)楦唠娖?從而使的/HOLD變低,表示有外部設備請求對外部總線的。隨即發(fā)出/HOLDA來響應/HOLD,8237-5的HLDA變高,取得總線權,并產生相應的響應信號DACK以通知外設。完成周期后,總線又回到正常狀態(tài)。

        4 軟件編程

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

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

        4.1 8237-5的初始化

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

        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 聲卡初始化中的相關設置

          聲卡一般默認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操作有關的寄存器:I14、I15、I30、I31。I14、I15用于設定DMA回放的計數基值,I30、I31則用于設定DMA采樣的計數基值。它可以產生一個中斷以方便用戶做相應處理。

        4.3 DSP的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 ;恢復中斷屏蔽寄存器內容。

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

        int1_one_speech1:

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



        評論


        相關推薦

        技術專區(qū)

        關閉
        主站蜘蛛池模板: 汕尾市| 鹰潭市| 大洼县| 沧源| 高州市| 正宁县| 门头沟区| 无棣县| 河源市| 宿州市| 宁武县| 新源县| 绵竹市| 长丰县| 翼城县| 乌恰县| 东兰县| 兰坪| 宁安市| 墨江| 尤溪县| 博白县| 富川| 沈阳市| 夹江县| 横山县| 新闻| 长汀县| 遂川县| 怀化市| 荣昌县| 德昌县| 开远市| 江口县| 都江堰市| 中山市| 自贡市| 鄱阳县| 太仓市| 阿坝| 波密县|