新聞中心

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

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

作者: 時(shí)間:2016-11-26 來(lái)源:網(wǎng)絡(luò) 收藏

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

為了證實(shí)后面跑的代碼是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,跳轉(zhuǎn)這樣寫:

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

通過(guò)兩種鏈接腳本的對(duì)比,這個(gè)vma lma,絕對(duì)跳轉(zhuǎn)的概念那應(yīng)該就很清楚了.太晚了,明天給出一個(gè)有意思的鏈接腳本.

今天晚上有時(shí)間,補(bǔ)充一個(gè)有點(diǎn)意思的鏈接腳本:

[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. }

編譯出來(lái)的二進(jìn)制文件會(huì)大很多,因?yàn)?text2段的LMA地址是2048.

bin檔大小為2184

arm-linux-readelf -a sram2sdram_elf,結(jié)果是:

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才行.

你應(yīng)該也發(fā)現(xiàn)了:2048+0x88 = 2184 這就是最后的bin檔大小

可以vi 最后的bin檔看一下, 輸入%!xxd后,效果如下:

從0x3f0到0x800都是0000,這一段都是gap.

既然是這樣,我們的拷貝代碼也只能拷貝sram中2048到4096這一部分就可以了.

有這三個(gè)linker script做對(duì)比,對(duì)linker script和代碼跳轉(zhuǎn)可以說(shuō)理解的比較透了.


上一頁(yè) 1 2 下一頁(yè)

關(guān)鍵詞: ARM匯編linkerscrip

評(píng)論


技術(shù)專區(qū)

關(guān)閉