您现在的位置: 主页 > 嵌入式处理器 > ARM > ARM微处理器的编程模型之:数据类型
本文所属标签:
为本文创立个标签吧:

ARM微处理器的编程模型之:数据类型

来源:网络整理 网络用户发布,如有版权联系网管删除 2018-08-12 

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

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)。

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]

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



              查看评论 回复



嵌入式交流网主页 > 嵌入式处理器 > ARM > ARM微处理器的编程模型之:数据类型
 模式 字节 指令

"ARM微处理器的编程模型之:数据类型"的相关文章

网站地图

围观()