SSAMOSWAP.W 未启用相关 CFI 时会怎样?
Zicfiss 指令按官方 Zimop/Zcmop 兼容规则退化,不执行影子栈检查或更新。
SSAMOSWAP.W 对影子栈内存执行 AMO 风格交换,返回旧值并写入新值。
入门理解:SSAMOSWAP.W 从 rs1 指向的影子栈位置原子读取32 位字值写入 rd,并把 rs2 的对应宽度值写回原地址。它用于影子栈切换、检查点保存等需要保护 ssp 相关数据的场景。在 RV64 上读出的 32 位值会符号扩展到 rd。
SSAMOSWAP.W 属于 RISC-V CFI 相关指令;其行为受 Zicfilp/Zicfiss 是否启用以及相关环境配置控制。
使用 jal ra, label 或 jalr ra, rs, imm。
结合 «ssamoswap.w t0, t1, (t2)» 等实际代码理解该场景。
结合 «ssamoswap.w t0, t1, (t2)» 等实际代码理解该场景。
Zicfiss 指令按官方 Zimop/Zcmop 兼容规则退化,不执行影子栈检查或更新。
RISC-V 非特权 ISA 的 Control-flow Integrity 章节定义 LPAD、SSPUSH、SSPOPCHK、SSRDP 和 SSAMOSWAP。