CBO.CLEAN 是否等价于 fence?
不是。CMO/预取有各自的缓存块语义,不提供通用内存排序替代。
缓存块 clean(Zicbom)。
CBO.CLEAN 是 Zicbom 缓存块管理指令,对 rs1 指定有效地址所在的缓存块执行 clean 操作:若该 coherent cache 集合中的副本被修改,则执行写传输,使 coherent agents 的存储对相关非 coherent agents 可见。缓存块大小由执行环境发现机制给出,不固定为 64 字节;汇编 offset 可省略,若写出则必须求值为 0。实现允许用 flush 代替 clean。
CBO.CLEAN 是 CMO 系列缓存块操作;它以有效地址定位缓存块,但语义不是普通 load/store。
结合 «cbo.clean 0(a1)» 等实际代码理解该场景。
结合 «cbo.clean 0(a1)» 等实际代码理解该场景。
结合 «cbo.clean 0(a1)» 等实际代码理解该场景。
不是。CMO/预取有各自的缓存块语义,不提供通用内存排序替代。
CBO 指令的 rs1 不要求按缓存块大小对齐。