
师兄,现在SPI这边没问题了,初始化正常。但在打开我保存在SD卡中的BIN文件时,gCheckFat==0x06,如下图所示。是我保存在SD卡中的Bin文件还需要做什么处理还是哪里不对呢,gCheckFat应该等于0啊。
if(gCheckFat == 0)
{gCheckFat = f_open(&FP_Struct,".../STM32-DEMOt.BIN",FA_READ); //”.../STM32-DEMOt.BIN“打开路径
if(gCheckFat == 0) //仿真发现该值为0x06 Bin文件是通过keil直接生成的,应该没问题。
{
APP_Sector = FP_Struct.fsize / 512;
APP_Byte = FP_Struct.fsize % 512;

原来APP是一个文件夹的子文件,在APP上又加了一个文件,刚才的问题解决了/现在程序执行到“跳转到APP处”,执行这一步时,发现产生了硬件失效中断,进入了中断函数处理,即死循环处。
//跳转到应用程序段
//appxaddr:用户代码起始地址.void iap_load_app(u32 appxaddr)
{
if(((*(vu32*)appxaddr)&0x2FFE0000)==0x20000000) //检查栈顶地址是否合法.
{
jump2app = (iapfun)*(vu32*)(appxaddr+4); //用户代码区第二个字为程序开始地址(复位地址)
MSR_MSP(*(vu32*)appxaddr); //初始化APP堆栈指针(用户代码区的第一个字用于存放栈顶地址)
jump2app(); //跳转到APP.执行到这一步,开始进入硬件失效死循环。即
(void HardFault_Handler(void)
{/* Go to infinite loop when Hard Fault exception occurs */
while (1) 一直在死在这里了。
{
}
}
)
}
}
是需要配置中断向量吗?

; *** Scatter-Loading Description File generated by uVision ***
; *************************************************************
LR_IROM1 0x08010000 0x00050000 { ; load region size_region
ER_IROM1 0x08010000 0x00050000 { ; load address = execution address
*.o (RESET, +First)
*(InRoot$$Sections)
; *************************************************************
LR_IROM1 0x08010000 0x00050000 { ; load region size_region
ER_IROM1 0x08010000 0x00050000 { ; load address = execution address
*.o (RESET, +First)
*(InRoot$$Sections)
.ANY (+RO)
keil中LINKER里面Scatter文件中的内容,有网友说红色部分地址需要这样更改,楼主,是不是需要这样改?我改了,直接进不了主程序了
回复
打赏帖 | |
---|---|
嵌入式LinuxC语言程序调试和宏使用技巧被打赏50分 | |
让代码中包含最新的编译时间信息被打赏50分 | |
rtthread硬件加密--2crc加密分析被打赏10分 | |
【分享开发笔记,赚取电动螺丝刀】mcxa156使用低功耗定时器适配硬件RTC框架被打赏26分 | |
【STM32F769】AI之与本地deepseek对接被打赏50分 | |
Buck电路工作在CCM模式下电感电流的计算公式是什么?被打赏5分 | |
buck电路工作原理被打赏5分 | |
基于MSPM0L1306的MODBUS-RTU协议通讯实验被打赏100分 | |
我想要一部加热台+多合一调试工具被打赏18分 | |
每周了解几个硬件知识+485硬件知识分享被打赏10分 |