关于ARM Keil5 Optimization level 优化后读取flash异常程序进入HardFault_Handler()-分析

在STM32项目中,将旧代码移植后遇到在执行FLASH_Read()函数时触发HardFault_Handler的问题。分析发现是由于编译优化导致的,原来代码使用的是-O0优化级别,而新代码可能使用了更高级别的优化。优化等级越高,虽然代码体积减小,但可能影响调试信息和代码逻辑。解决方案是将优化级别调整为-O0,以保持与未移植代码一致的调试友好性和代码逻辑。经过测试,建议使用-O0优化等级进行编译。

在这里插入图片描述

项目场景:

通过STM32 cubeMX创建程序后,把以前的flash驱动、UART等移植,实现产品相关功能。


问题描述

flash驱动移植后,程序在运行到FLASH_Read()函数时会进入到HardFault_Handler()硬件死循环中,而且单步运行发现该if(upgrade_finesh_flag == 0x5a5a) 条件可以进入。问题走向很明显编译环境出现了问题。

void InitDevice(void)
{
   
   
	__IO uint32_t upgrade_flag = 0;
	__IO uint32_t upgrade_finesh_flag = 0;

	HAL_FLASH_Unlock();	
	
	upgrade_flag = *(__IO uint32_t*)UPDATE_FLAG_ADDR;
	upgrade_finesh_flag = *(__IO uint32_t*)UPDATE_FINISH_FLAG_ADDR;
	if (upgrade_flag == 0xa5a5)    
	{
   
   
		FLASH_PageErase(UPDATE_FLAG_ADDR);
	}
	if(upgrade_finesh_flag == 0x5a5a)  //判断是否进行软件升级
	{
   
   
		FLASH_PageErase(UPDATE_FINISH_FLAG_ADDR);
		osDelay(500);
		__disable_fault_irq();
		NVIC_SystemReset();
	}
	osDelay(500);
	deviceInitSM = GET_RS485_BAUD;
	init_read_only_data();
	FLASH_Read(SERNUMBER_ADDR,&st_FactoryData.SerNumber,sizeof(st_FactoryData.SerNumber));
	FLASH_Read(FACTORYADDR_ADDR,&st_FactoryData.address,sizeof(st_FactoryData.address));
	FLASH_Read(MANUFACDAY_ADDR,&st_FactoryData.Manufacday,sizeof
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YH_DevJourney

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值