《電子技術應用》
您所在的位置:首頁 > 嵌入式技術 > 業界動態 > 基于DSP的DMA控制技術

基于DSP的DMA控制技術

2009-03-13
作者:淳 靜 張 王已 劉國福 羅

  摘? 要: 通過分析TMS320C2XX使用保持(HOLD)操作的直接存儲器訪問(DMA)和DMA控制器8237-5的工作原理,解決了DSP與8237-5的軟、硬件接口問題,實現了DMA在數字化語言學習系統中的應用。?

  關鍵詞: DMA? DSP? HOLD操作?

?

  TMS320C2XX是美國TI公司推出的一種低價格、高性能的16位定點運算數字信號處理器(DSP),它的性價比極高,目前已成為高檔單片機的理想替代品,在通信、語音處理、軍事、儀器儀表、圖像處理等領域得到了廣泛的應用。在以TMS320C2XX為核心的數字化語言學習系統中,為了滿足系統的實時性要求,并且提高系統的音質和負載能力,聲卡與存儲器之間的數據傳送已經不能采用程序查詢控制方式,因此我們考慮采用直接存儲器訪問(DMA)控制。直接存儲器訪問控制是指數據傳送時不需要CPU的介入,I/O設備和存儲器直接交換信息。DMA方式的數據傳送與程序查詢方式的數據傳送相比,具有數據傳送速度高、I/O響應時間短、CPU額外開銷小的明顯優點。本文根據課題需要,通過分析TMS320C2XX使用保持(HOLD)操作的直接存儲器訪問(DMA)和DMA控制器8237-5的工作原理,解決了DSP芯片TMS320F206與DMA控制器8237-5的軟、硬件接口問題,實現了DMA在數字化語言學習系統中的應用。?

1 TMS320C2XX使用HOLD操作的直接存儲器訪問?

  TMS320C2XX的HOLD操作允許對外部程序、數據以及I/O空間進行直接存儲器訪問。該過程由/HOLD和/HOLDA兩個信號控制。?

  (1)/HOLD。外部設備可以把該引腳驅動到低電平從而請求對外部總線的控制。如果HOLD/INT1中斷線被允許,那么將觸發中斷。?

  (2)/HOLDA。在響應/HOLD中斷時,軟件邏輯可以使處理器發出/HOLD應答信號,表示它將放棄對其外部總線的控制。根據/HOLDA,外部地址信號(A15~A0)、數據信號(D15~D0)以及存儲器控制信號(/PS,/DS,/BR,/STRB,R/W,/RD,/WE)被置為高阻狀態。?

  在我們的設計中,HOLD/INT1中斷服務子程序只用于HOLD操作以便控制DMA傳送,因此DSP的中斷控制寄存器(ICR)中的方式(MODE)位置為0。此時,中斷線INT1對下降沿和上升沿二者都敏感。當CPU檢測到下降沿時,它完成正在執行的當前指令,然后迫使程序控制轉到中斷服務子程序。在成功的測試到MODE=0之后,此子程序執行IDLE(空閑)指令。根據IDLE,/HOLDA變為有效而外部總線被置為高阻狀態。只有在檢測到HOLD/INT1引腳上的上升沿之后,CPU才退出IDLE狀態,/HOLDA變為無效,并使外部總線返回到正常狀態。?

  HOLD操作的子程序將在本文最后結合具體示例中給出,應該注意的是:IDLE指令應當放在中斷服務子程序內以便發出/HOLDA。同時要注意的是:中斷程序代碼禁止除HOLD/INT1之外的所有可屏蔽中斷,從而允許/HOLDA和總線的安全恢復。?

2 DMA控制器8237-5的工作原理?

  8237-5是一個高性能的40引腳雙列直插式可編程DMA控制器芯片,可以方便地與DSP微處理器相連,實現外部設備與存儲器之間的數據交換。其內部結構和引腳信號可參閱參考文獻[2]。該控制器通過編程可提供多種類型的控制特性,以優化系統性能,增大數據吞吐量,最高數據傳輸速率可達1.5MB/S。?

  DMA控制器實現DMA傳送的控制原理可用圖1的信息流示意圖表示?,F結合該圖將DMA控制原理操作順序說明如下:?

?

