ARM平台的地址对齐问题

发布者:bullfish最新更新时间:2016-07-01 来源: eefocus关键字:ARM平台  地址对齐 手机看文章 扫描二维码
随时随地手机看文章
前言
ARM流行已久,做嵌入式开发的不知道ARM不大可能。鉴于其所具备的较低功耗下的较高性能,也就成了大多数嵌入式设备的首选了。
不过对于刚上手的人来说,有可能会遇到一些稀奇古怪的问题。毕竟大部分人都习惯了IA-32下的程序设计,虽然两者都是32位的处理器,但是体系架构完全不同,于是也导致了一些隐含的问题。这里想描述一下一个有点蛊惑的问题,即在ARM上访问非对齐地址内容,会出现所谓“不可预料”结果的问题。
ARM内存访问的对齐问题
按照ARM文档上的描述,其访问规则如下:
1. 一次访问4字节内容,该内容的起始地址必须是4字节对齐的位置上;
2. 一次访问2字节内容,该内容的起始地址必须是2字节对齐的位置上;
(单字节的没有这个问题,就不用考虑啦。 )
好,既然规则如此,那应该遵守。不过么,不安分的人往往喜欢破坏规则,喜欢看看不遵守规则会有什么结果;另外么,即便遵规蹈距的人,有时也难免考虑不周,犯个错也是正常现象。好,那么让我们来看看犯错的结果吧。例如下面的代码:
char      buff[8] = {0x12, 0x34, 0x56, 0x78, 0x9a, 0xab, 0xbc, 0xcd};
int        v32, *p32;
short     v16, *p16;
p32 = (int*)&( buff[1] );     //unalignment
p16 = (short*)&( buff[1] );    //unalignment
v32 = *p32;    //what’s the result?
v16 = *p16;    //what’s the result?
如果上面这段代码在IA-32上运行,那么结果应该如下:
v32 = 0x9a785634
v16 = 0x5634
即便非对齐地址上访问,IA-32也就是牺牲一点性能,但是结果保证是正确的。恩,这也是我们所期望的……
可是…… 换到ARM上呢?我们来看看在ADS1.2编译后,执行的结果如下:
v32 = 0x12785634
v16 = 0x1234
这个结果有点奇怪了吧。照理说指向0x34,那么如果是Big-Endian的话,v32应该是0x3456789a,如果是Little-Endian的话,就是前面IA-32的结果。可现在的结果呢?两者都不是,莫名地把更低地址的0x12给凑进来了…… 而如果看看编译生成的汇编code的话,这两个赋值很简单,分别用了ldr和ldrsh指令,指令没有问题,分别用于读取32位和16位数据,都是最基本的指令。嗯,嗯,这就是我们所要描述的访问非对齐地址的问题了。
问题的缘由(个人猜测,非官方资料……)
个人感觉呢,这是ARM体系架构实现的问题,或者说这本来就是By Design的。这样做简化了处理器的实现,IA-32实现的时候肯定会对读取地址是否对齐进行判断,然后转换为相应的操作 ,而ARM呢?没有做这个事情,默认认为大家都按照规矩办事,你要是胆敢破坏,俺就给你好看~~~
那有没有办法解决呢?
这个问题其实ARM自己也知道,所以呢,它在编译器里面,已经添加了部分支持。不过有人会问,那上面那个情况呢?为什么结果还是不对呢?好像没有添加什么支持嘛……
嗯,其实ARM是做了一定的努力的,只是这个情况它没办法解决…… 它做的事情就是:在编译器能够的得知的情况下,尽量保证访问内容的正确。这句话有点笼统,那么把具体情况一个个来看看吧。
编译器的努力(1)—— 所有局部/全局/静态等变量都放在4字节对齐的地址上
其实这个努力很常见,由于在32位平台上,一次访问4字节是效率最高的,所以大多数32平台的编译器都如此处理,ARM的ADS也不例外。
编译器的努力(2)—— 填充、填充、再填充
这个事情么,其实也是常见的。各类编译器上,对于某些结构定义中会产生不对齐的情况,自动填充,以提高访问效率(例如IA-32上访问非对齐的,会加1个周期的)。而ARM的编译器也一样操作,不过感觉这里不单单是为了提高效率,也能够顺带解决这个不对齐的问题。
编译器的努力(3)—— 产生特殊代码
嗯,这个就是关键了,也是ARM编译器的与众不同之处。先来看一段代码:
__packed typedef struct _test
{
      char a;
      short c;
      int d;
} test;
char      buff[8] = {0x12, 0x34, 0x56, 0x78, 0x9a, 0xab, 0xbc, 0xcd};
test      *p = (test *)buff;
v32 =    p->d;     //这里的v32借用上面的定义;
貌似多了个限定为__packed的struct,以此来造成不对齐的状况,看不出多大区别嘛。可是运行一下的话,就会发现这里的结果是正确的。我们来看看ADS生成的汇编代码吧。
      v32 = q->d;
