OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 22|回复: 0

USART在DMA接收时清标志的注意事项

[复制链接]

5

主题

5

帖子

0

精华

新手上路

积分
24
金钱
24
注册时间
2024-12-9
在线时间
2 小时
发表于 前天 09:58 | 显示全部楼层 |阅读模式

Questions:USART 使能 DMA 来接收数据时,对于需要通过读 USART_DT 才能清除的标志(如 IDLE、PERR 等),如因某些原因被延时没有立即执行清除,可能会导致后面发送过来的数据无法被 DMA 接收,进而会出现 DMA 接收有丢数据的现象。

Answer:这类标志的清除操作如果被例如其他高优先级中断打断而延时,此时对接设备端后续的数据已经发送过来,这时才通过软件读 USART_DT 来清之前置位的标志(如 IDLE、PERR 等),可能会导致刚要置位的 RDBF 被清除(因设计原理为软件清除的优先级要高于硬件置位),进而清掉了 DMA 的接收请求,导致 DMA 的接收丢数据。解决方法,USART 使能 DMA 来接收数据时,对于需要通过读 USART_DT 才能清除的标志(如 IDLE、PERR等),必须及时清标志(先读 USART_STS 再读 USART_DT),以避免接收到新数据后才读 USART_DT,导致误清 RDBF 及 DMA 的接收请求。推荐通过 USART 中断来判断并清除这类标志,设置该 USART 中断的优先级为最高抢占级,保证能及时进中断去读 USART_DT 清标志,以避免被延时。

类型:MCU 应用
适用型号:AT32F403、AT32A403A、AT32F403A、AT32F413、AT32F415、AT32WB415、AT32F421、AT32F435、AT32F437、AT32F425、AT32L021、AT32F423、AT32A423、AT32F402、AT32F405、AT32F455、AT32M412
主功能:无
次功能:无
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-18 19:20

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表