?

 ?、買/O設備準備好后,向DMA控制器(DMAC)發出DMA請求信號DMARQ。?

 ?、贒MAC向CPU發出總線請求信號BUSRQ。?

 ?、郯凑疹A定的DMAC占用總線方式,CPU響應BUSRQ,向DMAC發出總線確認信號BUSAK。從這時起,CPU總線控制權交由DMAC接管,開始進入DMA有效周期,如圖1中陰影部分所示。?

 ?、蹹MAC接管總線后,先向I/O設備發出DMA請求的響應信號DACK,表示允許外設進行DMA傳送。然后按事先設置的初始地址和需傳送的字節數,依次發送地址和讀寫命令,使RAM和I/O設備直接交換數據,直至全部數據交換完畢。?

  ⑤DMA傳送結束后,自動撤消向CPU的總線請求信號BUSRQ,從而使BUSAK和DACK相繼變為無效,CPU又重新控制總線,恢復正常工作。?

3 DSP與DMA控制器8237-5的接口電路?

  通過上述分析可以知道,DSP與8237-5的接口關鍵是要解決DSP的/HOLD、/HOLDA信號與8237-5的總線保持請求輸出信號HRQ(即BUSRQ)、總線保持響應輸入信號HLDA(即BUSAK)之間的聯系問題。圖2給出DSP與8237-5的接口電路。

?

?

  (1)數據線、地址線可以直接相連,8237-5僅使用8根數據線和地址線。?

  (2)由于8237-5要向DSP申請對外部總線的控制,所以DSP的/HOLD信號決定于HRQ,而二者的有效電平正好是反相關系;另一方面,當DSP在合適程序代碼的協助下使/HOLDA有效,從而對/HOLD有效作出響應時,它就應該通知DMAC可以獲得總線控制權,那么可以將/HOLDA反相后發給8237-5的HLDA,從而使得該信號變高成為有效,8237-5得以接管總線。因此HLDA、/HOLD信號線的譯碼邏輯關系如下:?

  HLDA=/HOLDA?

  /HOLD=HRQ?

  一次DMA操作的時序關系如圖3所示。?

?

?

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

4 軟件編程?

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

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

4.1 8237-5的初始化?

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

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

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

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

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

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

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

4.2 聲卡初始化中的相關設置?

  聲卡一般默認DMA0=1為回放通道、DMA1=3為采樣通道,這在其PNP初始化中規定。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操作。發出/HOLDA,外部總線被置為高阻狀態,等待HOLD/INT1引腳上的上升沿。?

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

??????? sacl??? ? imr?????? ;恢復中斷屏蔽寄存器內容。?? ?

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

int1_one_speech1:?

??????? in???? temp0,dma_state_res ;讀8237與DMA狀態寄存器判斷是哪個通道的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中的成功運用解決了系統中存儲器與外設之間數據傳送的速度問題,大大減輕了CPU的負擔,實現了DSP對聲卡DMA方式的錄音與回放、立體聲及全雙工操作,從而可以方便地實現全數字化語言學習系統的各項功能。?

參考文獻?

1 TMS320C2XX數字信號處理器用戶指南.武漢力源電子股份有限公司,1998?

