
想请问下论坛的各位大佬们,stm32有一个HardFault硬件错误,这个是当发生内存溢出等错误时硬件自动跳转到HardFault地址吗,还是有其他机制呢?还有一个问题就是进入HardFault前或者后是否会把stm32的中断都关掉?请大佬们解惑,谢谢 |
stm32G474的flash模式如何判定?single bank 和dual bank
F103RCT6芯片对AFIO->MAPR寄存器写入时出错
基于STM32F103的HAL库实现USB(HID) OTA升级
STm32L562图片切换演示
STM32N6 使用SDMMC1-eMMC作为外部存储器,地址如何配置
使用CubeMX选择芯片生成项目时如何选择外部晶振?
STM32N6570-DK预装的Demo在哪里下载?
FlyMcu下载写入出错问题
STM32F373 SDAC1+DMA,数据只能更新一次?
在使用nucleo H7开发版 USART2发送数据测试的时候,RTS脚产生与TX脚一样的伴随波形,波形与TX脚一致
你发的那张NVIC的中断优先级表其实已经讲解的很清楚了。HARDFAULT是一个很高优先级的中断。而且是不可屏蔽的。
当发生比方说非法的地址访问的时候,就会出发HardFault中断。你看到的陷入到了hardfault函数里面可以认为是进入了hardfault的ISR。因为hardfault的isr是loop的所以,除了reset和nmi之外的中断都不可能被响应。
非法访问居多,比如数组越界访问、指针越位等,当然还有其它原因或机制,比方THUME \ARM运行状态选择不对,这点根本原因源于指令。其它还有可能是因为中断上访导致。HARDFAULT本身只是个优先级仅低于NMI和复位的异常,它不操作其它中断控制位,但由于其高优先级和它ISR处理方式或堵塞其它低优先级中断的响应,会给人感觉它能关闭其它中断。
[md]了解了,谢谢大佬
了解了,谢谢大佬