这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 嵌入式开发 » MCU » 两份简单的 Bootloader 程序

共708条 20/71 |‹ 18 19 20 21 22 23 ›| 跳转至
菜鸟
2014-08-18 14:41:23     打赏
191楼
bin文件拷贝到SD卡中了,通过KEIL转的。硬件接口也和你程序改成一样的了。其它地方都没改了。开机运行,没去loader我的流水灯程序呢,难道还要改其它什么位置?

菜鸟
2014-08-18 16:37:51     打赏
192楼

师兄,现在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;

高工
2014-08-18 17:07:21     打赏
193楼
你还是先验证一下,读写SD卡文件是否正常

菜鸟
2014-08-18 17:14:15     打赏
194楼

原来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)   一直在死在这里了。
  {
  }
}

}

}

是需要配置中断向量吗?


菜鸟
2014-08-18 17:15:22     打赏
195楼
SD卡文件读取正常,拷贝到flash中了,但跳转到PP,不对了

菜鸟
2014-08-19 10:37:49     打赏
196楼
; *** 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)

   .ANY (+RO)


keil中LINKER里面Scatter文件中的内容,有网友说红色部分地址需要这样更改,楼主,是不是需要这样改?我改了,直接进不了主程序了


高工
2014-08-19 11:18:58     打赏
197楼
你的APP程序编写的时候需要在编译器里设置一下地址,这个地址是根据bootloader来设置的。你可以看看bootloader里面的地址是跳转到哪个地方,你再去设置。具体的设置我下班后回去看看。

菜鸟
2014-08-19 13:02:43     打赏
198楼
是在APP程序编译时,更改KEIL   target options中的IROW1 为0X08010000啊,我一直在bootloader对应的keil里面改。我试试。谢谢了。

菜鸟
2014-08-19 13:26:19     打赏
199楼

需要改动的地方如下1,2

1,

system_stm32f10x.c    

#define VECT_TAB_OFFSET  0x00000  改成0x10000?

2,

KEIL   target options中的IROW1 改为0X08010000  ?

问:上面1,2两处的更改都是针对APP程序这边吗


高工
2014-08-19 13:38:24     打赏
200楼
是的

共708条 20/71 |‹ 18 19 20 21 22 23 ›| 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]