野火电子论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

查看: 7124|回复: 1

[求助] uboot前4K代码,为什么有的代码超过了4K的范围还能运行

[复制链接]
回帖奖励 3 火花 回复本帖可获得 3 火花奖励! 每人限 1 次
发表于 2021-10-24 10:24:35 | 显示全部楼层 |阅读模式
根据手册当选择SD卡启动时,bootRom会把SD卡的前 4K 数据读入到芯片内部 RAM 运行,然后在 arch\arm\lib\crt0.S 中的 relocate_code 函数会把整个uboot.imx搬运到外部的DDR中。我在分析uboot的 board_init_f 函数时,使用反汇编工具
  1. arm-buildroot-linux-gnueabihf-objdump -S u-boot > dumpview.txt
复制代码

  查看反汇编代码,发现有的代码不是在4K的范围内,这样运行为什么不会出错呢?不应该是在 relocate_code 执行之前只能运行前4K的部分吗?

例如 display_options 函数位于 0x87842a70位置,text段的起始位置为0x87800000,这两个差大于了4K(0x1000)的范围了。


display_options 函数中优调用了 printf 函数,printf 函数的地址在 0x87845468 位置,也超出了 4K 的范围了。



回复

使用道具 举报

 楼主| 发表于 2021-10-25 13:22:16 | 显示全部楼层
自问自答一下,原来是我自己理解错了,上电后boot ROM拷贝的不是4k内容不是代码,而是 IVT+BootData+DCD。boot Rom中的程序会利用这些配置信息,完成初始化时钟,初始化DDR,然后将整个uboot文件加载到外部的DDR中,最后跳转到外部的DDR中去执行程序。relocate_code 部分的代码将 uboot 从DDR内存的低地址拷贝到高地址去运行,低地址后面存放的是内核的镜像
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

联系站长|手机版|野火电子官网|野火淘宝店铺|野火电子论坛 ( 粤ICP备14069197号 ) 大学生ARM嵌入式2群

GMT+8, 2024-5-4 22:23 , Processed in 0.029045 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表