ARM专题之字节对齐
来源:互联网 发布:讨鬼传2女生捏脸数据 编辑:程序博客网 时间:2024/06/06 01:35
什么叫字节对齐?
如果一个数据是以能被4 整除的地址开始的连续存储,那么它就是字对齐,否则就是非字对齐。举例说明四字节对齐:对内存进行操作时,被访问的地址必须为4的倍数。如果分配到的地址的地址不是4的倍数时,CPU实际访问的地址还是按照字对齐的方式来操作。
用ADS的ARM C Complier下Optimization Level可能引起问题,其中的一个问题就是字节对齐的问题。下面讲讲问题的现象及实质。
如果一个数据是以能被4 整除的地址开始的连续存储,那么它就是字对齐,否则就是非字对齐。举例说明四字节对齐:对内存进行操作时,被访问的地址必须为4的倍数。如果分配到的地址的地址不是4的倍数时,CPU实际访问的地址还是按照字对齐的方式来操作。
用ADS的ARM C Complier下Optimization Level可能引起问题,其中的一个问题就是字节对齐的问题。下面讲讲问题的现象及实质。
当时问题的现象是:程序使用一公共变量Buf创建队列,如果ADS编译优化选项采用Minium则软件工作正常;源码不变,如果采用ALL优化,则不正常,数据紊乱且无法工作。为了发现问题,我们分别用Minium和ALL编译,在反汇编条件下单步跟踪程序,观察CPU寄存器和内存变量的变化情况。
当内存起始地址为4字节对齐地址的情况时,编译器分配地址和实际地址一致,因此不存在上述问题。
结 论:
在ARM嵌入式系统中,当把一个内存区域初始化为某个结构体时,必须注意字节对齐的情况。如果该内存起始地址为非对齐地址,不仅得不到预期的结果,还可能导致一些很奇怪的让人无法理解表面问题。在C层面上不太容易观察到这些问题的实质,只有深入到汇编一层去分析程序,才可能理解这些现象的深层原因。
- ARM专题之字节对齐
- ARM之字节对齐
- C++ 字节对齐专题
- Q24Plus ARM 字节对齐
- arm的字节对齐问题
- ARM字节对齐问题详解
- ARM字节对齐问题详解
- arm c中字节对齐
- 关于arm 的字节对齐
- arm字节对齐与4字节对齐分析
- ARM平台的字节对齐问题
- 字节对齐---arm-linux-gcc和gcc
- ARM平台的字节对齐问题
- 字节对齐详解-----(二)ARM下的对齐处理
- ARM程序由于字节对齐引起的问题深入分析
- 近来准备研究一下arm的字节对齐问题
- ARM平台 结构体字节对齐引起的一个问题
- ARM程序由于字节对齐引起的问题深入分析
- Android JNI实例
- mini2440 nfs 挂载到ubuntu
- C++接口的设计和声明
- DNS负载均衡与负载均衡器两种方案的选择
- 用HTTP GET调用web service
- ARM专题之字节对齐
- 关于自增运算符++a和a++的问题
- QTP 循环执行巧设置
- HDU1200——字符串处理
- weather
- dbcp配置--官方文档中文版本
- Android JNI实例
- 使用CFE加载vxWorks
- 单例模式