ARM之字节对齐

什么叫字节对齐?

如果一个数据是以能被4 整除的地址开始连续存储,那么它就是字对齐,否则就是非字对齐。举例说明四字节对齐:对内存进行操作时,被访问的地址必须为4的倍数。如果分配到的地址不是4的倍数时,CPU实际访问的地址还是按照字对齐的方式来操作。

用ADS的ARM C Complier下Optimization Level可能引起问题,其中的一个问题就是字节对齐的问题。下面讲讲问题的现象及实质。

       当时问题的现象是:程序使用一公共变量Buf创建队列,如果ADS编译优化选项采用Minium则软件工作正常;源码不变,如果采用ALL优化,则不正常,数据紊乱且无法工作。为了发现问题,我们分别用Minium和ALL编译,在反汇编条件下单步跟踪程序,观察CPU寄存器和内存变量的变化情况。

当内存起始地址为4字节对齐的情况时,编译器分配地址和实际地址一致,因此不存在上述问题。

结 论:

         ARM嵌入式系统中,当把一个内存区域初始化为某个结构体时,必须注意字节对齐的情况。如果该内存起始地址为非对齐地址,不仅得不到预期的结果,还可能导致一些很奇怪的让人无法理解表面问题。在C层面上不太容易观察到这些问题的实质,只有深入到汇编一层去分析程序,才可能理解这些现象的深层原因。

 

详细可见:http://blog.chinaunix.net/uid-21354120-id-1827467.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ARM64 架构中,内存对齐方式与其它架构类似,但由于 ARM64 架构采用的是 Little-Endian 字节序,因此在计算偏移量时需要注意字节序的影响。 ARM64 架构中,基本数据类型的对齐方式如下: | 类型 | 对齐方式 | | ----------- | -------- | | `int8_t` | 1 字节 | | `int16_t` | 2 字节 | | `int32_t` | 4 字节 | | `int64_t` | 8 字节 | | `float` | 4 字节 | | `double` | 8 字节 | | 指针类型 | 8 字节 | | 结构体类型 | 最大成员变量对齐方式的整数倍 | | 枚举类型 | 枚举类型基础类型的对齐方式 | 需要注意的是,ARM64 架构中结构体的对齐方式与其最大成员变量的对齐方式有关。如果结构体的最大成员变量的对齐方式小于等于 8 字节,则结构体对齐方式为最大成员变量的对齐方式;否则,结构体对齐方式为 8 字节。 在计算结构体成员变量的偏移量时,也需要注意字节序的影响。在 ARM64 架构中,字节序为 Little-Endian,即低位字节存储在低地址处,高位字节存储在高地址处。因此,在计算偏移量时,需要将成员变量的位置与结构体的起始地址相加,并根据成员变量的类型、字节序等因素进行相应的字节顺序转换。 需要注意的是,由于 ARM64 架构采用的是 64 位地址空间,因此在 ARM64 架构下,指针类型的变量占据 8 个字节。在计算指针类型变量的偏移量时,也需要按照 8 字节对齐
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值