當(dāng)前位置:首頁(yè) > 單片機(jī) > 單片機(jī)
[導(dǎo)讀] STM32F2/F4 DMA控制器經(jīng)過(guò)精心設(shè)計(jì),固件程序在選擇合適的16-數(shù)據(jù)流X 16-通道組合時(shí)頗具靈活性。雙AHB端口結(jié)構(gòu)和到APB橋的直接路徑,避免了DMA服務(wù)低速APB外設(shè)時(shí)CPU在AHB1訪問(wèn)上的暫停,減少了DMA傳輸總延時(shí);在DM

 

STM32F2/F4 DMA控制器經(jīng)過(guò)精心設(shè)計(jì),固件程序在選擇合適的16-數(shù)據(jù)流X 16-通道組合時(shí)頗具靈活性。雙AHB端口結(jié)構(gòu)和到APB橋的直接路徑,避免了DMA服務(wù)低速APB外設(shè)時(shí)CPU在AHB1訪問(wèn)上的暫停,減少了DMA傳輸總延時(shí);在DMA控制器上實(shí)現(xiàn)了FIFO,使得在源和目標(biāo)之間配置不同的數(shù)據(jù)寬度時(shí)更具靈活性,遞增批量傳輸模式可以提高傳輸速度。

這里就STM32F2/F4的DMA編程,分享以下8點(diǎn)使用技巧或提示:

1.停止DMA的軟件序列

要斷開(kāi)連接到DMA數(shù)據(jù)流請(qǐng)求的外設(shè),必須:

?斷開(kāi)外設(shè)連接的DMA數(shù)據(jù)流,

?待DMA_SxCR寄存器的EN位復(fù)位(“0”)。

只有這樣才能安全地禁止外設(shè)。

注:在這兩種情況下,傳輸完成中斷標(biāo)志(DMA_LISR或DMA_HISR中的TCIF)置1將指示因數(shù)據(jù)流禁止而結(jié)束傳輸。

2.使能新的傳輸之前對(duì)DMA標(biāo)志進(jìn)行管理

使能新的傳輸之前,用戶(hù)必須確定DMA_LISRDMA_HISR中的傳輸完成中斷標(biāo)志(TCIF)已清0。

一般建議,在開(kāi)始新的傳輸之前,將DMA_LIFCR和DMA_HIFCR寄存器的所有標(biāo)志位均清零。

3.使能DMA的軟件序列

使能DMA時(shí),使用下面的軟件序列:

?配置適當(dāng)?shù)腄MA數(shù)據(jù)流。

?使能所用的DMA數(shù)據(jù)流(設(shè)置DMA_SxCR寄存器的EN位)。

?使能所用的外設(shè)。

注:如果用戶(hù)在使能相應(yīng)的DMA數(shù)據(jù)流之前就使能了所用的外設(shè),則由于DMA尚未準(zhǔn)備好向

外設(shè)發(fā)送其所需要的數(shù)據(jù)(從存儲(chǔ)器到外設(shè)進(jìn)行傳輸?shù)那闆r下),將會(huì)出現(xiàn)“FEIF”(FIFO錯(cuò)誤中斷標(biāo)志)。

4. NDTR=0時(shí),存儲(chǔ)器到存儲(chǔ)器傳輸

對(duì)DMA數(shù)據(jù)流進(jìn)行配置使其實(shí)現(xiàn)正常模式下從存儲(chǔ)器到存儲(chǔ)器的傳輸,當(dāng)NDTR達(dá)到0時(shí),傳輸完成標(biāo)志將置1。此時(shí),如果用戶(hù)重新置位該數(shù)據(jù)流的使能位(DMA_SxCR中的EN位),存儲(chǔ)器到存儲(chǔ)器的傳輸將自動(dòng)使用最后的NDTR值再次重新觸發(fā)。

5. PINC/MINC=0,DMA外設(shè)批量傳輸

禁止外設(shè)地址或存儲(chǔ)器地址遞增配置下的DMA批量數(shù)據(jù)傳輸,允許對(duì)

