當前位置:首頁 > 公眾號精選 > 嵌入式大雜燴
[導讀]之前有個同事因為用串口查詢方式發(fā)送數(shù)據(jù),被我說了一頓,明明有DMA資源,竟然放著不用,對于魚鷹這種性能強迫癥來說,肯定無法忍受,所以當時就和他說,有時間你把它改一下。誰知道過了好幾個月他才有時間弄這個,然后還是出了問題,沒法子,只能找我解決了?,F(xiàn)象是這樣的,使用查詢方式,一點問題...

之前有個同事因為用串口查詢方式發(fā)送數(shù)據(jù),被我說了一頓,明明有 DMA 資源,竟然放著不用,對于魚鷹這種性能強迫癥來說,肯定無法忍受,所以當時就和他說,有時間你把它改一下。


誰知道過了好幾個月他才有時間弄這個,然后還是出了問題,沒法子,只能找我解決了。



現(xiàn)象是這樣的,使用查詢方式,一點問題沒有,從機可以正常接收數(shù)據(jù),一旦換成 DMA,從機就無法正常解析數(shù)據(jù)了,從機緩存的數(shù)據(jù)也不正確。



因為當時我也一臉懵逼,也不知道他做了什么操作導致的,畢竟他調(diào)用的 DMA 發(fā)送函數(shù)都是魚鷹很久以前寫的,也是久經(jīng)考驗的代碼,不可能出現(xiàn)問題才對。



所以在沒有頭緒的情況下,直接同時調(diào)試兩顆單片機了。



對,你沒有看錯,就是使用兩個調(diào)試器同時調(diào)試兩個單片機。



很簡單,就在下面的圖中選擇即可,估計有很多老司機都不知道這個吧。(不同工程)





這樣一臺電腦就可以同時調(diào)試主機和從機了。



當時首先查看了 DMA 外設和 UART 寄存器情況,發(fā)現(xiàn)并沒有問題(畢竟如果這個錯了,再怎么查應用代碼也是沒用的,排查問題要講究先后順序)。



又在線查了一會發(fā)現(xiàn),如果我在 DMA 發(fā)送函數(shù)后打上斷點,從機是可以正常解析的,這一點又讓我疑惑了,所以為了防止從機代碼可能有問題,直接讓同事用一個串口模塊接收數(shù)據(jù)。



串口助手顯示,發(fā)送的字節(jié)數(shù)是正確的,但是只有幀頭幾個字節(jié)對的,其它字節(jié)全是錯的。



一看到這里,魚鷹大概就知道了,大概率是 DMA 發(fā)送緩沖區(qū)被篡改了,一查函數(shù)調(diào)用,瞬間就明白了是怎么回事,函數(shù)調(diào)用大概如下(細節(jié)沒有展示):


void dma_send(DMA_Channel_TypeDef *DMAx, void *buff, uint8_t size)

{

DMAx->CNDTR = size;

DMAx->CMAR = buff;

}


void send_data()

{

uint8_t buff[8];

buff[0] = 1;

buff[1] = 2;

……

dma_send(dma1, buff, 8);

}竟然用局部數(shù)組變量作為 DMA 發(fā)送的緩沖區(qū),魚鷹也是醉了。


那么為什么查詢方式下,這樣的代碼不會出錯,DMA 方式就錯了?



要解答這樣的問題,基礎必須扎實:


1、DMA 傳輸原理


2、局部變量存放位置與特性。



只要知道這兩點,這個問題就很容易避免。


但事實上,很多人只會大概用,根本沒有真正理解。



DMA  串口傳輸憑什么說效率高?是因為它讓串口速率傳輸更快了嗎?一個字節(jié)傳輸本來要 1 ms,用 DMA 只要 0.5 ms?估計很多人都是這么理解的吧。



事實上,DMA 并沒有加快傳輸速率,只不過是把傳輸?shù)娜蝿辙D交給專業(yè)的而言《數(shù)據(jù)傳輸還用 CPU?不如交給 DMA 吧!》,而 CPU 就可以專心干剩下的事情。



注意這里的轉交一詞,CPU 把必要的傳輸信息(比如傳輸?shù)刂贰⒋笮〉龋└嬖V DMA 后,一般會啟動 DMA,之后立刻運行后面的代碼,但此時 DMA 緩存地址里面的數(shù)據(jù)并沒全部發(fā)送出去,如果這個緩存用的是局部變量,離開這個函數(shù)后,局部變量被回收,并會繼續(xù)給其他函數(shù)使用,此時這個緩存的數(shù)據(jù)就被篡改了,這樣 DMA 發(fā)送出去的數(shù)據(jù)當然不正確。



所以,從這個角度來說,DMA 并沒有加快串口本身的傳輸速度,只是解放了 CPU 資源而已。但是 CPU 被解放了, DMA 所使用的 緩存 資源可不能也隨之解放呀,只能等發(fā)送完畢后才能釋放。所以最簡單的方法是在 緩存 前面加一個 static 。



那么為什么查詢不會出問題呢?查詢是把所有緩存中的數(shù)據(jù)發(fā)送出去后,才會離開當前函數(shù),這樣局部變量始終存在,也就不會有問題了,不像 DMA 一樣扔到緩存里面就溜之大吉,局部變量也隨之溜了。



但是,還有一種特殊的局部變量,也能達到全局的效果。這就是操作系統(tǒng)中的主函數(shù)的局部變量。


void task()

{

uint32_t buff[32]; // 局部變量,但效果和全局變量差不多。

while(1)

{

}

}因為任務一般會被死循環(huán)包含,永不退出(前提條件),所以這里的局部變量也就不會被釋放掉,所以有些情況下,為了更好的使用資源,會采用這種方式。


好了,今天的分享到此結束,有收獲的話,記得三連支持一波呦!



往期推薦:


解析內(nèi)核的Makefile、Kconfig和.config之間的關聯(lián)!


極客感十足的電子胸牌 ART-Badge V2.0開發(fā)記錄!




本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(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 信息技術
關閉