程序卡在 B.处什么原因?如何处理?(串口配置无问题,重写putc无问题,但不打印)

文章目录

前提

为了张流量券多加更一篇,是我2月份遇到的问题的总结,在我的笔记中,一直没发

现象:

已经配置好串口但不打印输出(printf指向串口1 的SR寄存器,其他引脚和usart配置无问题)

debug:

先运行,无error无warning

进行debug查询问题所在,发现串口初始化usart_init(115200);都没走到就卡死在如图下所示的 B .位置

经过这个现象,再去寻找答案

原因

程序卡死在B .处,说明有中断没处理
比如,启用了某个类型的中断,但是没有对应的中断处理函数 ,则会出现这种问题
知道是中断的原因后,我第一个想法是关于串口配置的中断,因为我现在做的是串口功能,检查
串口中断服务函数
中断配置位置


检查后并无发现有问题

继续debug

在初始化发现根本还没来得及串口初始化便卡死在B.也就是说是串口之前的初始化工作中的中断出了问题,继续debug

发现在sys_init();函数中卡死

卡在126行,但是125是赋值,所以我当时并不能确定是126行的错误,也不能说是125行(126还没运行,卡死的是125,但是125没有写逻辑只是进行了赋值)

我们就知道是SYS_TICK()出了问题,结合前面卡在B.位置,大约已经能够确定是系统初始化的中断没有打开,在stm32f4xx_it.c文件中找到了我们需要的函数

默认情况下该函数是被屏蔽的,打开问题解决,串口打印也成功。

总结

.B处一般是中断配制出错的问题

检查之后没有出错

可以看看是不是systick_handler是不是初始化了

本篇文章仅供解决问题参考。

相关推荐
余生皆假期-4 小时前
永磁同步电机二次起步处理
单片机·嵌入式硬件
DLGXY5 小时前
STM32——TIM定时器、定时中断、RCC时序(八)
stm32·单片机·嵌入式硬件
CQ_YM5 小时前
ARM之I2C
arm开发·单片机·嵌入式硬件·嵌入式
让世界再也没有bug5 小时前
测试工具之一 ------示波器
单片机·嵌入式硬件·硬件测试·嵌入式软件测试
CircuitWizard6 小时前
STM32 + 淘晶驰T1串口屏波形显示
stm32·单片机·嵌入式硬件
A9better6 小时前
嵌入式开发学习日志53——互斥量
stm32·嵌入式硬件·学习
Q_21932764558 小时前
基于单片机的个性化服装尺寸红外 测量仪的设计
单片机·嵌入式硬件
Polanda。8 小时前
定时器-PWM参数测量实验
stm32·单片机·嵌入式硬件
恶魔泡泡糖9 小时前
51单片机串口通信
c语言·单片机·嵌入式硬件·51单片机
wotaifuzao9 小时前
【Keil 5安装】keil 5最新版本安装+环境配置+下载百度资源分享(安装包,注册机等)
stm32·单片机·嵌入式硬件·mcu·学习·keil5·最新keil