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

4870

被折叠的 条评论
为什么被折叠?



