chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

STM32串口中斷 DMA接收的幾點注意地方

黃工的嵌入式技術圈 ? 來源:黃工的嵌入式技術圈 ? 2020-03-04 13:57 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

今天寫點大家常問,也是常見的關于UART串口的內容。這幾點內容或許曾經也困惑了你很久。

1UART串口中斷接收

使能UART串口中斷之后,有接收到UART數據,進入中斷,此時要清除RXNE接收標志位:

1.通過軟件向該RXNE標志位寫入零來清零;

2.通過對 USART_DR 寄存器執(zhí)行讀入操作將該位清零。

這里可以查看對應《參考手冊》,一般我們選擇第2種,通過讀取UART串口數據來清零。

1.中斷接收數據丟失

在UART串口中斷函數中,或者更高優(yōu)先級中斷函數中長時間執(zhí)行,導致接收丟失,所以,請勿在中斷函數中長時間執(zhí)行。

特別有些人,還在中斷函數添加延時函數。實際應用中,只要不是特殊情況,比如測試某個功能可以添加延時函數,都不建議在中斷函數添加延時函數。

2.ORE上溢錯誤

ORE上溢錯誤是什么意思呢?可能很多人不了解,簡單說就是:UART接收到有數據,沒有去取,但又來了數據,此時就會產生ORE上溢錯誤。(請看“參考手冊”)

其實,上面這種長時間在占用中斷,就會導致UART接收數據上溢。

很多人沒有在意這個,如果是使能了中斷接收,標志位沒有清除,又有ORE上溢錯誤的話,程序就會不停地進入UART中斷。(大家不妨試一下,看一下是不是你代碼一直在UART中斷里面不停運行)。

3.使能接收中斷前,先清除接收標志位

有時候,在程序初始化的時候,就會接收到數據,這個時候建議大家先清除接收標志位再使能接收中斷。類似如下:

2

DMA接收串口數據

使用DMA接收串口數據,相信很多朋友都知道。這個可以理解為使用隊列,或者FIFO的形式,防止因高優(yōu)先級中斷而打斷,導致接收數據丟失。

但很多人都遇到過,接收不到數據,或者數據異常的情況。所以,這里同樣有需要注意的地方。

1.使能UART之前,先使能DMA相關配置

這個和清除標志位一樣的道理,使能UART之前,先使能DMA相關配置,防止在配置過程中有接收數據。

2.ORE上溢錯誤導致不能使用DMA接收數據

導致不能DMA接收不到數據的根源,有一種可能就是有ORE上溢錯誤。

若在串口初始化并使能后到 DMA 使能之前有數據來,MCU是不能接收的。如果此時數據寄存器 USART_DR 存在一個數據,再來一個數據,就會導致ORE上溢錯誤。

一旦產生上溢錯誤后,就無法再觸發(fā) DAM 請求,及時之后再啟動 DMA 也不行,無法觸發(fā) DMA 請求就無法將數據寄存器內的數據及時轉移走,如此陷入死鎖。這就是串口無法正常接收的原因。

