CBO.INVAL 是否等价于 fence?
不是。CMO/预取有各自的缓存块语义,不提供通用内存排序替代。
缓存块 invalidate(Zicbom)。
CBO.INVAL 是 Zicbom 缓存块管理指令,对 rs1 指定地址所在的缓存块执行 invalidate 操作;根据 CSR 编程,低特权执行时可陷入或被转换为 flush。rs1 不要求按缓存块大小对齐;发生故障时故障虚拟地址按 rs1 的值报告。缓存块大小由执行环境发现机制给出,不固定为 64 字节;offset 可省略,若写出必须为 0。
CBO.INVAL 是 CMO 系列缓存块操作;它以有效地址定位缓存块,但语义不是普通 load/store。
结合 «cbo.inval 0(a1)» 等实际代码理解该场景。
结合 «cbo.inval 0(a1)» 等实际代码理解该场景。
结合 «cbo.inval 0(a1)» 等实际代码理解该场景。
不是。CMO/预取有各自的缓存块语义,不提供通用内存排序替代。
CBO 指令的 rs1 不要求按缓存块大小对齐。