[0xe2890003]     add        r0,r9,#3
[0xeb000088]     bl         __rt_uread4
[0xe1a05000]     mov        r5,r0
看到这里的那条"bl         __rt_uread4"的指令了吧。对ARM指令有一定了解的都知道bl其实就是一个函数调用。所以,这里的代码其实是调用了ADS自己提供的__rt_uread4函数,该函数完成的操作就是读取四个字节。ADS提供了类似的一系列函数,针对signed/unsigned,以及4字节/2字节的读取/写入操作。
估计看到这里,大家会问,如果没有__packed限定符呢?猜对了,没有__packed限定符,那么编译器会对上面的情况pending,所以这个struct里面的d所在的位置是4字节对齐的(编译期信息,而非实际运行期信息)。所以就回到类似最初的例子了。
那么,还有一种情况,就是在有__packed的情况下,而struct里的字段都是符合对齐要求的,那么生成的代码会是怎么样的呢?从实际生成的代码来看,和上面的这段汇编代码,唯一的区别就是第一条指令把#3改成了#4,而后面仍旧调用__rt_uread4函数。嗯,这样结论就出来了:
编译器会在使用__packed的情况下,自动对其中的4字节/2字节访问添加特殊代码,以保证其结果的正确。
好了,这个关于这个问题描述得差不多了,可能的话,尽量倚赖编译器的这些功能,而对于编译器无能为力的部分,就要靠万分小心了……
p.s. 其实这里有很多事情可以来尽量预防此类问题,比如嵌入式项目往往喜欢自己管理内存分配,那么自己写的内存分配函数就保证返回的地址都是4字节对齐位置上的……
关键字:ARM平台  地址对齐 引用地址:ARM平台的地址对齐问题

上一篇:ARM平台的字节对齐问题
下一篇:ARM处理器结构

推荐阅读最新更新时间:2024-03-16 14:59

