先说结果,可能是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、反思
配置出问题,可第一时间从单个功能的工程入手,直接在现有代码上调试会有更多不确定的因素,更浪费时间精力。
不要太相信打断点调试,可能会有些代码不能正常执行,尤其是遇到和手册中描述不一致的地方,奇奇怪怪的时候。