當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導讀]1.使用范圍:DMA(直接存儲器存取)提供在外設與存儲器之間或者存儲器和存儲器之間的高速數(shù)據(jù)傳輸使用。注意這里的外設指的是32的外設,比如spi、usart、iic、adc等基于APB1

1.使用范圍:

DMA(直接存儲器存取)提供在外設與存儲器之間或者存儲器和存儲器之間的高速數(shù)據(jù)傳輸使用。注意這里的外設指的是32的外設,比如spi、usart、iic、adc等基于APB1 、APB2或AHB時鐘的外設,而這里的存儲器包括32自身的閃存(flash)或者內存(SRAM)以及外設的存儲設備都可以作為訪問的源或者目的。注意外部存儲設備其自身在這就是外設了,配置時屬于外設,不要與配置寄存器的存儲設備混淆

2.以目前嵌入式為例,DMA和CPU兩者怎么實現(xiàn)分時使用內存:

通常采用以下三種方法:

(1)停止CPU訪內存;

(2)周期挪用;

(3)DMA與CPU交替訪問內存。

停止CPU訪問內存

當外圍設備要求傳送一批數(shù)據(jù)時,由DMA控制器發(fā)一個停止信號給CPU,要求CPU放棄對地址總線、數(shù)據(jù)總線和有關控制總線的使用權.DMA控制器獲得總線控制權以后,開始進行數(shù)據(jù)傳送.在一批數(shù)據(jù)傳送完畢后,DMA控制器通知CPU可以使用內存,并把總線控制權交還給CPU.圖(a)是這種傳送方式的時間圖.很顯然,在這種DMA傳送過程中,CPU基本處于不工作狀態(tài)或者說保持狀態(tài)。

 

優(yōu)點: 控制簡單,它適用于數(shù)據(jù)傳輸率很高的設備進行成組傳送。

缺點: 在DMA控制器訪內階段,內存的效能沒有充分發(fā)揮,相當一部分內存工作周期是空閑的。這是因為,外圍設備傳送兩個數(shù)據(jù)之間的間隔一般總是大于內存存儲周期,即使高速I/O設備也是如此。例如,軟盤讀出一個8位二進制數(shù)大約需要32us,而半導體內存的存儲周期小于0.5us,因此許多空閑的存儲周期不能被CPU利用。

周期挪用

當I/O設備沒有DMA請求時,CPU按程序要求訪問內存;一旦I/O設備有DMA請求,則由I/O設備挪用一個或幾個內存周期。

這種傳送方式的時間圖如下圖(b):

 

I/O設備要求DMA傳送時可能遇到兩種情況:

(1)此時CPU不需要訪內,如CPU正在執(zhí)行乘法指令。由于乘法指令執(zhí)行時間較長,此時I/O訪內與CPU訪內沒有沖突,即I/O設備挪用一二個內存周期對CPU執(zhí)行程序沒有任何影響。

(2)I/O設備要求訪內時CPU也要求訪內,這就產(chǎn)生了訪內沖突,在這種情況下I/O設備訪內優(yōu)先,因為I/O訪內有時間要求,前一個I/O數(shù)據(jù)必須在下一個訪問請求到來之前存取完畢。顯然,在這種情況下I/O 設備挪用一二個內存周期,意味著CPU延緩了對指令的執(zhí)行,或者更明確地說,在CPU執(zhí)行訪內指令的過程中插入DMA請求,挪用了一二個內存周期。與停止CPU訪內的DMA方法比較,周期挪用的方法既實現(xiàn)了I/O傳送,又較好地發(fā)揮了內存和CPU的效率,是一種廣泛采用的方法。但是I/O設備每一次周期挪用都有申請總線控制權、建立線控制權和歸還總線控制權的過程,所以傳送一個字對內存來說要占用一個周期,但對DMA控制器來說一般要2—5個內存周期(視邏輯線路的延遲而定)。因此,周期挪用的方法適用于I/O設備讀寫周期大于內存存儲周期的情況。

DMA與CPU交替訪問內存

