关于2440启动代码的一点小疑问~!?

发布于 2022-09-06 02:30:13 字数 1354 浏览 13 评论 3

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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

南…巷孤猫 2022-09-19 04:56:41

楼主误解了大端小端的意义,arm下一条指令对应于32bit,32bit的MSB在最右边,大端小端下都一样的,大端小端影响的都是strb strh  ldrb ldrh 取数的值。

夜吻♂芭芘 2022-09-15 10:44:28

看看ld文件里面是怎么写的

星星的軌跡 2022-09-14 16:00:04

我想有可能前面还没有设置大端小端,所以代码是通用的。个人猜测,如果错了,希望lz不要被误导。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文