AMOCAS.D 如何判断成功?
比较执行后的 rd 旧值与期望值;如果相同,说明交换写入发生。
原子比较并交换双字:比较内存旧值与 rd/寄存器对,匹配时写入 rs2/寄存器对;rd 返回旧值
AMOCAS.D(Zacas 扩展)原子地加载 rs1 地址处的 64 位双字并与比较操作数比较;匹配时写入交换操作数。RV64 中比较值来自 rd、交换值来自 rs2,旧值写回 rd。RV32 中比较值来自偶数 rd 与 rd+1 寄存器对,交换值来自偶数 rs2 与 rs2+1 寄存器对,旧值写回 rd/rd+1;奇数 rd 或 rs2 编码保留。支持 aq/rl 内存序位。
AMOCAS.D 原子加载 64 位内存值,与输入 rd 中的比较值按位比较;相等时把 rs2 的交换值写回内存,并始终把旧内存值写回 rd。
结合 «amocas.d a0, a2, (a1)» 等实际代码理解该场景。
结合 «amocas.d a0, a2, (a1)» 等实际代码理解该场景。
比较执行后的 rd 旧值与期望值;如果相同,说明交换写入发生。
不是。rs2 提供成功时要写入的新值;比较值来自执行前的 rd(或寄存器对)。