ARM链接脚本.docVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ARM链接脚本

ARM链接脚本 链接脚本: ================= 什么是链接脚本,就是用于告诉链接器如何把输入文件内的各个段(section)放到输出文件中,并控制输出文件中的各个段在此程序运行时的地址空间布局。一个程序由多个段组成,那么这些段是如何在文件中存放的,以及是如何加载到内存的相应位置进行执行的呢,这个就是通过连接脚本进行控制的。 链接脚本格式: 链接脚本由一系列命令组成,每一个命令由一个关键字和相应的参数,或者一些赋值语句等组成。命令由分号进行分割。用/* */进行注释。 常见命令: ENTRY(SYMBOL);将SYMBOL的值设置成入口地址。一般设置为_start。 OUTPUT(FILENAME); 定义输出文件的名字。可以用它来指定默认的输出文件名称。当然我们一般都用手动-o进行指定,如果我们没有进行手动指定的话,输出文件名称就以这个FILENAME为输出文件名。 STARTUP(filename);指定filename为第一个输入文件。 OUTPUT_FORMAT(default, big, little);定义3种输出文件的格式。若有命令行选项-EB(大端),则使用第二个输出格式,有命令行指定-EL(小端),则使用第三个格式。否则使用默认的default输出格式。 OUT_ARCH(arch);设置输出文件的体系架构。 SECTIONS命令:最重要的,最基本的,也是最主要的命令,它告诉链接器如何把输入文件的各个section输出到目标文件中的各个section中去。 SECTIONS命令的格式如下: SECTIONS { 一条或者多条section-command 或者符号赋值语句 } section-command的常见格式如下: secname [address] : [AT(LMA)] { contents } 首先中括号的选项是可选的,可以不写。 secname, 指定输出的段名称。 address, 表示程序的VMA地址。也就是表示当执行此程序的时候程序加载器应该把这个段加载到内存的哪个地址。如果没有指定这个地址,链接器根据定位符号‘.‘的值设置该section的VMA。 AT, 后面跟LMA, 这个是表示当我们把目标文件拷贝成二进制的时候,该段在文件中物理存放位置的偏移。这个可以用来把多个不同的部分的代码写到一个文件中,然后烧写到flash上去,然后,程序在运行的时候再把它从AT指定的位置读到内存的另外一个位置上去。 contents,内容里面指定把哪些文件里面的哪些段或者该文件全部输出到secname所指定的这个段中。比如*(.text)就表示所有输入文件的.text段。括号外面表示文件名称,括号里面表示这些文件里面的什么段。 例子: SECTIONS { . = 0 //表示设置当前符号的值为0x3000000 .text : { *(.text) } //表示把所有输入文件的代码段集合在一起,起始运行地址就为当前定位符号的值,-- 0 .rodata ALIGN(4) : { *(.rodata) } // 在输出文件中它紧挨着.text段存放。 } 常见的例子: (1): ENTRY(_start); OUTPUT_FORMAT(elf32-littlearm, elf32-bigarm, elf32-littlearm); OUTPUT_ARCH(arm); SECTIONS { . = 0 . = ALIGN(4); .text : { *(.text); } . = ALIGN(4); .rodata : { *(.rodata); } . = ALIGN(4); .data : { *(.data); } . = ALIGN(4); .bss : { *(.bss); } } 这个链接脚本表示代码段从0始加载,然后后面的.rodata,.data,.bss段都分别加在其后,并且后面的每个段的起始地址是按照4个字节对齐的。 (2): ENTRY(_start); OUTPUT_FORMAT(elf32-l

文档评论(0)

jgx3536 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:6111134150000003

1亿VIP精品文档

相关文档