关于2440启动代码的一点小疑问~!?
arm是支持大端存储的,但是系统复位时默认执行小端代码,因此需要在开始的几条语句中完成大小端的转换,在2440的启动代码中有下面一段:
__ENTRY
ResetEntry
;1)The code, which converts to Big-endian, should be in little endian code.
;2)The following little endian code will be compiled in Big-Endian mode.
; The code byte order should be changed as the memory bus width.
;3)The pseudo instruction,DCD can not be used here because the linker generates error.
ASSERT EF:ENDIAN_CHANGE
[ ENDIAN_CHANGE
ASSERT EF:ENTRY_BUS_WIDTH
[ ENTRY_BUS_WIDTH=32
b ChangeBigEndian ;DCD 0xea000007
]
[ ENTRY_BUS_WIDTH=16
andeq r14,r7,r0,lsl #20 ;DCD 0x0007ea00
]
[ ENTRY_BUS_WIDTH=8
streq r0,[r0,-r10,ror #1] ;DCD 0x070000ea
]
|
b ResetHandler
]
根据注释来看,如果用大端模式来编译代码,这段代码也必须是机器在复位时所能认识的小端模式的代码;也就是说在大端模式下编译出来的这几句指令同是也能够在小端模式下被CPU识别~!
我的问题是:
b ChangeBigEndian这句代码被大端模式编译以后也能在小端模式下运行吗?难道大端小端模式编译出来的机器码都是0xea000007吗?
还有为何ENTRY_BUS_WIDTH不同,也就是内存的位宽不同,代码也会不同呢?
望高手回答~谢谢
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
楼主误解了大端小端的意义,arm下一条指令对应于32bit,32bit的MSB在最右边,大端小端下都一样的,大端小端影响的都是strb strh ldrb ldrh 取数的值。
看看ld文件里面是怎么写的
我想有可能前面还没有设置大端小端,所以代码是通用的。个人猜测,如果错了,希望lz不要被误导。