arm地址对齐的总结

static void axi_azx_writeb(u8 value, u8 __iomem *addr)

{

u32 data;

u32 offset;

offset = (u64)addr & 0x03; // 编译器不允许地址做& 操作时要强转为数据

addr = (u8 __iomem *)((u64)addr & 0xFFFFFFFFFFFFFFFC); // __iomem是个64位的地址 u8表示从这个地址取8位的数据(编译器是这么解释的)

data = readl(addr); //readl会把读到的数据强转为32位

//根据偏移写数据

data &= ~(0xFF << offset * BYTE_BIT_WIDTH);

data |= (value << offset * BYTE_BIT_WIDTH);

writel(data, addr);

}

地址对齐是规定(这个对齐不是c语言结构体的对齐) arm x86都需要,只不过看硬件来做还是软件来做,硬件做成本大一些

arm手册说指令对齐 实际上就是指令的地址对齐,如果硬件不对齐,软件也不做,cpu执行指令就会错

编译器会把单个变量做地址对齐

寄存器读写一般都是32位数据操作,小于32位(单、双字节对齐)的话都是先读写32

C语言定义一个变量int c 编译器会4字节对齐 如果定义8字节的变量就8字节对齐

相关推荐
一抹晴空6 小时前
Keil MDK AC6 compiler编译报错,与AC5区别
c语言·arm开发·单片机
运维成长记7 小时前
关于“有x86镜像,没有Dockerfile” 怎么制作arm架构的镜像
arm开发·架构
熠速14 小时前
PolarBox高性能实时仿真系统
arm开发·fpga开发·嵌入式实时数据库·硬件在环半实物仿真
天下·第二2 天前
如何在【x86】服务器上打包构建【arm】镜像
服务器·arm开发·eureka
止观止2 天前
在 WSL2 上从零搭建 ARM 混合编程环境
汇编·arm开发·嵌入式开发·混合编程
陌上花开缓缓归以2 天前
nand flash bbt和bmt管理
arm开发
小熊officer2 天前
AMD架构与ARM架构
arm开发·架构
_kerneler3 天前
arm虚拟机实时性优化总结
arm开发
口袋里のInit3 天前
基础知识——ARM M核入栈出栈流程
开发语言·arm开发
2035去旅行4 天前
WIFI传输带宽
arm开发·嵌入式硬件