《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > ARM中基于DMA的高效UART通訊及其應(yīng)用
ARM中基于DMA的高效UART通訊及其應(yīng)用
摘要: 在UART通訊中,通過采取DMA方式,直接將UART接收的數(shù)據(jù)轉(zhuǎn)移到設(shè)定好的RAM區(qū),然后設(shè)置相應(yīng)的全局標(biāo)志,通知主程序數(shù)據(jù)可用就可以了。開發(fā)人員不需要到UART的緩沖區(qū)中讀取數(shù)據(jù),直接讀RAM就可以了。與采用中斷方式或者查詢方式的串行口通訊方式相比較,不僅僅可以節(jié)省CPU通訊時用于接收數(shù)據(jù)的時間,同時可以防止UART接收的數(shù)據(jù)由于沒有及時被讀取而丟失,提高了通訊的可靠性。
關(guān)鍵詞: ARM DMA控制器 UART
Abstract:
Key words :

 

1、引言

由于UART串行口的廣泛應(yīng)用,在傳統(tǒng)的8位和16位的處理器以及32位處理器中,一般都帶有UART串行口。傳統(tǒng)的基于UART的數(shù)據(jù)通訊中,采用的方式一般有兩種,查詢式和中斷式。查詢方式下CPU的負(fù)擔(dān)較重,浪費了處理器的能力,不能夠很好的處理其他的事件;中斷方式可以在接收到信息或需要發(fā)送數(shù)據(jù)時產(chǎn)生中斷,在中斷服務(wù)程序中完成數(shù)據(jù)的接收與發(fā)送。相對于查詢方式,中斷方式的CPU利用率要高。在CPU任務(wù)簡單的系統(tǒng)中,使用中斷方式確實是一種好方法。但是在復(fù)雜的系統(tǒng)中,比如移動機器人,處理器需要處理串行口通信,多個傳感器數(shù)據(jù)的采集以及處理,實時軌跡的生成,運動軌跡插補以及位置閉環(huán)控制等等任務(wù),牽扯到多個中斷的優(yōu)先級分配問題。為了保證數(shù)據(jù)發(fā)送與接收的可靠性,需要把UART的中斷優(yōu)先級設(shè)計較高,但是系統(tǒng)可能還有其他的需要更高優(yōu)先級的中斷,必須保證其定時的準(zhǔn)確,這樣就有可能造成串行通訊的中斷不能及時響應(yīng),從而造成數(shù)據(jù)丟失。為此,筆者在采用S3c44b0x設(shè)計移動機器人控制器時,為了保證串行通訊的數(shù)據(jù)及時可靠的接收,同時兼顧其它任務(wù)不受影響,采用了基于DMA和中斷方式相結(jié)合的UART串行通信方式。DMA是 Direct Memory Access的縮寫,意思是“存儲器直接訪問”,它是一種高速的數(shù)據(jù)傳輸操作,允許在外部設(shè)備和存儲器之間直接讀/寫數(shù)據(jù),即不通過CPU,也不需要 CPU干預(yù)。整個數(shù)據(jù)傳輸操作是在一個稱作DMA控制器的控制下進(jìn)行的。CPU除了在數(shù)據(jù)傳輸開始和結(jié)束時做一點處理外,在傳輸過程中可以進(jìn)行其他的工作。這樣,在大部分時間里,CPU和輸入/輸出設(shè)備都處于并行的操作狀態(tài)。其基本原理可以查閱教科書,此處不贅述。這里僅介紹S3c44c0x的DMA控制器。

2、S3c44b0x中的DMA控制器和UART的特性

