没有合适的资源?快使用搜索试试~ 我知道了~
首页USART中断方式接收无响应问题的一种情况及其处理方法
USART中断方式接收无响应问题的一种情况及其处理方法
1.7k 浏览量
更新于2023-05-30
评论 1
收藏 268KB PDF 举报
此问题由客户工程师提出,客户在使用STM32F103的USART做串口通讯时,发现了一个问题,当设备正常通信一段时间后,串口不响应外部的通信请求了.
资源详情
资源评论
资源推荐

USART中断方式接收无响应问题的一种情况及其处理方法中断方式接收无响应问题的一种情况及其处理方法
此问题由客户工程师提出,客户在使用STM32F103的USART做串口通讯时,发现了一个问题,当设备正常通信
一段时间后,串口不响应外部的通信请求了.
调研:
一、经过调研:
1.1 客户除了使用USART做串口通信,还开启了定时器中断来进行数据采集.
1.2 定时器的优先级比串口接收的优先级高.
1.3 定时器处理数据操作也比较频繁.
1.4 客户使用的STM32F1标准库(版本V3.5.0).
二、经过问题复现和使用ST-LINK在线调试和定位发现:
2.1 在出现这个问题的时候,程序不断的进入串口接收中断,不能够运行到main主函数处理其他任务了.
2.2 发现ORE标志为‘1’,也就说明程序是发生了串口溢出错误.
2.3 客户在进入串口中断后会调用USART_GetITStatus(USART2, USART_IT_RXNE)来获取RXNE的值.如果RXNE为1则去读
取DR数据寄存器的数据,读取后RXNE为0,但是ORE的标志依然为1,依然进入了串口中断.
三、经过分析以及我们可以通过我们芯片的用户手册可以得到以下信息:
3.1 程序不断进入串口中断是因为ORE标志始终为1,没有被用户清除掉:
从上图红色部分我们可以看到,如果串口接收中断开启了,那么ORE为1时就会产生中断.
3.2.从下图我们可以看到,顺序执行对USART_SR和USART_DR的操作就会清除ORE的标志,客户在中断中执行了以下操作,
那为什么ORE标志还没有被清除呢?(R1执行了读USART_SR操作,R2执行了读USART_DR操作).
3.3 我们可以看手册中下表的解释:
3.3.1 ORE表征的是一个历史事件,当ORE为1时,表明至少有1个数据已经丢失.
3.3.2这有2种可能发生的情况,RXNE为1的情况R3和RXNE为0的情况R4,如下图中的解释.




















weixin_38607864
- 粉丝: 3
- 资源: 935
上传资源 快速赚钱
我的内容管理 收起
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助

会员权益专享
最新资源
- ARM Cortex-A(armV7)编程手册V4.0.pdf
- ABB机器人保养总结解析.ppt
- 【超详细图解】菜鸡如何理解双向链表的python代码实现
- 常用网络命令的使用 ipconfig ping ARP FTP Netstat Route Tftp Tracert Telnet nslookup
- 基于单片机控制的DC-DC变换电路
- RS-232接口电路的ESD保护.pdf
- linux下用time(NULL)函数和localtime()获取当前时间的方法
- Openstack用户使用手册.docx
- KUKA KR 30 hA,KR 60 hA机器人产品手册.pdf
- Java programming with JNI
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈



安全验证
文档复制为VIP权益,开通VIP直接复制

评论0