Linux arm cache 入门

  1. ARM 架构下 Cache 的基本概念
  • Cache 层级:L1 I-Cache、L1 D-Cache、L2(统一 Cache),部分 SoC 还有 L3

  • Cache 特性:写分配 / 非写分配,写回(write-back)/ 写直达(write-through)

  • 一致性问题:SMP 多核下的 Cache 一致性协议(MESI/MOESI 思路)

  • ARM 内存 域划分:Normal memory vs Device memory


  1. ARM Cache 维护指令族

ARMv8/v7 都提供了一组专门的 cache maintenance instructions,在内核驱动和系统软件里很常见。

指令分类

  • I-Cache(指令 Cache)相关

    • IC IVAU:Invalidate I-Cache by VA to PoU

    • IC IALLUIS:Invalidate all I-Cache inner shareable

    • IC IALLU:Invalidate all I-Cache (non-shareable)

  • D-Cache(数据 Cache)相关

    • DC CIVAC:Clean & Invalidate D-Cache line by VA to PoC

    • DC CVAC:Clean D-Cache line by VA to PoC

    • DC IVAC:Invalidate D-Cache line by VA to PoC

    • DC ZVA:Zero a cache line by VA

    • DC CVAU:Clean D-Cache line by VA to PoU

关键参数

  • PoU (Point of Unification)

    • 指指令流和数据流统一的位置,通常是 I-Cache 之前的层级。

    • 比如写代码到内存后,需要清到 PoU,确保 I-Cache 能看到。

  • PoC (Point of Coherency)

    • 体系保证所有 master 观察到一致性的点。

    • 通常是 L2 Cache 出口到内存的接口。

  • PoP (Point of Persistence)

    • 数据被写入"持久存储"的点(比如 NVM、持久内存系统)。

    • 在 ARMv8.2+ 中提出,和持久化内存相关。

使用场景举例

  • 代码自修改 / 动态加载代码:先写 D-Cache,再清到 PoU,最后无效 I-Cache。

  • DMA 缓冲区:CPU 和外设共享内存时,需要 Clean / Invalidate 到 PoC。


  1. Linux 内核中的 Cache 操作接口

内核提供的 API

在 Linux 内核(arch/arm64/include/asm/cacheflush.h)中常见的接口有:

高层 API

  • dma_map_single() / dma_unmap_single()

    • 用于驱动中确保 DMA 缓冲区 Cache 与内存一致
  • dma_sync_single_for_device() / dma_sync_single_for_cpu()

    • 针对 CPU/设备交替访问的场景

dma摸之前clean,cpu摸之前inv

相关推荐
jun_bai10 小时前
python写的文件备份网盘程序
运维·服务器·网络
HIT_Weston11 小时前
39、【Ubuntu】【远程开发】拉出内网 Web 服务:构建静态网页(二)
linux·前端·ubuntu
欢喜躲在眉梢里11 小时前
CANN 异构计算架构实操指南:从环境部署到 AI 任务加速全流程
运维·服务器·人工智能·ai·架构·计算
weixin_5377658012 小时前
【容器技术】虚拟化原理与Docker详解
运维·docker·容器
胡斌附体12 小时前
docker健康检查使用
运维·docker·依赖·健康检查
云飞云共享云桌面12 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张12 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
TH_112 小时前
腾讯云-(3)-Linux宝塔面板使用
linux·云计算·腾讯云
虚伪的空想家13 小时前
arm架构服务器使用kvm创建虚机报错,romfile “efi-virtio.rom“ is empty
linux·运维·服务器·javascript·arm开发·云原生·kvm
火车头-11013 小时前
【docker 部署nacos1.4.7】
运维·docker·容器