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