所以,最后提醒大家,配置時,請一定要注意這些細節(jié)。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • STM32
    +關注

    關注

    2313

    文章

    11189

    瀏覽量

    374569
  • uart
    +關注

    關注

    22

    文章

    1319

    瀏覽量

    106961
  • dma
    dma
    +關注

    關注

    3

    文章

    582

    瀏覽量

    106257
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    cs32A010串口通訊問題

    串口中斷接收數據,第一個數據是0,第二個才是正確的數據,而且最后一個字節(jié)放到了下一幀數據第一個。 pack包的串口中斷例程跑的也有問題,讀取串口數據為什么是兩條一樣的語句,是什么意思?
    發(fā)表于 04-13 12:35

    串口中斷和定時中斷,外部中斷在一起如何調用?

    /9600=20ms 也就是說,處理了定時中斷后,再處理的串口中斷 時間上:實際是定時+串口 如果是1s內,那么定時中斷內嵌套串口中斷
    發(fā)表于 01-14 06:25

    為什么串口接收數據就會觸發(fā)中斷呢?

    為什么串口接收數據就會觸發(fā)中斷呢? 串口接收喚醒機制有哪些注意事項?
    發(fā)表于 01-08 06:45

    串口空閑中斷串口超時中斷介紹

    1. 空閑中斷(Idle Interrupt) 觸發(fā)條件 當串口總線在接收數據后持續(xù)保持空閑狀態(tài)(如高電平)超過一幀時間(即一個字符傳輸時間)時觸發(fā)。 硬件自動檢測總線空閑狀態(tài),與數據長度無關
    發(fā)表于 11-21 08:31

    E203串口中斷使用總結

    以上函數的設置后,就可以在中斷服務函數中寫下自己需要的中斷處理功能,并且在 main() 函數中寫下“my_uart_init()”,就能實現(xiàn)串口中斷。 二、串口
    發(fā)表于 10-22 07:34

    rt-thread 在使用串口DMA模式的時候,接收數據接收不到00,為什么?

    硬件為STM32F103ZET6: 在使用串口通訊時,在DMA接收模式下,收不到00數據,遇到00數據,好像DMA模式就認為是數據已經結束了
    發(fā)表于 10-14 06:20

    串口DMA接收方式打開,為什么在開啟IDLE中斷的情況下還需要開啟DMA中斷呢?

    如圖,在以 RT_DEVICE_FLAG_DMA_RX 方式打開串口時,底層會配置串口IDLE中斷,同時也會打開DMA
    發(fā)表于 09-29 08:30

    串口DMA接收數據包丟失怎么解決?

    RTT串口DMA接收數據,超過緩沖區(qū)后為什么會吞掉一個數據包呢,不能每次處理完后清除緩沖區(qū)數據嗎,感覺接收的數據是累計的,累計滿之后會重新覆蓋,在最后一個包
    發(fā)表于 09-29 07:50

    配置了串口DMA,現(xiàn)在是接收可以,發(fā)送不行,是什么地方沒有設置對嗎?

    配置了串口DMA,現(xiàn)在是接收可以,發(fā)送不行,是什么地方沒有設置對嗎?當配置DMA_TX 不能發(fā)送數據,默認輪詢發(fā)送就可以。配置如下圖:
    發(fā)表于 09-28 07:41

    RTT5.2.0串口接收中斷死機怎么解決?

    RT_DEVICE_FLAG_DMA_RX 和 RT_DEVICE_FLAG_INT_RX 問題一樣, 如果不使用中斷就不會出現(xiàn)這個問題, 開始中斷如果沒有數據接收不會報錯, 有
    發(fā)表于 09-22 06:16

    關于stm32f4zgt6和mspm0g3507串口通信問題

    本人在使用stm32f4zgt6和mspm0g3507串口通信時出現(xiàn)問題,情況如下: m0芯片使用軟件超時解析進行數據接收,使用標準庫的transmit函數進行數據發(fā)送。 stm32使
    發(fā)表于 09-01 11:11

    CYT2B7串口接收會漏接數據怎么解決?

    串口中斷方式接收會漏接數據如串口工具發(fā)送 :1234567芯片接收到 :1357硬件是CYTVII-B-E-1M-SK開發(fā)板軟件是SDL v8.3 中的
    發(fā)表于 08-14 07:29

    求助,關于stm32H7多DMA數據流問題求解

    情況如下:stm32H7配置了一個adc進行采樣,通過dma進行數據傳輸,串口接收和發(fā)送命令,用兩個dma數據流通道,采用的空閑
    發(fā)表于 07-29 15:02

    STM32407使用串口閑時中斷+DMA方式接收最大接收字節(jié)是多少?

    使用串口閑時中斷+DMA方式接收數據,波特率為460800,DMA接收長度為1024個字節(jié),并開
    發(fā)表于 07-22 08:16

    STM32F407多機RS485串口通訊+地址位喚醒+DMA空閑線接收,無法進入中斷服務程序怎么處理?

    USART3_MspInit 1 / / USER CODE END USART3_MspInit 1 / } } 在主程序中開啟DMA接收和空閑線中斷: int main(void) { / USER
    發(fā)表于 07-10 07:28