ARM发布业界最广泛的40纳米G物理IP平台
ARM公司近日宣布,开始向台积电的40纳米G制造工艺提供业界最完善的IP平台。这一ARM® 最新的、已通过流片验证的物理IP能够满足性能驱动消费产品的高成本效率开发;这些产品要求在不提高功耗的前提下提供先进的功能。这一平台是为那些期望使用40纳米工艺进行设计的开发者设计的,能够促进更高水平的技术创新,同时保持性能驱动消费产品的功耗水平。这些消费产品包括:磁盘驱动器、机顶盒、移动计算设备、网络应用、高清电视以及图形处理器。 通过多通道的逻辑库,ARM平台提供了非常高的灵活性。这些库包括高性能和高密度标准单元库,以及电源管理套件和ECO套件库扩展;后者主要用于解决亚微米设计中的漏电问题。所有的多通道长度库(length
[嵌入式]
一款基于ARM7的嵌入式实验平台设计
1 前 言 嵌入式系统是先进的计算机技术、半导体技术、电子技术与各个行业的具体应用相结合后的产物, 它是硬件与软件是紧密捆绑在一起的系统, 这一特点就决定了它必然是一个技术密集、高度分散、不断创新的知识集成系统。目前的嵌入式系统人才多数是在工作岗位上培养起来的, 国内高校还很少设立嵌入式系统这个本科专业, 只是为了适应社会的需要, 对某些专业的学生开设了相关课程, 学习。嵌入式系统设计是一门实践性非常强的课程, 其理论还在不断的发展当中, 如果没有很好的实践平台, 嵌入式系统技术很难掌握, 学生的技能就得不到提高, 培养的学生就不能适应市场的需要。 现有的一些嵌入式系统实验平台已经非常成熟,产品也覆盖了ARM7至A
[单片机]
一款基于<font color='red'>ARM</font>7的嵌入式实验<font color='red'>平台</font>设计
基于ARM7系列芯片嵌入式平台上实现的设计方案解析
系统防掉电设计的目的是:采用一种机制,使得系统在意外失去供电的情况下,可以保证系统运行状态的确定性以及记录数据的完整性;当系统供电恢复后,现场数据可以及时恢复,避免应用系统产生混乱。我们知道,在嵌入式系统设计与开发中越来越多地应用嵌入式操作系统。由于操作系统的引入,数据的读写往往是通过文件的方式完成,而不是直接对存储单元地址操作。用文件读写方式操作数据,在程序的运行过程中往往将数据暂存在易失性的存储空间,如SDRAM,一旦系统意外失电,这些数据往往被丢失。因此,当系统意外失电时必须采取一定的措施进行系统的掉电保护,以避免系统产生混乱。总的说来,防掉电程序的主要思路就是:产生掉电信号,捕捉掉电信号,处理掉电信号和数据以及现场状态
[单片机]
基于<font color='red'>ARM</font>7系列芯片嵌入式<font color='red'>平台</font>上实现的设计方案解析
ARM平台下无线网卡的配置
前言 看了下上次博客时间,大概是毕业后到目前两个多月了没有更新博客,突然发现自己正在变得越来越懒,这可不是一个好的征兆。除过找工作一个礼拜的时间,算起来已经工作了快2个月了,目前也正在试用期,对工作也慢慢有所适应。曾经在大学听老师说“上班后第一天、第一个礼拜、第一个月都是很难受的”,这次有所体会,慢慢的对周围各种事物熟悉下来也就不会觉得难受了。 ARM平台下无线网卡的配置和平时在windows或者linux下有点不太一样,对于热衷于window的朋友可能会觉得吃力,完全没有图像界面点击,只能靠一些命令来完成。刚好周末有时间,总结下这段时间调试无线网卡相关的操作。 网卡介绍 项目中暂时调试使用的无线网卡型号是:HLK-3M0
[单片机]
<font color='red'>ARM</font><font color='red'>平台</font>下无线网卡的配置
英特尔智能手机平台存隐忧 携手联想难抵ARM威胁
    英特尔在此次CES展上宣布推出专为智能手机和平板电脑打造的基于X86架构的低能耗芯片,并与联想合作推出首款智能手机K800,英特尔此次掘金移动互联网领域决心可见。     【IT商业新闻网讯】(记者 汪洋)“我们是三家餐馆,但各有特色。”英伟达CEO黄仁勋在2012CES上如此形容与英特尔和高通的竞合关系。      如其所言,英特尔处理器在大型企业、众多PC中依旧扮演着举足轻重的角色。但亦不可否认,更薄、能耗更低的移动处理器将成为未来移动互联市场致胜的关键。     IT商业新闻网获悉,英特尔在此次CES展上宣布推出专为智能手机和平板电脑打造的基于X86架构的低能耗芯片,并与联想合作推出首款智能手机K800,英特
[手机便携]
基于ARM7系列芯片嵌入式平台上实现的设计方案
系统防掉电设计的目的是:采用一种机制,使得系统在意外失去供电的情况下,可以保证系统运行状态的确定性以及记录数据的完整性;当系统供电恢复后,现场数据可以及时恢复,避免应用系统产生混乱。我们知道,在嵌入式系统设计与开发中越来越多地应用嵌入式操作系统。由于操作系统的引入,数据的读写往往是通过文件的方式完成,而不是直接对存储单元地址操作。用文件读写方式操作数据,在程序的运行过程中往往将数据暂存在易失性的存储空间,如SDRAM,一旦系统意外失电,这些数据往往被丢失。因此,当系统意外失电时必须采取一定的措施进行系统的掉电保护,以避免系统产生混乱。总的说来,防掉电程序的主要思路就是:产生掉电信号,捕捉掉电信号,处理掉电信号和数据以及现场状态的恢
[电源管理]
基于<font color='red'>ARM</font>7系列芯片嵌入式<font color='red'>平台</font>上实现的设计方案
安富利基于ARM mbed物联网平台,提供更强大的设计链增值服务
上海2016年11月1日 全球领先的技术分销商安富利公司 (NYSE: AVT)今日宣布,将采用ARM mbed 物联网平台进行物联网(IoT)参考方案设计。这将有助于提升安富利在IoT领域的创新设计能力,此服务面向亚洲市场,为客户提供更出色的设计链增值服务,并帮助供应商创造市场需求。 ARM mbed物联网平台提供了所有关键组件,通过 ARM 的 mbed 操作系统、mbed Cloud以及 mbed 开发者社区,简化了下一代IoT应用的开发与部署。借助该平台,安富利的开发人员可以获取ARM mbed 合作伙伴生态系统的广泛资源,包括全面的硬件开发工具包数据库、可重复使用的软件组件资源库、各种参考应用程序、说明文档以及网络开发工具
[物联网]
linux 2.6.32 在arm9(s3c2440)平台的移植2 -- Kconfig和Makefile(2)
make menuconfig后,首先读入linux-2.6.32.2/arch/arm/Kconfig ??? sudu vi linux-2.6.32.2/arch/arm/Kconfig (1)找到开头的mainmenu Linux Kernel Configuration source 这一行, 这是整个Configure树的根, 这一行匹配最后一个 带endmenu字样的行 .再找到init/Kconfig 这一行, 可以看到该行之前的都是固定选项,不会出现在Configure可选选项的, 某个config的例子如下 config CONFIG_SYMBOL tristate string 或者 bool
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved