解决STM32断点调试无法进入串口接收中断问题

先说结果,可能是stm32调试功能/keil软件/调试器(试过STLINK和JLINK两种)的问题,不是代码;

1、入坑

配置完串口后,可以发送数据到串口助手,但不能接收数据并做处理,所以第一步,想确定有没有接收到单个字节进入中断。

开始打断点调试,发现串口数据寄存器DR能收到数据,串口状态寄存器SR也有标志的变化,但就是进不了中断服务函数的判断,反复检查配置、各种百度、直到替换为最简单的工程只保留串口,仍然不能解决。

2、串口状态寄存器

串口状态寄存器,显示了串口是否发送完成、接收到数据等,就是我们主要观察的寄存器。

3、具体现象

3.1、初始状态

断点打在判断是否收到数据的if语句,此时,状态寄存器SR=0xC0,未收到数据,数据寄存器DR=0x00;

3.2、进不去接收判断

通过串口助手发送0x01,状态寄存器SR=0xF0,表示收到数据RXNE=1,DR=0x01,收到数据和发送数据一致。

此时一切正常,理论上单步执行后,应该进入if的内容执行接收数据的操作,但是直接跳到了else,再看状态寄存器SR=0xC0,接收数据的标志没了RXNE=0,所以无法接收数据。

为什么RXNE标志位被清掉了呢?

看手册有两种情况,一是读数据寄存器,二是写0。

但是我们既没有去读DR,更没有写0,只是单步执行就自动被清掉了。

3.3、修改断点位置,正常进入接收

通过串口助手发送0x02,状态寄存器SR=0xF0,表示收到数据RXNE=1,DR=0x02,收到数据和发送数据一致,并且进入if判断内部,可正常接收数据。

 4、反思

配置出问题,可第一时间从单个功能的工程入手,直接在现有代码上调试会有更多不确定的因素,更浪费时间精力。

不要太相信打断点调试,可能会有些代码不能正常执行,尤其是遇到和手册中描述不一致的地方,奇奇怪怪的时候。

物联沃分享整理
物联沃-IOTWORD物联网 » 解决STM32断点调试无法进入串口接收中断问题

发表评论