支持批量傳輸(集成FIFO)的內(nèi)部或外部(FSMC)外設(shè)尋址。這種模式保證了該DMA數(shù)據(jù)流在其數(shù)據(jù)傳輸過(guò)程中不被其他DMA數(shù)據(jù)流中斷。

6.兩次映射DMA請(qǐng)求

當(dāng)用戶(hù)配置了兩個(gè)(或更多)DMA數(shù)據(jù)流服務(wù)于同一個(gè)外設(shè)請(qǐng)求時(shí),軟件應(yīng)當(dāng)保證在使能新的DMA數(shù)據(jù)流之前,當(dāng)前DMA數(shù)據(jù)流完全被禁止(通過(guò)輪詢(xún)DMA_SxCR寄存器的EN位)。

7.最佳DMA吞吐量配置

若STM32F4xx的AHB頻率不太高,而DMA為一個(gè)高速外設(shè)服務(wù)時(shí),建議將堆棧置于CCM(CPU可通過(guò)D-bus對(duì)其直接尋址)中而不是SRAM上,否則將會(huì)在CPU和DMA訪問(wèn)SRAM存儲(chǔ)器時(shí)產(chǎn)生額外的并發(fā)訪問(wèn)請(qǐng)求。

8. DMA傳輸暫停

可以隨時(shí)暫停DMA傳輸稍后重新開(kāi)始;也可以在DMA傳輸結(jié)束前完全停止其傳輸功能。分為兩種情況:

?傳輸被中止,且后續(xù)不再?gòu)钠渫V裹c(diǎn)繼續(xù)傳輸:無(wú)其他操作,僅將DMA_SxCR寄存器的EN位清零來(lái)禁止該數(shù)據(jù)流,并在EN位置位前保持等待。因此:

–DMA_SxNDTR寄存器中含有數(shù)據(jù)流停止時(shí)剩余數(shù)據(jù)項(xiàng)的數(shù)目,這樣軟件便可以確定數(shù)據(jù)流中斷前已傳輸了多少數(shù)據(jù)項(xiàng)。

暫停傳輸,以便稍后通過(guò)重新使能該數(shù)據(jù)流來(lái)重新開(kāi)始(傳輸):要從停止點(diǎn)重新開(kāi)始該傳輸,軟件必須在禁止數(shù)據(jù)流(EN位置“0”)后讀取DMA_SxNDTR寄存器,以便獲取已接收的數(shù)據(jù)項(xiàng)數(shù)目。然后:

–必須更新外設(shè)和/或存儲(chǔ)器地址以調(diào)整地址指針。

–必須使用要傳輸?shù)氖S鄶?shù)據(jù)項(xiàng)的數(shù)目(禁止數(shù)據(jù)流時(shí)讀取的值)更新SxNDTR寄存器。

–數(shù)據(jù)流接著可以被重新使能,從停止點(diǎn)繼續(xù)開(kāi)始傳輸。

注:傳輸完成中斷標(biāo)志(DMA_LISR或DMA_HISR中的TCIF)置1將指示因數(shù)據(jù)流中斷而結(jié)束傳輸。

以上內(nèi)容自ST官方STM32應(yīng)用筆記文檔AN4031的部分內(nèi)容翻譯而來(lái),有疑問(wèn)或覺(jué)得需斟酌的地方,建議閱讀英文版及相關(guān)STM32參考手冊(cè)。該文檔對(duì)STM32F4/F2的DMA及芯片總線(xiàn)框架做了較為詳細(xì)的解說(shuō),值得一讀。STM32蝶粉們可以去ST中文官網(wǎng)www.stmcu.com.cn搜索AN4031下載該文檔。

 

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

9月2日消息,不造車(chē)的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

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

關(guān)鍵字: 汽車(chē) 人工智能 智能驅(qū)動(dòng) BSP

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

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

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

關(guān)鍵字: 騰訊 編碼器 CPU

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

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

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

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

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

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

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

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

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

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