STM32通过rt_hw_hard_fault_exception中的LR寄存器追溯程序问题

1. 问题现象

程序运行导致rt_hw_hard_fault_exception

如图

显示错误相关代码

c 复制代码
struct exception_stack_frame
{
    uint32_t r0;
    uint32_t r1;
    uint32_t r2;
    uint32_t r3;
    uint32_t r12;	
    uint32_t lr;	 // 链接寄存器 (LR)
    uint32_t pc;	// 程序计数器 (PC)
    uint32_t psr;	// 程序状态寄存器 (PSR)
};

void rt_hw_hard_fault_exception(struct exception_stack_frame *contex)
{
	Fm24cl64bInit();
//	static struct exception_stack_frame test;
	static CoreRegister_Type s_error_save;
//	test = *contex;   
	s_error_save.r0 = contex->r0;
	s_error_save.r1 = contex->r1;
	s_error_save.r2 = contex->r2;
	s_error_save.r3 = contex->r3;
	s_error_save.r12 = contex->r12;
	s_error_save.lr = contex->lr;
	s_error_save.pc = contex->pc;
	s_error_save.psr = contex->psr;
	uint8_t save_res = WriteCoreRegisterToEeprom(&s_error_save);
	
	lcd_Init();
	lcd_Init_PowerOn();
	lcd_Init_BackLight(1);
	lcd_BufferClear();
    lcd_BufferPrint(0, 0, 16, "R0:0x%08X  R1:0x%08X", s_error_save.r0, s_error_save.r1);
    lcd_BufferPrint(0, 2, 16, "R2:0x%08X  R3:0x%08X", s_error_save.r2, s_error_save.r3);
    lcd_BufferPrint(0, 4, 16, "R12:0x%08X LR:0x%08X", s_error_save.r12, s_error_save.lr);
    lcd_BufferPrint(0, 6, 16, "PC:0x%08X PSR:0x%08X", s_error_save.pc, s_error_save.psr);
	lcd_BufferPrint(0, 8, 16, "save_res:%d", save_res);
	lcd_BufferPrint(0, 10, 16, "Dst:%d 1st:%d 2st:%d", msg.MsgDstId, msg.FirstSubId, msg.SecondSubId);
	
	lcd_ScreenRefresh();
	
	while(1);
}

2. 问题分析

在ARM Cortex-M架构中,LR (Link Register, R14) 的值在HardFault或其他异常发生时,对追溯问题根源非常关键。

LR---保存函数返回地址

3. 问题追溯

1. 定位触发HardFault的代码位置

通过 LR:0x08009B47 找到对应的代码位置

使用调试器(如ST-Link + IDE)直接跳转到该地址。

​​

2. 分析LR地址附近的代码

常见触发HardFault的操作:

  • 访问非法地址(野指针、数组越界)。
  • 未对齐的内存访问(如对非4字节对齐地址执行LDR)。
  • 堆栈溢出(检查线程栈大小是否足够)。
  • 错误的函数指针调用(如跳转到无效地址)

这里的LPTIM1_IRQ_callback是个空指针,最终导致硬件错误。

相关推荐
weixin_491853311 小时前
SpringBoot 实现 RAS+AES 自动接口解密
java·spring boot·后端
Yuroo zhou2 小时前
无人机在复杂气流中,IMU 如何精准捕捉姿态变化以维持稳定?
单片机·嵌入式硬件·算法·机器人·无人机
程序员良辰3 小时前
Spring与SpringBoot:从手动挡到自动挡的Java开发进化论
java·spring boot·spring
鹦鹉0073 小时前
SpringAOP实现
java·服务器·前端·spring
练习时长两年半的程序员小胡4 小时前
JVM 性能调优实战:让系统性能 “飞” 起来的核心策略
java·jvm·性能调优·jvm调优
崎岖Qiu4 小时前
【JVM篇11】:分代回收与GC回收范围的分类详解
java·jvm·后端·面试
27669582926 小时前
东方航空 m端 wasm req res分析
java·python·node·wasm·东方航空·东航·东方航空m端
许苑向上6 小时前
Spring Boot 自动装配底层源码实现详解
java·spring boot·后端
喵叔哟6 小时前
31.【.NET8 实战--孢子记账--从单体到微服务--转向微服务】--单体转微服务--财务服务--收支分类
java·微服务·.net
codu4u13147 小时前
Maven中的bom和父依赖
java·linux·maven