运用ADS编译生成.axf文件,运用ARM fromELF能够提出可执行文件.bin——>可直接写入到Flash中:
bin文件的构成:RO+RW+ZI,其间RO中的地址和符号的地址是相同的,但RW和ZI是不同的,所以在用到RW和ZI之前有必要将其移动到实践的地址上,能够参阅44binit.s的源代码:
;********************************************************
;* Copy and paste RW data/zero initialized data *
;********************************************************
LDR r0, =|Image
Limit| ; Get pointer to ROM data
LDR r1, =|Image
Base| ; and RAM copy
LDR r3, =|Image
Base|
;Zero init base => top of initialised data
CMP r0, r1 ; Check that they are different,判别RW是否需求移动
BEQ %F1
0
CMP r1, r3 ; Copy init data
LDRCC r2, [r0], #4 ;–> LDRCC r2, [r0] + ADD r0, r0, #4
STRCC r2, [r1], #4 ;–> STRCC r2, [r1] + ADD r1, r1, #4
BCC %B0
1
LDR r1, =|Image
Limit| ; Top of zero init segment
MOV r2, #0
2
CMP r3, r1 ; Zero init
STRCC r2, [r3], #4
BCC %B2
一切ARM的源代码都有必要在运用RW和ZI域之前运转