从corebld的实现可以看出,corebld本身是不会对ELF文件中的代码进行重新定位的,这点与在A核中运行的程序不同。这就要求在编译生成要在B核中运行的程序的时候,链接器就必须设置好每个Section的代码在绝对地址空间中的位置。要达到这个目的,要求在编写B核程序的时候要同时通过lds文件指定目标代码的位置。
以下代码就是user/blkfin-apps/corebld/coreb.lds中的内容,在链接B核程序的时候可以修改makefile将这个文件链接进去即可。
INCLUDE bf561.lds
PHDRS {
text PT_LOAD ;
data PT_LOAD ;
bss PT_LOAD ;
}
SECTIONS {
ENTRY(start)
. = SIZEOF_HEADERS;
.text : { . = ALIGN(4); *(.text) } >MEM_L1_CODE_A :text
.data : { . = ALIGN(4); *(.data) } >MEM_L1_DATA_A :data
.bss : { . = ALIGN(4); *(.bss)
. = ALIGN(4); __stack_bottom = .;
. = 0x1000; __stack_top = .;
} >MEM_L1_DATA_B :bss
}
至于主程序的编写可以参考user/blkfin-apps/corebld/coreb.S,对其中的一条跳转指令做适当修改即可:
.global _real_start;
_real_start:
/* Enable interrupts */
[--sp] = reti;
r0 = [sp++];
/* Disable WatchDog */
p0.l = (WDOGB_CTL & 0xFFFF);
p0.h = (WDOGB_CTL >> 16);
r0 = ((0xad << 4) | (0x3 << 1))(z);
w[p0] = r0;
//
在此处插入跳转指令
do_nothing:
IDLE;
jump do_nothing;