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字节对齐

相关推荐
AndyHeee5 天前
【SVC、PendSV(系统异常) 与 外设 IRQ 、NVIC笔记】
arm开发
暮云星影5 天前
瑞芯微rk3588利用Rockchip NPU运行大语言模型(LLM)
arm开发·人工智能·语言模型·自然语言处理
techdashen5 天前
绕过系统 ICMP:用 rawsock、Npcap 和 WMI 找到默认网卡
开发语言·arm开发·rust
振南的单片机世界6 天前
ARM中断比51快在哪?硬件压栈+NVIC集中管理
arm开发·stm32·单片机·嵌入式硬件
墨绿色的摆渡人6 天前
论文笔记(一百三十七)Learning Dual-Arm Push and Grasp Synergy in Dense Clutter
arm开发·论文阅读
暮云星影6 天前
全志linux开发屏幕适配(一)屏幕参数设置说明
linux·arm开发
m0_547486666 天前
《ARM Cortex-M4嵌入式应用技术——基于STM32F407、STM32CubeMX与Proteus》全套PPT课件
arm开发·stm32·proteus
Lanceli_van6 天前
SQLite 3.45.2(sqlite-autoconf-3450200)ARM 交叉编译完整步骤
arm开发·sqlite
暮云星影6 天前
全志linux开发屏幕适配(二)`HDMI`驱动适配说明
linux·arm开发·驱动开发
暮云星影6 天前
瑞芯微rk3566开发FIT Secure Boot
linux·arm开发·驱动开发·安全