在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.