如果CPU的工作周期比內存存取周期長很多,此時采用交替訪內的方法可以使DMA傳送和CPU同時發(fā)揮最高的效率。

這種傳送方式的時間圖如下

 

此圖是DMA與CPU交替訪內的詳細時間圖.假設CPU工作周期為1.2us,內存存取周期小于0.6us,那么一個CPU周期可分為C1和C2兩個分周期,其中C1專供DMA控制器訪內,C2專供CPU訪內。

這種方式不需要總線使用權的申請、建立和歸還過程,總線使用權是通過C1和C2分時制的。CPU和DMA控制器各自有自己的訪內地址寄存器、數(shù)據(jù)寄存器和讀/寫信號等控制寄存器。在C1周期中,如果DMA控制器有訪內請求,可將地址、數(shù)據(jù)等信號送到總線上。在C2周期中,如CPU有訪內請求,同樣傳送地址、數(shù)據(jù)等信號。事實上,對于總線,這是用C1,C2控制的一個多路轉換器,這種總線控制權的轉移幾乎不需要什么時間,所以對DMA傳送來講效率是很高的。這種傳送方式又稱為“透明的DMA”方式,其來由是這種DMA傳送對CPU來說,如同透明的玻璃一般,沒有任何感覺或影響。在透明的DMA方式下工作,CPU既不停止主程序的運行,也不進入等待狀態(tài),是一種高效率的工作方式。當然,相應的硬件邏輯也就更加復雜.

的DMA控制器和Cortex?-M3核心共享系統(tǒng)數(shù)據(jù)總線,執(zhí)行直接存儲器數(shù)據(jù)傳輸。當CPU和DMA同時訪問相同的目標(RAM或外設)時, DMA請求會暫停CPU訪問系統(tǒng)總線達若干個周期,總線仲裁器執(zhí)行循環(huán)調度,以保證CPU至少可以得到一半的系統(tǒng)總線(存儲器或外設)帶寬。

也就是說對32而言,DMA即使和CPU使用同樣的內存空間,32也會保證cpu至少會占用一半以上運行時間。也就是宏觀上兩者仍是同步的。而當DMA和CPU使用不同空間時,兩者宏觀上也是同步的

3.STM32使用DMA非循環(huán)方式傳輸完成后重新開啟傳輸:

當通道配置為非循環(huán)模式時,傳輸結束后(即傳輸計數(shù)變?yōu)?)將不再產(chǎn)生DMA操作。要開始新的DMA傳輸,需要在關閉DMA通道的情況下,在DMA_CNDTRx寄存器中重新寫入傳輸數(shù)目。

即關DMA->寫傳輸數(shù)目->開DMA

4.借用系統(tǒng)提供的庫函數(shù)或者說DMA_CNDTRx寄存器可以查詢我們傳輸?shù)氖S鄶?shù)據(jù),可用在記錄當前接收數(shù)據(jù)百分比的顯示。

5.存儲器到存儲器模式

DMA通道的操作可以在沒有外設請求的情況下進行,這種操作就是存儲器到存儲器模式。(我們以串口為例,這種外設查看串口使能DMA時序可知其會自動向CPU提DMA請求,而對于比如外設也是存儲設備那么他自身不具有自動提DMA申請功能,這種就屬于存儲器到存儲器模式,這是m2m位需置1)

 

[!--empirenews.page--]

以上圖DMA1請求映像為例,可知外設(這里指的是比如串口 spi TIM等32自帶的外設)都是以硬件自動觸發(fā)的DMA請求,而非自身外設比如加的外部存儲設備無硬件自動觸發(fā)機制就需要通過設置M2M位實現(xiàn)軟件觸發(fā)DMA請求給CPU了當設置了DMA_CCRx寄存器中的MEM2MEM位之后,在軟件設置了DMA_CCRx寄存器中的EN位啟動DMA通道時, DMA傳輸將馬上開始。當DMA_CNDTRx寄存器變?yōu)?時, DMA傳輸結束。存儲器到存儲器模式不能與循環(huán)模式同時使用。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