S3c44b0x采用ARM7TDMI核,具有4 通道的DMA控制器,并且對應(yīng)有4個中斷。其中兩個DMA通道稱做ZDMA(通用DMA),連接在SSB(系統(tǒng)總線)上,另外兩個DMA通道稱做 BDMA(橋DMA),連接于SSB和SPB(外設(shè)總線)之間的接口層。連接于SSB上的ZDMA控制器可以用于從存儲器到存儲器,從存儲器到固定目標(biāo)的 I/O存儲器,和從I/O 設(shè)備到存儲器之間的數(shù)據(jù)傳輸。另外的兩個BDMA 控制器主要作用是在外部存儲器和內(nèi)部外設(shè)之間傳輸數(shù)據(jù),這里的I內(nèi)部外設(shè)包括SIO,IIS,TIMER和UART等。BDMA與ZDMA可以通過軟件啟動,也可以通過硬件啟動。此設(shè)計中我們使用UART0,與其對應(yīng)的DMA通道為BDMA0。其控制器框圖如圖1所示。

S3c44b0x的UART單元提供2個獨立的異步串行I/O口,每個口均可以工作于中斷模式或者DMA模式,即 UART可以產(chǎn)生內(nèi)部中斷請求或者DMA請求,在CPU的串行I/O口之間傳送數(shù)據(jù),支持高達(dá)115.2KBPS的傳輸速率,每個UART通道包含2個 16位的分別用于發(fā)送和接收的FIFO通道。

6.jpg

3、硬件電路設(shè)計

由于S3c44b0x自帶支持UART的DMA控制器,所以關(guān)于DMA硬件部分不需要作任何的工作。S3C44B0X的I/O口電壓為3.3V,而PC機一端的串口采用RS232電平,所以中間要經(jīng)過電平轉(zhuǎn)換,在此采用SP3232E芯片。連接電路如圖2所示。    

 

7.jpg

4、基于DMA和中斷相結(jié)合的通訊軟件設(shè)計

在以S3C44B0X為核心組成的移動機器人中,采用3路PWM定時器驅(qū)動3個直流電機,通用的GPIO口和A/D口連接外部的紅外和超聲以及激光傳感器,使用UART0完成與上位機(PC)的數(shù)據(jù)交換,這些數(shù)據(jù)是單向的(從上位機發(fā)送給S3c44b0x),主要是上位機傳給機器人控制器的各種命令信息,但是命令信息的發(fā)送時間上是不具有規(guī)律性的,即間隔時間不定。為了充分的利用CPU,減少數(shù)據(jù)丟失的風(fēng)險,我們利用UART的DMA模式來完成數(shù)據(jù)的接收。軟件部分主要是針對具體的應(yīng)用,對DMA控制器以及UART作適當(dāng)?shù)某跏蓟ART的初始化比較簡單,主要是通訊數(shù)據(jù)格式、波特率等的設(shè)置,這些與其他控制器相同,只要設(shè)置相關(guān)的寄存器即可。注意UART設(shè)置成不使用自動流控制,不使用紅外線傳輸模式,關(guān)鍵要注意UART0設(shè)置成DMA模式而不是中斷模式,并且要使能FIFO緩沖區(qū)(根據(jù)需要,使用16字節(jié)的接收緩沖區(qū)),這樣在接收緩沖區(qū)滿時,會產(chǎn)生DMA請求而不是中斷請求。限于篇幅,具體的寄存器定義以及串行口的初始化不做詳悉介紹,可以參考文獻(xiàn)[1][2]。

DMA控制器的初始化也比較簡單,主要是相關(guān)寄存器的設(shè)置。與BDMA0相關(guān)的在本系統(tǒng)中用到的寄存器以及相關(guān)定義見表1,具體寄存器的名稱定義以及物理地址見參考文獻(xiàn)[1][2]。

表1  S3c44b0x的BDMA相關(guān)寄存器的定義
4.jpg
 
