STM32HAL库HAL_Delay()卡死

     STM32的HAL_Delay本质上是和Systick有关,而Systick官方默认的优先级为15,非常低,如果在中断里调用了HAL_Delay()函数就会出现卡死的问题。需要将Systick的优先级提高,外部中断的优先级降低(建议最好不要在中断中调用HAL_Delay()函数)

### 关于CubeIDE中HAL_Delay导致程序卡死的原因分析 在STM32微控制器开发过程中,`HAL_Delay()`函数是一个常用的阻塞延时函数。然而,在某些情况下,该函数可能会导致程序卡死或无法正常运行。这通常与系统的滴答定时器(SysTick Timer)配置有关。 #### SysTick 配置的重要性 `HAL_Delay()` 函数依赖于 `HAL_Init()` 初始化期间设置的系统滴答中断(SysTick)。如果未正确初始化 SysTick 或者其回调函数被禁用,则可能导致延迟功能失效并使程序进入无限等待状态[^1]。 #### 中断优先级冲突的可能性 另一个常见原因是中断优先级配置不当。当其他高优先级中断持续占用 CPU 时间片而阻止了 SysTick 的执行时,也会引发类似的冻结现象。因此需要合理规划各个外设及其对应 ISR (Interrupt Service Routine) 的抢占优先级(preemption priority) 和子优先级(sub-priority)[^2]。 以下是调整代码的一个例子来展示如何重新定义默认向量表偏移地址: ```c // 修改NVIC Group Priority分组模式为4位Preemptive Priority,无Subpriority __set_PRIMASK(1); // 禁止全局中断防止修改过程被打断 SCB->AIRCR = 0x05FA | (SCB->AIRCR & SCB_AIRCR_VECTKEY_MASK) | SCB_AIRCR.PRIGROUP_Msk; __DSB(); __ISB(); __set_PRIMASK(0); // 开启全局中断 ``` 以上片段展示了通过改变 NVIC 组优先级分配方式从而减少潜在竞争条件风险的方法之一[^3]。 #### 调试建议 为了定位具体原因可以采取如下措施: - 使用串口打印调试信息确认到达哪一步骤; - 借助逻辑分析仪观察实际硬件信号波形变化情况; - 利用JTAG/SWD接口连接专业工具如Keil uVision Trace或者ST-LINK Utility查看实时寄存器数值以及堆栈指针位置等细节数据; 最终解决方案可能涉及修复错误的启动脚本参数、优化现有资源利用率甚至更换更适合当前应用场景的新算法模型等等。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值