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

相关推荐

  1. arm地址对齐总结

    2024-03-22 11:54:04       42 阅读
  2. 总结:IP地址、网络地址与子网掩码理解

    2024-03-22 11:54:04       38 阅读
  3. openssl源文件下载地址arm交叉编译arm32位

    2024-03-22 11:54:04       39 阅读
  4. ARMCI-700和ArterisNoC对比

    2024-03-22 11:54:04       41 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-22 11:54:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-22 11:54:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-03-22 11:54:04       87 阅读
  4. Python语言-面向对象

    2024-03-22 11:54:04       96 阅读

热门阅读

  1. 微服务配置nacos

    2024-03-22 11:54:04       42 阅读
  2. 新手如何入门电子电路

    2024-03-22 11:54:04       48 阅读
  3. UnityShader(十七)透明效果

    2024-03-22 11:54:04       40 阅读
  4. 深入理解浏览器的页面渲染机制

    2024-03-22 11:54:04       45 阅读
  5. 【wpf 应用6】基本控件-Label的详解与示例

    2024-03-22 11:54:04       45 阅读
  6. 光模块概述

    2024-03-22 11:54:04       42 阅读
  7. ngnix负载均衡

    2024-03-22 11:54:04       44 阅读
  8. 40 道高频 C++ 面试、笔试题及答案

    2024-03-22 11:54:04       42 阅读