在初始化時要正確設(shè)置目標(biāo)(緩沖區(qū)的)首地址、數(shù)據(jù)傳輸?shù)姆较颉⒃醇拇嫫鞯氖椎刂贰⒌刂分羔樖欠襁f增以及遞增方向、DMA計數(shù)器等等。相關(guān)代碼以及注釋如下:
#define  RAM_ADDRESS  0xc200000  //定義接收數(shù)據(jù)的緩沖區(qū),根據(jù)硬件而定。在我們的系統(tǒng)中擴展的SDRAM 存儲空間從0x0C00000~0x0C7fffff,占用S3c44b0x的bank 6。
#define  size  16  //定義DMA的計數(shù)器,根據(jù)需要設(shè)定,可以選擇的選項是4、8、2和16
char *Buf;
Buf=(unsigned char*) RAM_ADDRESS;  //指針指向起始地址
BDISRC0=(11<<28)+(int)(rURxH0);    /*以字節(jié)為單位傳送;因為DMA操作時是將UART的寄存器中的數(shù)據(jù)讀出放置到設(shè)定的緩沖區(qū),所以源寄存器的地址應(yīng)該是固定到;UART的接收保存寄存器rURxH0,同時位[29:28]應(yīng)該設(shè)置成 0b11。*/
BDIDES0=(10<<30)+(01<<28)+ Buf); /*傳輸方向模式設(shè)定為從內(nèi)部設(shè)備(UART口)到外部存儲器(SDRAM),目標(biāo)存儲器(SDRAM)使用地址遞增的方向,將數(shù)據(jù)順次放置到緩沖區(qū)中*/
BDICNT0=(10<<30)+(1<<26)+(3<<22)+(1<<21)+(0& lt;<20)+size;/*設(shè)置UART0使用BDMA0通道,在DMA計數(shù)到0時自動重載和自動啟動,計數(shù)結(jié)束產(chǎn)生中斷,每次DMA操作移動 16字節(jié)數(shù)據(jù)到設(shè)定地緩沖區(qū)*/
BDICNT0 |= (1<<20);//使能DMA
BDCON0 = 0x0<<2;//允許外部DMA請求

數(shù)據(jù)接收:這一部分工作由初始化好后的DMA控制器依靠硬件來完成。接收數(shù)據(jù)不定時,初始化UART0的接收緩沖區(qū)為16字節(jié),當(dāng)接收緩沖區(qū)滿時,會產(chǎn)生DMA請求,然后在DMA控制器的控制下,將UART的接收FIFO中的16字節(jié)的數(shù)據(jù)轉(zhuǎn)移到指定的緩沖區(qū)中(SRAM),當(dāng)數(shù)據(jù)轉(zhuǎn)移完畢(DMA 計數(shù)到0)后,要做兩件事情:一是自動重載和自動啟動,即自動重新設(shè)置好目標(biāo)(緩沖區(qū))首地址和源地址(UART接收寄存器)以及DMA計數(shù)器,準(zhǔn)備好下次DMA請求;另外產(chǎn)生DMA中斷。DMA中斷服務(wù)程序要做的工作很簡單,只要對全局標(biāo)志RECEIVE_FLAG置位,通知主程序有新的命令需要處理。這樣主程序可以直接處理RAM中的數(shù)據(jù),而不需要花費時間去讀取UART的接收緩沖區(qū)。                                 

數(shù)據(jù)處理:當(dāng)主程序通過查詢?nèi)謽?biāo)志RECEIVE_FLAG,如果為1,則知道有新的命令,可以直接讀取命令緩沖區(qū),同時對RECEIVE_FLAG清零。然后按照一定的算法對接收的數(shù)據(jù)做出解析,這部分內(nèi)容不做重點討論。

5、試驗及結(jié)論                

為了驗證基于DMA的通訊的有效性,筆者做了對比試驗。把負(fù)責(zé)軌跡插補的定時中斷優(yōu)先級設(shè)計成最高(中斷時間間隔50毫秒,中斷服務(wù)程序執(zhí)行時間約需要30毫秒),然后一個機器人采用中斷方式接收上位機連續(xù)發(fā)送的100組命令,另一個采用基于DMA的方式接收上位機連續(xù)發(fā)送的100組命令。然后在機器人主程序中通過讀取UART的狀態(tài)寄存器判斷出現(xiàn)錯誤(主要是數(shù)據(jù)溢出錯誤,即緩沖區(qū)有接收數(shù)據(jù)而沒有及時讀取,被新的數(shù)據(jù)覆蓋)的次數(shù)。軟件采用C語言,用ADS1.2編譯調(diào)試。試驗結(jié)果如表2。實驗證明了第二種方式的有效性。

