AMOCAS.B 如何判断成功?
比较执行后的 rd 旧值与期望值;如果相同,说明交换写入发生。
原子比较并交换字节:若内存旧值等于 rd 低 8 位,则写入 rs2 低 8 位;rd 返回旧值
AMOCAS.B(Zacas 扩展)原子地加载 rs1 地址处的 8 位值,将加载值与 rd 的低 8 位比较;若按位相等,则把 rs2 的低 8 位写回原地址。无论比较是否成功,加载到的旧值都会符号扩展到 XLEN 后写入 rd。支持 aq/rl 内存序位。
AMOCAS.B 原子加载 8 位内存值,与输入 rd 中的比较值按位比较;相等时把 rs2 的交换值写回内存,并始终把旧内存值写回 rd。
结合 «amocas.b a0, a2, (a1)» 等实际代码理解该场景。
结合 «amocas.b a0, a2, (a1)» 等实际代码理解该场景。
比较执行后的 rd 旧值与期望值;如果相同,说明交换写入发生。
不是。rs2 提供成功时要写入的新值;比较值来自执行前的 rd(或寄存器对)。