您好!
我正在为28035开发定制引导加载程序。 我创建了两个不同的项目、一个用于引导加载程序、另一个用于应用程序。 我能够同时运行这两者。 引导加载程序位于扇区 A 中、而其他扇区用于闪存。 这两个应用都从闪存运行。
当我使用调试器时、我注意到引导加载程序能够跳转到主应用程序、之后主应用程序运行正常。 但当我复位电路板时、我注意到引导加载程序正在执行、但应用 程序不运行。
我尝试了其他一些方法、发现如果我使用函数指针跳转到主应用程序、它工作正常。 但我认为这不是一种正确的方法、因为它不会使堆栈和所有其他寄存器处于静止状态。
对于引导加载程序、我使用了 controlsuit 中的闪存内核示例。
/***** 引导加载程序链接器********
第0页:
程序:origin = 0x008000,length = 0x001000 //片上 RAM (L0-L2)*/
OTP:origin = 0x3D7800,length = 0x000400 //片上 OTP */
FLASHH:origin = 0x3E8000、length = 0x004000 //片上闪存*/
// FLASHG:origin = 0x3EA000,length = 0x002000 //片上闪存*/
FLASHF:origin = 0x3EC000、length = 0x002000 //片上闪存*/
FLASHE:origin = 0x3EE000、length = 0x002000 //片上闪存*/
FLASHD:origin = 0x3F0000,length = 0x002000 //片上闪存*/
FLASHC:origin = 0x3F2000,length = 0x002000 //片上闪存*/
FLASHA:origin = 0x3F6000,length = 0x001F80 //片上闪存*/
csm_RSVD:origin = 0x3F7F80,length = 0x000076 // FLASHA 的一部分。 当 CSM 正在使用时、使用所有0x0000进行编程。 *
begin:origin = 0x3F7FF6,length = 0x000002/* FLASHA 的一部分。 用于"引导至闪存"引导加载程序模式。 *
CSM_PWL:origin = 0x3F7FF8,length = 0x000008 // FLASHA 的一部分。 FLASHA 中的 CSM 密码位置*/
部分
{
/*分配计划领域:*/
codestart:> begin,page = 0
ramfuncs:load = FLASHA,
运行=程序、
load_start (_RamfuncsLoadStart)、
load_end (_RamfuncsLoadEnd)、
run_start (_RamfuncsRunStart)、
PAGE = 0
.text:> FLASHA,page = 0
InitBoot:> FLASHA,page = 0
.cinit:> FLASHA,page = 0
.pinit:> FLASHA,page = 0
.switch:> FLASHA,PAGE = 0
.reset:> FLASHA,page = 0,type = DSECT /* not used,*/
csmpasswds:>csm_PWL page = 0
csm_rsvd:>csm_RSVD page = 0
/*分配未初始化的数据段:*/
.stack:>RAMM0,page = 1.
.ebss:> DataRAM,page = 1.
.esysmem:> DataRAM,page = 1.
/***** 主应用程序链接器*********
第0页:
程序:origin = 0x008000,length = 0x001000 //片上 RAM (L0-L2)*/
OTP:origin = 0x3D7800,length = 0x000400 //片上 OTP */
FLASHH:origin = 0x3E8002、length =(0x006000 - 0x2)//片上闪存*
// FLASHG:origin = 0x3EA000,length = 0x002000 //片上闪存*/
// FLASHF:origin = 0x3EC000、length = 0x002000 //片上闪存*/
FLASHE:origin = 0x3EE000、length = 0x002000 //片上闪存*/
FLASHD:origin = 0x3F0000,length = 0x002000 //片上闪存*/
FLASHC:origin = 0x3F2000,length = 0x002000 //片上闪存*/
// FLASHA:origin = 0x3F6000,length = 0x001F80 //片上闪存*/
csm_RSVD:origin = 0x3F7F80,length = 0x000076 // FLASHA 的一部分。 当 CSM 正在使用时、使用所有0x0000进行编程。 *
begin:origin = 0x3E8000,length = 0x000002/* FLASHA 的一部分。 用于"引导至闪存"引导加载程序模式。 *
CSM_PWL:origin = 0x3F7FF8,length = 0x000008 // FLASHA 的一部分。 FLASHA 中的 CSM 密码位置*/
IQTABLES:origin = 0x3FE000,length = 0x000B50 //引导 ROM 中的 IQMath 表*/
IQTABLES2:origin = 0x3FEB50,length = 0x00008C //引导 ROM 中的 IQMath 表*
IQTABLES3:origin = 0x3FEBDC,length = 0x0000AA /*引导 ROM 中的 IQMath 表*/
BootROM:origin = 0x3FF27C,length = 0x000D44 // Boot ROM */
复位:origin = 0x3FFFC0,length = 0x000002 //引导 ROM 的部分*/
向量:origin = 0x3FFFC2,length = 0x00003E //引导 ROM 的部分*/
第1页:
BOOT_RSVD:origin = 0x000000,length = 0x000050 // M0的一部分,引导 ROM 将此用于栈*/
RAMM0:origin = 0x000050、length = 0x0007B0 //片上 RAM 块 M0 *
// RAMM1:origin = 0x000400,length = 0x000400 //片上 RAM 块 M1 */
DataRAM:origin = 0x009000,length = 0x001000 //数据 RAM (L3)*/
FLASHB:origin = 0x3F4000,length = 0x002000 //片上闪存*/
CLA_CPU_MSGRAM:origin = 0x001480,length = 0x000080 /* CLA-R/W,CPU-R 消息 RAM *
CPU_CLA_MSGRAM:origin = 0x001500,length = 0x000080 // cpu-R/W,cla-R 消息 RAM *
}
部分
{
/*分配计划领域:*/
.cinit:> FLASHH,PAGE = 0
.pinit:> FLASHH,PAGE = 0
.text:> FLASHH,PAGE = 0
codestart:> begin page = 0
ramfuncs:load = FLASHD,
运行=程序、
load_start (_RamfuncsLoadStart)、
load_end (_RamfuncsLoadEnd)、
run_start (_RamfuncsRunStart)、
PAGE = 0
csmpasswds:>csm_PWL page = 0
csm_rsvd:>csm_RSVD page = 0
/*分配未初始化的数据段:*/
.stack:>RAMM0,page = 1.
.ebss:> DataRAM,page = 1.
.esysmem:> DataRAM,page = 1.
/*********
在引导程序代码中、
返回 SCI_Boot ();不能使用 whtout JTAG。
但是 (*((void (*)(void)) AppEntryAddr)(); 起作用。