当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]ARM采用的是32位架构,ARM的基本数据类型有以下3种。 Byte:字节,8bit。Halfword:半字,16bit。 Word:字,32bit。

3.1 数据类型3.1.1 ARM的基本数据类型

ARM采用的是32位架构,ARM的基本数据类型有以下3种。

· Byte:字节,8bit。

· Halfword:半字,16bit(半字必须于2字节边界对齐)。

· Word:字,32bit(字必须于4字节边界对齐)。

存储器可以看作是序号为0~232−1的线性字节阵列。图3.1所示为ARM存储器的组织结构。

图3.1 ARM存储器组织结构

图3.1所示为存储器的一小片区域,其中每一个字节都有惟一的地址。字节可以占用任一位置,图中给出了几个例子。长度为1个字的数据项占用一组4字节的位置,该位置开始于4的倍数的字节地址(地址最末两位为00)。图3.1中包含了3个这样的例子。半字占有两个字节的位置,该位置开始于偶数字节地址(地址最末一位为0)。

注意

① ARM系统结构v4以上版本支持以上3种数据类型,v4以前版本仅支持字节和字。

② 当将这些数据类型中的任意一种声明成unsigned类型时,N位数据值表示范围为0~2n−1的非负数,通常使用二进制格式。

③ 当将这些数据类型的任意一种声明成signed类型时,N位数据值表示范围为−2n−1~2n−1−1的整数,使用二进制的补码格式。

④ 所有数据类型指令的操作数都是字类型的,如“ADD r1,r0,#0x1”中的操作数“0x1”就是以字类型数据处理的。

⑤ Load/Store数据传输指令可以从存储器存取传输数据,这些数据可以是字节、半字、字。加载时自动进行字节或半字的零扩展或符号扩展。对应的指令分别为LDR/BSTRB(字节操作)、LDRH/STRH(半字操作)、LDR/STR(字操作)。详见后面的指令参考。

⑥ ARM指令编译后是4个字节(与字边界对齐)。Thumb指令编译后是2个字节(与半字边界对齐)。

3.1.2 浮点数据类型

浮点运算使用在ARM硬件指令集中未定义的数据类型。

尽管如此,但ARM公司在协处理器指令空间定义了一系列浮点指令。通常这些指令全部可以通过未定义指令异常(此异常收集所有硬件协处理器不接受的协处理器指令)在软件中实现,但是其中的一小部分也可以由浮点运算协处理器FPA10以硬件方式实现。

另外,ARM公司还提供了用C语言编写的浮点库作为ARM浮点指令集的替代方法(Thumb代码只能使用浮点指令集)。该库支持IEEE标准的单精度和双精度格式。C编译器有一个关键字标志来选择这个历程。它产生的代码与软件仿真(通过避免中断、译码和浮点指令仿真)相比既快又紧凑。

3.1.3 存储器大/小端

从软件角度看,内存相对于一个大的字节数组,其中每个数组元素(字节)都是可寻址的。

ARM支持大端模式(big-endian)和小端模式(little-endian)两种内存模式。

图3.2和图3.3分别显示了内存的大端模式和小端模式。

图3.2 大端模式

图3.3 小端模式

下面的例子显示了使用内存大/小端(big/little endian)的存取格式。

【例3.1】

程序执行前:

r0=0x11223344

执行指令:

r1=0x100

STR r0,[r1]

LDRB r2,[r1]

执行后:

小端模式下:r2=0x44

大端模式下:r2=0x11

上面的例子向我们提示了一个潜在的编程隐患。在大端模式下,一个字的高地址放的是数据的低位,而在小端模式下,数据的低位放在内存中的低地址。要小心对待存储器中一个字内字节的顺序。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

据《日经新闻》报道,软银旗下英国芯片制造商Arm计划到2025年销售AI芯片。该公司专门成立一个AI芯片部门,并将在2025年春季之前制造出原型产品,并于秋季开始大规模生产。

关键字: 软银 AGI ARM AI芯片

业内消息,近日日本软件银行集团(SoftBank Group)旗下安谋国际科技公司(Arm)计划研发人工智能(AI)芯片,先成立一个AI芯片部门,目标是明年春季建立AI芯片原型产品,然后将量产工作交由代工厂制造,预估20...

关键字: ARM AI芯片

双核心,出色安全性功能、内部堆栈DRAM、丰富的外围

关键字: 微处理器 DRAM 工业物联网

Arm CPU正在从根本上推动AI变革,并造福地球。Arm架构是未来AI计算的基石。​

关键字: ARM AI

近日,Arm推出了Arm® Ethos™-U85神经网络处理器(NPU)和Arm Corstone™-320物联网参考设计平台,旨在满足海量的数据处理和大规模计算,加速推进边缘AI的发展进程。

关键字: ARM

为了赶超云计算市场上的竞争对手,谷歌正试图通过定制的Arm服务器芯片降低云计算服务成本。

关键字: 谷歌 ARM 定制芯片

嵌入式开发作为一个融合了计算机软硬件和系统工程的综合性领域,其成功与否往往取决于三个核心要素的有效整合与协调。这三个要素分别是:硬件平台的选择与设计、软件开发及其优化、以及系统级的设计与集成。深入理解并熟练掌握这三个方面...

关键字: 嵌入式开发 ARM

随着汽车软件数量爆发式的增长,整个行业都需要重新思考汽车产品的开发流程。为此,Arm推出了丰富的硬件IP、新的系统IP,以及全新的汽车计算与计算子系统产品路线图,旨在为各种汽车应用实现性能、功能安全、可扩展等方面的支持。

关键字: ARM 汽车电子

知名移动芯片设计公司ARM最近迈出重要一步,它正式推出汽车芯片设计。ARM推出的芯片设计方案名叫Neoverse,随同芯片一起推出的还有面向汽车制造商、汽车供应商的新系统。

关键字: ARM 汽车芯片 芯片

双核心 Arm Cortex-A35、图形加速、高速连接能力,及内建硬件安全功能

关键字: 微处理器 电动车充电站 智能家居
关闭
关闭