UBOOT从NAND-FLASH启动分析.docVIP

  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文档。上传文档
查看更多
UBOOT从NAND FLASH启动分析 UBOOT从NAND FLASH启动分析 在分析启动代码之前先看一下S3C2440的NAND启动: 在配置NAND启动模式之后,S3C2440上电会先将NAND中的0x0 - 0x1000共4096字节的数据拷贝到位于Bank0中的Boot Internal SRAM上 Bank0如下图: 可以看出Boot Internal SRAM为4KB大小,也正是因为Boot Internal SRAM只有4KB大小,所以只能从NAND中拷贝4K的内容 = 3= 这个Boot Internal SRAM是配置为NAND FLASH启动模式才有的 这4K内容是什么呢?~ 这就要看Uboot的镜像文件中是如何进行连接的了~ 连接脚本在board/smdk2440/u-boot.lds中,如下 SECTIONS { . = 0 . = ALIGN(4); .text : { cpu/arm920t/start.o (.text) cpu/arm920t/s3c24x0/nand_read.o (.text) *(.text) } . = ALIGN(4); .rodata : { *(.rodata) } . = ALIGN(4); .data : { *(.data) } . = ALIGN(4); .got : { *(.got) } . = .; __u_boot_cmd_start = .; .u_boot_cmd : { *(.u_boot_cmd) } __u_boot_cmd_end = .; . = ALIGN(4); __bss_start = .; .bss : { *(.bss) } _end = .; } .text为代码段,可以看出cpu/arm920t/start.o在代码段的最前面,所以会先执行start.o中的代码 连接完成后的镜像文件的前4K如下 cpu/arm920t/start.o(.text) .text 0x33f80000 0x4e0 cpu/arm920t/start.o 0x33f80050 IRQ_STACK_START 0x33f80048 _bss_start 0x33f8004c _bss_end 0x33f80044 _armboot_start 0x33f80000 _start 0x33f80054 FIQ_STACK_START cpu/arm920t/s3c24x0/nand_read.o(.text) .text 0x33f804e0 0x1b8 cpu/arm920t/s3c24x0/nand_read.o 0x33f804e0 nand_read_ll *(.text) .text 0x33f80698 0x64 board/smdk2440/libsmdk2440.a(lowlevel_init.o) 0x33f8069c lowlevel_init .text 0x33f806fc 0x280 cpu/arm920t/libarm920t.a(interrupts.o) 0x33f80934 do_fiq 0x33f80880 do_undefined_instruction 0x33f80744 show_regs 0x33f80958 do_irq 0x33f80728 bad_mode 0x33f808c8 do_prefetch_abort 0x33f8070c disable_interrupts 0x33f80910 do_not_used 0x33f808ec do_data_abort 0x33f808a4 do_software_interrupt 0x33f806fc enable_interrupts .text 0x33f8097c 0x250 cpu/arm920t/s3c24x0/libs3c24x0.a(interrupts.o) 0x33f80aa4 set_timer 0x33f80a20 reset_timer 0x33f8097c interrupt_init 0x33f80ba0 get_tbclk 0x33f80a90 get_timer 0x33f809f0 reset_timer_masked 0x33f80a24 get_timer_masked 0x33f80ab4 udelay 0x33f80b10 udelay_masked 0x33f80bac reset_cpu 0x33f80b8c get_ticks .text 0x33f80bcc 0x150 cpu/arm920t/s3c24x0/libs3c24x0.a(speed.o) 0x33f80c

文档评论(0)

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

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

版权声明书
用户编号:7014141164000003

1亿VIP精品文档

相关文档