在uclinux for bf561中使用B核(4):B核代码的编写

    从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;
 
 

你可能感兴趣的:(include,makefile)