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