新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > GNU ARM匯編--(十三)GNU ARM匯編下的linker script

GNU ARM匯編--(十三)GNU ARM匯編下的linker script

作者: 時間:2016-11-26 來源:網(wǎng)絡 收藏

[cpp]view plaincopy
  1. ldrpc,=on_sdram
  2. n_sdram:
  3. blclearsram

為了證實后面跑的代碼是sdram中的,在跳到sdram后將sram都清除了.

2.

[cpp]view plaincopy
  1. OUTPUT_FORMAT("elf32-littlearm","elf32-littlearm","elf32-littlearm")
  2. OUTPUT_ARCH(arm)
  3. ENTRY(_start)
  4. SECTIONS{
  5. .=0x00000000;
  6. .textALIGN(4):{*(.text)}
  7. .rodataALIGN(4):{*(.rodata)}
  8. .dataALIGN(4):{*(.data)}
  9. .bssALIGN(4):{*(.bss)*(COMMON)}
  10. }
[cpp]view plaincopy

vma的地址用的是0x00000000,跳轉這樣寫:

[cpp]view plaincopy
  1. ldrr0,=on_sdram
  2. addr0,r0,#0x30000000
  3. movpc,r0
  4. n_sdram:
  5. blclearsram

通過兩種鏈接腳本的對比,這個vma lma,絕對跳轉的概念那應該就很清楚了.太晚了,明天給出一個有意思的鏈接腳本.

今天晚上有時間,補充一個有點意思的鏈接腳本:

[cpp]view plaincopy
  1. OUTPUT_FORMAT("elf32-littlearm","elf32-littlearm","elf32-littlearm")
  2. OUTPUT_ARCH(arm)
  3. ENTRY(_start)
  4. SECTIONS{
  5. .text10x00000000:
  6. {
  7. start.o(.text)
  8. }
  9. .text20x30000000:AT(2048)
  10. {
  11. main.o(.text)
  12. }
  13. }

編譯出來的二進制文件會大很多,因為.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和代碼跳轉可以說理解的比較透了.


上一頁 1 2 下一頁

關鍵詞: ARM匯編linkerscrip

評論


技術專區(qū)

關閉