tq2440从nand启动及位置无关码的理…

如果从nand启动,s3c2440会自动将nand中的前4kb内容拷贝到steppingstone 中运行(soc集成的大小为4kb的ram),所以nand的前4kb的内容必须是进行一些硬件初始化以及将nand中的关于bootloader的代码拷贝到sdram中执行。
下面结合u-boot-1.1.6的start.s 来分析:
_start: b       reset
    这是第一条执行的指令,b属于位置无关码指令:意思就是说即使程序代码没有被拷在链接是的地址时也能执行的代码,这是因为b 加的后面的是标号reset与当前地址的相对地址而不是绝对地址,这跟x86汇编的偏移地址很相像。
如果第一条执行的是位置相关关码,根据链接脚本,在链接u-boot的时候,默认是运行地址是0x33f80000(-Ttext 0x33f80000),而从nand启动,前4kb被拷贝steppingstone中运行,其地址为0x00000000,所以将会运行不了,因为0x33f80000是sdram此时该地址还没有内容。

使用LDR 伪指令将一个常量读取到非PC 的其他通用寄存器中可实现位置无关的常量访问;但将一个地址值读取到PC 中进行程序跳转时,跳转目标则是位置相关的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值