ARM中字对齐和半字对齐,以及小尾模式

本文解释了Cortex-M3处理器中的小端模式,即低八位位于低地址,以及字和半字对齐的概念。ARM指令由于是32位的,导致存储地址需遵循字对齐规则,即能被4整除,而半字对齐则需能被2整除。

在Cortex-M3中,默认的小端模式,就是一个word型数据是32位,低八位存放在低地址中。同时也是小尾方式,也就是说,把低地址作为访问这个字的地址。

比如存放0x12345678在地址0x0000 00000 中,实际上会把0x78放在地址0x0000 0001处,把0x12放在地址0x0000 0004处。这样外部访问一个字的时候就可以 mov R0, [0x0000 0000],以字的低地址作为字的地址。

字对齐:即存储的地址相邻且可以被4整除,即最后两位是00。

半字对齐:即存储的地址相邻且可以被2整除,即最后一位是0。

因为ARM指令是32位的,所以存放的时候需要占用4个字节也就是4个地址。就比如有个地址存放指令是0x0000 0000,下一个指令就得是0x0000 0004。展开成32位地址表示最低的四位分别是0000b,0100b,这就是字对齐,最后两位是0,如果是八字节对齐,则最后的三位都是0.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值