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