GNU ARM匯編--(十三)GNU ARM匯編下的linker script
- ldrpc,=on_sdram
- n_sdram:
- blclearsram
為了證實后面跑的代碼是sdram中的,在跳到sdram后將sram都清除了.
2.
- OUTPUT_FORMAT("elf32-littlearm","elf32-littlearm","elf32-littlearm")
- OUTPUT_ARCH(arm)
- ENTRY(_start)
- SECTIONS{
- .=0x00000000;
- .textALIGN(4):{*(.text)}
- .rodataALIGN(4):{*(.rodata)}
- .dataALIGN(4):{*(.data)}
- .bssALIGN(4):{*(.bss)*(COMMON)}
- }
vma的地址用的是0x00000000,跳轉這樣寫:
- ldrr0,=on_sdram
- addr0,r0,#0x30000000
- movpc,r0
- n_sdram:
- blclearsram
通過兩種鏈接腳本的對比,這個vma lma,絕對跳轉的概念那應該就很清楚了.太晚了,明天給出一個有意思的鏈接腳本.
今天晚上有時間,補充一個有點意思的鏈接腳本:
- OUTPUT_FORMAT("elf32-littlearm","elf32-littlearm","elf32-littlearm")
- OUTPUT_ARCH(arm)
- ENTRY(_start)
- SECTIONS{
- .text10x00000000:
- {
- start.o(.text)
- }
- .text20x30000000:AT(2048)
- {
- main.o(.text)
- }
- }
編譯出來的二進制文件會大很多,因為.text2段的LMA地址是2048.
bin檔大小為2184
arm-linux-readelf -a sram2sdram_elf,結果是:
Program Headers:
Type Offset VirtAddr PhysAddr FileSiz MemSiz Flg Align
LOAD 0x008000 0x00000000 0x00000000 0x003f0 0x003f0 R E 0x8000
LOAD 0x010000 0x30000000 0x00000800 0x00088 0x00088 R E 0x8000
Section to Segment mapping:
Segment Sections...
00 .text1
01 .text2
第二段.text2的大小是0x88,而.text1的大小是ox3f0,必須要小于2048才行.
你應該也發(fā)現(xiàn)了:2048+0x88 = 2184 這就是最后的bin檔大小
可以vi 最后的bin檔看一下, 輸入%!xxd后,效果如下:
從0x3f0到0x800都是0000,這一段都是gap.
既然是這樣,我們的拷貝代碼也只能拷貝sram中2048到4096這一部分就可以了.
有這三個linker script做對比,對linker script和代碼跳轉可以說理解的比較透了.
評論