AT91BootStrap_Nandflash引导代码分析.pdfVIP

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

AT91BootStrap-Nandflash 引导代码分析 1. 程序的各个段在/elf32-littlearm.lds 中定义,入口为reset,包含text, dummy, data, bss 段。 . = ALIGN(4); .text : { _stext = .; *(.text) *(.rodata) /* read-only data (constants) */ *(.rodata*) . = ALIGN(4); *(.glue_7) . = ALIGN(4); *(.eh_frame) . = ALIGN(4); _etext = . ; } /* 需要初始化的数据段 collect all initialized .data sections */ /* .data : AT ( ADDR (.text) + SIZEOF (.text) SIZEOF (.ARM.*) { */ . = ALIGN(4); .dummy : { _edummy = .; } .data : AT (LOADADDR(.dummy)) { _sdata = .; *(.vectors) *(.data) _edata = .; } /* 不需要初始化的数据段 collect all uninitialized .bss sections */ .bss (NOLOAD) : { . = ALIGN(4); _sbss = .; *(.bss) _ebss = .; } 2. /crt0_gnu.S,第一阶段初始化,汇编代码 reset: /* 程序入口 */ _exception_vectors: /* 异常向量表,必须放置跳转指令,使得芯片检测为有效代码 */ b reset_vector /* reset */ b undef_vector /* Undefined Instruction */ b swi_vector /* Software Interrupt */ b pabt_vector /* Prefetch Abort */ b dabt_vector /* Data Abort */ .word _edata /* 文件大小,SAM-BA 以此校验程序Size of the image for SAM-BA */ b irq_vector /* IRQ : read the AIC */ b fiq_vector /* FIQ */ … reset_vector: /* 初始化堆栈 */ _init_stack: /* TOP_OF_MEMORY 在/board/ at91sam9x5ek /at91sam9x5nf_defconfig 中定义 CONFIG_TOP_OF_MEMORY=0x308000,即内部32K RAM 的末尾 */ ldr sp,=TOP_OF_MEMORY /* 执行时钟初始化,函数在/driver/pmc.c 中实现 */ ldr r4, =lowlevel_clock_init mov lr, pc bx r4 /* 拷贝数据段到内存的指定位置中Copy the data section in RAM at .data link address */ _init_data: /* 从_lp_data 读入内存地址分配, _lp_data 在文件末尾定义如下 _lp_data:

文档评论(0)

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

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

1亿VIP精品文档

相关文档