ARM编程模型-内存空间和数据

ARM属于RISC体系,许多指令单周期指令,是32位读取/存储架构,对内存访问是32位,Load and store的架构,只有寄存器对内存,不能内存对内存存储,CPU通过寄存器对内存进行读写操作。

ARM的寻址空间是线性地址空间,典型的32位地址下,空间大小为232 = 4G.

注:X86 寻址是段+偏移量

1.数据类型

字节类型(Byte):数据宽度为8bits

半字节类型(Halfword):数据宽度为16bits,存取时一般要求为2字节对齐。

字数据类型(Word):数据宽度为32bits,存取时一般要求4字节对齐

2.数据对齐

在V6架构之前,数据访问都必须针对要访问的大小把访问的地址进行对齐,没有对齐的地址将会导致出现"数据中止"异常(在数据存取或指令预取时都可能出现)。

没有对齐的地址数据可以通过多个对齐地址数据以为/掩码操作来实现。

ARM V6架构添加了新的硬件来支持未对齐的数据访问。

3.数据存储的大小端问题

大小端问题时指数据在计算机内存中的字节顺序问题,它决定了寄存器的内容和内存内容的格式关联。

ARM寄存器时字宽,就是4字节。而内存寻址是按照字节顺序的。

采用大端方式符合人类的正常思维,小端方式有利于计算机处理,无优劣之分。

ARM支持大端(Big-endian)和小端(Little-endian)的内存数据方式,可以通过硬件的方式设置端模式,也可以通过软件的方式来设置(V6版本以上)

大端格式(Big-endian)

最低地址是该数据的地址(A)

最高有效字节(MSB, Most Signifcant Byte) 放内存低地址(A)

最低有效字节(LSB,Least Significant Byte)放内存高地址(A+3)

小端格式(Little-endian)

最低地址是该数据的地址(A)

最高有效字节(MSB, Most Signifcant Byte) 放内存高地址(A+3)

最低有效字节(LSB,Least Significant Byte)放内存低地址(A)

大小端具体实例

变量A:Word A = 0x f6 73 4b cd,在内存中的起始地址为0xb3 20 45 00

变量B:half word B= 218,在内存中的起始地址为0x dd dd dd d0

相关推荐
Q_21932764552 小时前
基于ARM的嵌入式温度控制系统的设计
arm开发
想你依然心痛7 小时前
从x86到ARM的HPC之旅:鲲鹏开发工具链(编译器+数学库+MPI)上手与实战
java·开发语言·arm开发·鲲鹏·昇腾
MUTA️7 小时前
x86 架构下运行 ARM-ROS2 Docker 镜像操作指南
arm开发·docker·架构
比奇堡派星星1 天前
Linux 杂项设备驱动框架详解
linux·arm开发·驱动开发
xingzhemengyou11 天前
LINUX 通过/proc/interrupts了解系统硬件中断的使用情况
linux·arm开发
rfidunion1 天前
ubuntu下使用qemu模拟ARM(一)-------安装samba服务器
服务器·arm开发·ubuntu
三佛科技-134163842121 天前
FT32F072xx、FT32F072xB、FT32F072x6/x8基于ARM Cortex-M0内核32位单片机分析
arm开发·单片机·嵌入式硬件·智能家居·pcb工艺
p66666666681 天前
STM32(基于 ARM Cortex-M 内核)中函数调用栈帧的开辟 销毁过程
arm开发·stm32·嵌入式硬件
星空真迷人2 天前
嵌入式 WiFi 加持 普通设备也能联网 “唠嗑”
arm开发·stm32·单片机·嵌入式硬件·物联网·iot
灵哎惹,凌沃敏3 天前
FreeRTOS 任务上下文切换核心函数:xPortPendSVHandler详解
c语言·arm开发