表2:對比試驗結(jié)果
5.jpg

本文作者的創(chuàng)新點在于:在UART通訊中,通過采取DMA方式,直接將UART接收的數(shù)據(jù)轉(zhuǎn)移到設(shè)定好的RAM區(qū),然后設(shè)置相應(yīng)的全局標(biāo)志,通知主程序數(shù)據(jù)可用就可以了。開發(fā)人員不需要到UART的緩沖區(qū)中讀取數(shù)據(jù),直接讀RAM就可以了。與采用中斷方式或者查詢方式的串行口通訊方式相比較,不僅僅可以節(jié)省CPU通訊時用于接收數(shù)據(jù)的時間,同時可以防止UART接收的數(shù)據(jù)由于沒有及時被讀取而丟失,提高了通訊的可靠性。

參考文獻(xiàn):
(1)嵌入式系統(tǒng)開發(fā)與應(yīng)用,田澤編著,北京航空航天大學(xué)出版社,2005年5月第一版;
(2)S3C44B0X RISC MICROPROCESSOR ,SAMSUNG ElECTRONICS
(3)ARM微控制器基礎(chǔ)與實戰(zhàn),周立功等編著,北京航空航天大學(xué)出版社,2003年11月第1版.
(4) 魏永清 萬寶年,具有軟件模擬FIFO緩沖區(qū)的串口通信模塊設(shè)計,微計算機信息 2006年第7-2期:64-66 

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
国产字幕视频一区二区| 亚洲精品视频一区| 欧美久久视频| 欧美国产日韩精品免费观看| 久久嫩草精品久久久久| 欧美在线短视频| 午夜视频久久久| 亚洲男女自偷自拍| 亚洲影院在线| 亚洲一区不卡| 亚洲一区二区三区四区五区黄 | 国产精品xnxxcom| 欧美日韩国产精品一区| 欧美人与性动交a欧美精品| 欧美成人激情视频免费观看| 美女国内精品自产拍在线播放| 久久躁日日躁aaaaxxxx| 久久五月激情| 免费在线一区二区| 欧美国产日韩在线| 欧美精品一区二区三区一线天视频 | 欧美一区91| 欧美在线播放视频| 久久久青草婷婷精品综合日韩| 久久久久久久成人| 可以看av的网站久久看| 蜜臀av性久久久久蜜臀aⅴ四虎| 美女精品网站| 欧美精品一区二区三| 欧美视频在线不卡| 国产精品网站在线播放| 国产一区二区在线观看免费播放| 国产综合色在线| 亚洲国产精品国自产拍av秋霞| 亚洲精品影院在线观看| 99视频超级精品| 亚洲欧美一区二区在线观看| 久久都是精品| 亚洲三级国产| 亚洲午夜视频在线| 久久国产成人| 欧美搞黄网站| 国产精品vvv| 韩国v欧美v日本v亚洲v| 91久久精品国产91性色| 中文亚洲字幕| 欧美在线高清| 99精品热6080yy久久 | 亚洲欧美日韩综合| 久久久久国色av免费看影院| 欧美成人激情在线| 国产精品国产| 在线观看亚洲一区| 一区二区三区鲁丝不卡| 欧美影片第一页| av72成人在线| 久久精品观看| 欧美日韩精品一区二区三区四区| 国产欧美亚洲精品| 91久久亚洲| 亚洲欧美成人精品| 亚洲精品日韩一| 性欧美精品高清| 欧美国内亚洲| 国产精品永久在线| 亚洲国产精品日韩| 午夜在线播放视频欧美| 亚洲精品一线二线三线无人区| 亚洲中字在线| 欧美成人免费大片| 国产日韩欧美制服另类| 亚洲精美视频| 欧美一区二区观看视频| 一区二区三区回区在观看免费视频| 欧美在线视频网站| 欧美日韩免费高清| 狠狠色综合日日| 亚洲一区二区三区视频播放| 91久久久久| 久久国产欧美| 国产精品高潮呻吟| 91久久在线播放| 久久成人综合网| 午夜精品电影| 欧美片在线观看| 一区二区在线视频| 午夜精品视频在线观看| 亚洲视频axxx| 欧美国产视频日韩| 黄色欧美日韩| 亚洲欧美一区二区三区在线| 亚洲手机在线| 欧美激情视频网站| 一区视频在线看| 欧美一区国产二区| 性欧美大战久久久久久久免费观看 | 亚洲另类自拍| 亚洲精品乱码久久久久久黑人 | 国产精品欧美久久| aa国产精品| 99亚洲一区二区| 免费成人网www| 一区二区三区在线免费观看| 欧美一区2区三区4区公司二百 | 久久国产视频网站| 国产精品久久久久久久久久三级 | 麻豆精品视频在线观看视频| 国产日韩欧美精品| 亚洲一区二区在线观看视频| 正在播放亚洲一区| 欧美精品自拍| 亚洲精品国产无天堂网2021| 亚洲日本精品国产第一区| 久久久天天操| 韩日成人av| 亚洲高清一区二| 久久资源在线| 激情视频一区二区| 久久xxxx| 久久综合伊人77777麻豆| 韩国久久久久| 亚洲第一黄网| 理论片一区二区在线| 影音先锋久久资源网| 亚洲精品国产精品国自产观看浪潮| 美国十次成人| 欧美日韩一区二区免费在线观看 | 久久久国产一区二区| 欧美在线精品一区| 亚洲一区亚洲| 亚洲性图久久| 欧美日韩中文精品| 亚洲精品一二三区| 在线综合亚洲欧美在线视频| 欧美伦理在线观看| 国产专区综合网| 一本色道久久综合精品竹菊| 麻豆精品网站| 亚洲激情偷拍| 亚洲手机成人高清视频| 国产精品爱久久久久久久| 亚洲视频在线观看三级| 亚洲欧美国产毛片在线| 国产欧美精品在线观看| 欧美一区二视频| 免费不卡视频| 亚洲精品日韩综合观看成人91| 一本大道久久a久久精二百| 欧美日韩免费高清一区色橹橹| 亚洲少妇诱惑| 欧美主播一区二区三区| 在线免费观看视频一区| 一本一道久久综合狠狠老精东影业 | 一区二区三区在线高清| 亚洲美女av在线播放| 欧美三级乱码| 香蕉成人久久| 欧美高清在线一区| 亚洲视频图片小说| 久久久精品国产99久久精品芒果| 在线看一区二区| 亚洲一区亚洲二区| 国语自产精品视频在线看一大j8 | 久久国产精品99精品国产| 欧美激情无毛| 亚洲永久免费视频| 久色婷婷小香蕉久久| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲一区二区在线免费观看| 国产亚洲欧美日韩在线一区| 亚洲狼人综合| 国产精品系列在线播放| 亚洲欧洲精品一区二区| 国产精品久久久久久久午夜片 | 国产精品欧美一区二区三区奶水| 欧美在线不卡视频| 欧美日韩国产成人在线91| 性久久久久久久| 欧美福利精品| 亚洲欧美成人在线| 欧美激情一区二区三区四区 | 久久岛国电影| 欧美体内she精视频| 久久黄色影院| 欧美先锋影音| 亚洲精品1区2区| 国产精品手机在线| 亚洲人体1000| 国产日韩欧美日韩大片| 亚洲免费电影在线观看| 国产欧美日韩视频在线观看 | 国产精品盗摄久久久| 亚洲国产欧美一区二区三区久久| 国产精品久久久久久久久久三级| 亚洲欧洲视频在线| 国产情侣久久| 亚洲性图久久| 亚洲黄页一区| 久久亚洲欧美| 亚洲欧美国产日韩中文字幕|