2 鄒逢興.微型計算機硬件技術及應用基礎.長沙:國防科技大學出版社,1997
本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          国产精品揄拍500视频| 欧美亚洲网站| 国产日韩欧美综合| 欧美色欧美亚洲另类七区| 国产欧美日韩视频一区二区三区| 久久精品国产免费观看| 久热精品视频在线观看一区| 亚洲国产高清视频| 91久久久久久久久久久久久| 国产亚洲人成a一在线v站| 欧美高清在线精品一区| 亚洲永久免费视频| 亚洲视频一起| 欧美freesex8一10精品| 日韩亚洲欧美在线观看| 欧美成人精品高清在线播放| 麻豆91精品91久久久的内涵| 在线视频日韩精品| 欧美日韩激情小视频| 99一区二区| 欧美午夜精品久久久久久孕妇| 9l国产精品久久久久麻豆| 欧美精品一区二区高清在线观看| 欧美国产一区二区三区激情无套| 国产欧美日韩综合一区在线播放| 亚洲综合999| 欧美在线免费看| 亚洲手机在线| 亚洲综合精品四区| 日韩亚洲国产欧美| 欧美人与性动交α欧美精品济南到| 久久久久欧美| 国产精品盗摄久久久| 狠狠综合久久av一区二区老牛| 亚洲韩国日本中文字幕| 国产一区二区三区四区老人| 亚洲欧美综合国产精品一区| 欧美午夜激情小视频| 欧美在线精品一区| 亚洲国产综合91精品麻豆| 亚洲电影专区| 久久手机精品视频| 亚洲美女福利视频网站| aaa亚洲精品一二三区| 国产精品第13页| 在线观看视频一区| 亚洲欧洲在线观看| 在线观看视频亚洲| 国产精品成人va在线观看| 精品av久久久久电影| 欧美激情中文不卡| 国产乱子伦一区二区三区国色天香| 日韩一级黄色片| 欧美精品在线视频观看| 亚洲在线免费视频| 亚洲精品久久嫩草网站秘色| 亚洲电影激情视频网站| 欧美一级淫片aaaaaaa视频| 影音先锋久久资源网| 欧美精品成人| 久久精品中文字幕一区| 日韩午夜av电影| 国产精品盗摄一区二区三区| 欧美日韩另类国产亚洲欧美一级| 在线精品一区二区| 久久国产视频网站| 久久国产精品久久w女人spa| 亚洲精品社区| 欧美一区二区三区啪啪| 中日韩高清电影网| 国产精品一级二级三级| 国产亚洲精品久久久久久| 欧美日韩高清免费| 夜夜爽www精品| 国产一区二区三区电影在线观看| 日韩一级大片在线| 好吊一区二区三区| 欧美三日本三级三级在线播放| 欧美日韩亚洲一区二区| 久久精品视频在线看| 久久久久免费观看| 性欧美1819sex性高清| 久久亚洲综合| 国精品一区二区三区| 欧美小视频在线观看| 亚洲国产精品久久久久秋霞不卡| 激情欧美日韩| 久久精品日产第一区二区三区| 亚洲视频在线二区| 国产精品国产三级国产| 久久精品国产v日韩v亚洲| 亚洲欧洲精品一区二区| 国产日产亚洲精品系列| 欧美在线播放一区二区| 久久精品99国产精品| 久久日韩粉嫩一区二区三区| 国产精品日韩欧美大师| 亚洲精品视频免费在线观看| 免费h精品视频在线播放| 国产日韩欧美精品在线| 欧美一区二区免费视频| 久热爱精品视频线路一| 香港久久久电影| 在线观看视频免费一区二区三区| 狠狠色丁香久久婷婷综合丁香| 欧美日韩伦理在线免费| 久久精品日韩一区二区三区| 国产精品海角社区在线观看| 最新国产成人av网站网址麻豆| 国产午夜精品麻豆| 亚洲一区二区三区涩| 欧美精品v国产精品v日韩精品| 另类图片国产| 国产欧美一区二区三区视频| 午夜精彩国产免费不卡不顿大片| 国产欧美日韩精品a在线观看| 亚洲大片在线| 一级日韩一区在线观看| 国自产拍偷拍福利精品免费一| 亚洲欧美在线视频观看| 欧美日韩久久| 亚洲一区黄色| 亚洲激情成人| 午夜日韩激情| 欧美日韩国产二区| 亚洲综合首页| 久久久久久久久一区二区| 亚洲欧美日韩一区| 伊人久久婷婷| 欧美sm极限捆绑bd| 欧美日本在线一区| 国产精品视频专区| 欧美视频免费看| 午夜精品久久久久久久男人的天堂| 亚洲色无码播放| 欧美一级二区| 亚洲国产精品精华液网站| 久久久噜噜噜久久久| 欧美国产日韩一区二区三区| 欧美一级久久久久久久大片| 国产精品爱久久久久久久| 国产精品高清一区二区三区| 9国产精品视频| 久久视频国产精品免费视频在线| 91久久嫩草影院一区二区| 亚洲经典一区| 欧美日韩一区二区三| 国产一区二区三区电影在线观看| 国产精品激情av在线播放| 国产精品丝袜91| 欧美aaaaaaaa牛牛影院| 欧美激情一区二区三区在线| 美女图片一区二区| 亚洲精品女av网站| 亚洲一区在线免费观看| 中文精品视频一区二区在线观看| 欧美在线啊v一区| 久久亚洲国产精品日日av夜夜| 在线免费观看视频一区| 美女脱光内衣内裤视频久久影院| 欧美一级夜夜爽| 日韩天堂在线观看| 性欧美1819sex性高清| 欧美日韩国产亚洲一区| 亚洲欧洲精品一区二区三区波多野1战4| 香港成人在线视频| 亚洲精品视频免费| 亚洲二区在线视频| 日韩视频永久免费观看| 国产麻豆午夜三级精品| 欧美a级片网站| 欧美电影免费观看大全| 久久亚洲综合色| 一本色道久久加勒比88综合| 亚洲欧美影院| 久久久高清一区二区三区| 国产视频欧美| 在线精品亚洲| 国产精品影视天天线| 久久在线视频| 欧美日韩国产综合在线| 亚洲欧美视频在线观看| 国产精品美女久久久浪潮软件| 奶水喷射视频一区| 国产精品福利久久久| 国产精品久久久久久久久免费桃花| 韩国av一区二区三区在线观看| 国产精品自拍小视频| 亚洲一区二区三区免费在线观看| 亚洲免费观看| 亚洲日本无吗高清不卡| 亚洲欧美日韩一区二区三区在线| 国产亚洲欧美一区| 一区免费在线| 国产亚洲一本大道中文在线| 国产视频在线观看一区| 91久久精品www人人做人人爽| 国产亚洲精久久久久久| 亚洲欧美三级伦理| 欧美日韩亚洲天堂| 国产乱码精品一区二区三区五月婷| 亚洲国产成人久久综合| 欧美在线中文字幕| 欧美有码在线视频| 亚洲一区3d动漫同人无遮挡| 久久精品一二三区| 香蕉免费一区二区三区在线观看| 最近中文字幕日韩精品| 欧美日韩免费在线观看| 午夜欧美理论片| 国产精品chinese| 日韩午夜精品| 欧美成年人视频网站| 久久精品在线| 亚洲免费人成在线视频观看| 一区二区三区导航| 老司机精品福利视频| 久久精品道一区二区三区| 欧美视频在线观看免费网址| 美国成人毛片| 国产女主播在线一区二区| 国产日产高清欧美一区二区三区| 久久久久九九九| 国产日韩欧美二区| 欧美婷婷六月丁香综合色| 欧美黄色小视频| 日韩亚洲不卡在线| 欧美日韩另类丝袜其他| 欧美精品久久久久久久久老牛影院| 欧美日韩国产美女| 欧美色视频日本高清在线观看| 亚洲一区三区视频在线观看| 亚洲国产精品久久人人爱蜜臀| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美色综合网| 欧美激情一区二区三区在线视频| 欧美日韩亚洲高清一区二区| 激情综合电影网| 国产在线一区二区三区四区| 免费在线成人| 国产日韩欧美一区二区三区四区| 欧美久久精品午夜青青大伊人| 欧美激情一二三区| 国产精品美女久久久久久久| 欧美电影在线免费观看网站| 国产无遮挡一区二区三区毛片日本| 亚洲夜间福利| 亚洲免费观看高清完整版在线观看熊| 欧美第一黄网免费网站| 久久视频精品在线| 亚洲精品中文字幕女同| 欧美日韩成人网| 在线日本欧美| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲国产黄色| 欧美大片在线观看| 羞羞答答国产精品www一本| 欧美在线关看| 国产精品视频一| 久久精品观看| 久久久青草青青国产亚洲免观| 亚洲毛片一区| 国产精品99免费看| 国产精品素人视频| 国产亚洲亚洲| 国产日韩av高清| 欧美成人亚洲成人日韩成人| 国产精品麻豆成人av电影艾秋| 欧美激情va永久在线播放| 久久人人爽人人爽爽久久| 黄色成人免费观看| 裸体女人亚洲精品一区| 亚洲香蕉网站| 一区二区激情视频| 亚洲一区二区三区午夜| 国产美女搞久久| 欧美视频免费在线观看| 亚洲电影自拍| 欧美三级视频在线播放| 欧美在线国产| 久久国产精品久久久久久电车| 欧美日韩一区高清| 99视频国产精品免费观看| 日韩视频在线一区二区三区| 在线播放视频一区| 国产一区 二区 三区一级| 欧美99久久| 国产伦精品一区二区三区免费| 欧美日韩精品一区视频| 亚洲国产另类 国产精品国产免费| 久久精品女人天堂| av不卡在线观看| 美女久久一区| 久久精品日产第一区二区| 国产精品高潮呻吟久久av无限| 美女黄网久久| 亚洲综合精品自拍| 久久久久久自在自线| 亚洲欧洲日韩综合二区| 激情视频一区二区| 亚洲国产精品一区二区第一页| 亚洲精品影视| 亚洲一区二区精品| 中日韩男男gay无套| 欧美日本在线视频| 影音先锋久久| 久久亚洲美女| 黄色资源网久久资源365| 国产一区二区精品在线观看| 国产精品久久久久久福利一牛影视| 国产欧美在线观看| 免费成人高清视频| 欧美精品日韩一区| 激情国产一区| 欧美日韩免费在线| 欧美96在线丨欧| 欧美日韩美女| 亚洲午夜av电影| 亚洲欧美激情视频在线观看一区二区三区| 亚洲国产精品一区二区久| 亚洲国产精品久久久久秋霞不卡| 亚洲二区精品| 亚洲男人的天堂在线aⅴ视频| 欧美日韩国产在线观看| 亚洲国产岛国毛片在线| 99精品欧美一区二区三区综合在线| 亚洲欧洲日产国码二区| 国产欧美亚洲日本|