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