|
@@ -238,13 +238,13 @@ relocate_code:
|
|
mov r4, r0 /* save addr_sp */
|
|
mov r4, r0 /* save addr_sp */
|
|
mov r5, r1 /* save addr of gd */
|
|
mov r5, r1 /* save addr of gd */
|
|
mov r6, r2 /* save addr of destination */
|
|
mov r6, r2 /* save addr of destination */
|
|
- mov r7, r2 /* save addr of destination */
|
|
|
|
|
|
|
|
/* Set up the stack */
|
|
/* Set up the stack */
|
|
stack_setup:
|
|
stack_setup:
|
|
mov sp, r4
|
|
mov sp, r4
|
|
|
|
|
|
adr r0, _start
|
|
adr r0, _start
|
|
|
|
+ mov r1, r6 /* r1 <- scratch for copy_loop */
|
|
ldr r2, _TEXT_BASE
|
|
ldr r2, _TEXT_BASE
|
|
ldr r3, _bss_start_ofs
|
|
ldr r3, _bss_start_ofs
|
|
add r2, r0, r3 /* r2 <- source end address */
|
|
add r2, r0, r3 /* r2 <- source end address */
|
|
@@ -254,7 +254,7 @@ stack_setup:
|
|
stmfd sp!, {r0-r12}
|
|
stmfd sp!, {r0-r12}
|
|
copy_loop:
|
|
copy_loop:
|
|
ldmia r0!, {r3-r5, r7-r11} /* copy from source address [r0] */
|
|
ldmia r0!, {r3-r5, r7-r11} /* copy from source address [r0] */
|
|
- stmia r6!, {r3-r5, r7-r11} /* copy to target address [r1] */
|
|
|
|
|
|
+ stmia r1!, {r3-r5, r7-r11} /* copy to target address [r1] */
|
|
cmp r0, r2 /* until source end address [r2] */
|
|
cmp r0, r2 /* until source end address [r2] */
|
|
blo copy_loop
|
|
blo copy_loop
|
|
ldmfd sp!, {r0-r12}
|
|
ldmfd sp!, {r0-r12}
|
|
@@ -264,7 +264,7 @@ copy_loop:
|
|
* fix .rel.dyn relocations
|
|
* fix .rel.dyn relocations
|
|
*/
|
|
*/
|
|
ldr r0, _TEXT_BASE /* r0 <- Text base */
|
|
ldr r0, _TEXT_BASE /* r0 <- Text base */
|
|
- sub r9, r7, r0 /* r9 <- relocation offset */
|
|
|
|
|
|
+ sub r9, r6, r0 /* r9 <- relocation offset */
|
|
ldr r10, _dynsym_start_ofs /* r10 <- sym table ofs */
|
|
ldr r10, _dynsym_start_ofs /* r10 <- sym table ofs */
|
|
add r10, r10, r0 /* r10 <- sym table in FLASH */
|
|
add r10, r10, r0 /* r10 <- sym table in FLASH */
|
|
ldr r2, _rel_dyn_start_ofs /* r2 <- rel dyn start ofs */
|
|
ldr r2, _rel_dyn_start_ofs /* r2 <- rel dyn start ofs */
|
|
@@ -305,7 +305,7 @@ clear_bss:
|
|
ldr r0, _bss_start_ofs
|
|
ldr r0, _bss_start_ofs
|
|
ldr r1, _bss_end_ofs
|
|
ldr r1, _bss_end_ofs
|
|
ldr r3, _TEXT_BASE /* Text base */
|
|
ldr r3, _TEXT_BASE /* Text base */
|
|
- mov r4, r7 /* reloc addr */
|
|
|
|
|
|
+ mov r4, r6 /* reloc addr */
|
|
add r0, r0, r4
|
|
add r0, r0, r4
|
|
add r1, r1, r4
|
|
add r1, r1, r4
|
|
mov r2, #0x00000000 /* clear */
|
|
mov r2, #0x00000000 /* clear */
|
|
@@ -333,7 +333,7 @@ _start_oneboot_ofs
|
|
add lr, lr, r9
|
|
add lr, lr, r9
|
|
/* setup parameters for board_init_r */
|
|
/* setup parameters for board_init_r */
|
|
mov r0, r5 /* gd_t */
|
|
mov r0, r5 /* gd_t */
|
|
- mov r1, r7 /* dest_addr */
|
|
|
|
|
|
+ mov r1, r6 /* dest_addr */
|
|
/* jump to it ... */
|
|
/* jump to it ... */
|
|
mov pc, lr
|
|
mov pc, lr
|
|
|
|
|