免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3142 | 回复: 3
打印 上一主题 下一主题

关于2440启动代码的一点小疑问~!? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-01-24 20:26 |只看该作者 |倒序浏览
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不同,也就是内存的位宽不同,代码也会不同呢?
望高手回答~谢谢

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
2 [报告]
发表于 2011-01-25 15:53 |只看该作者
我想有可能前面还没有设置大端小端,所以代码是通用的。个人猜测,如果错了,希望lz不要被误导。

论坛徽章:
2
水瓶座
日期:2013-09-04 15:09:57白羊座
日期:2014-04-17 16:48:13
3 [报告]
发表于 2011-02-16 10:31 |只看该作者
看看ld文件里面是怎么写的

论坛徽章:
0
4 [报告]
发表于 2011-02-27 22:15 |只看该作者
楼主误解了大端小端的意义,arm下一条指令对应于32bit,32bit的MSB在最右边,大端小端下都一样的,大端小端影响的都是strb strh  ldrb ldrh 取数的值。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP