SSRDP 未启用相关 CFI 时会怎样?
Zicfiss 指令按官方 Zimop/Zcmop 兼容规则退化,不执行影子栈检查或更新。
读取当前 ssp;未启用 Zicfiss 时按 Zimop 性质返回 0。
入门理解:SSRDP 用于运行时、异常展开或栈切换代码读取 ssp。若 Zicfiss 未启用,结果可为 0,因此软件常用它动态判断影子栈是否处于活动状态。
SSRDP 属于 RISC-V CFI 相关指令;其行为受 Zicfilp/Zicfiss 是否启用以及相关环境配置控制。
使用 jal ra, label 或 jalr ra, rs, imm。
结合 «ssrdp t0» 等实际代码理解该场景。
结合 «ssrdp t0» 等实际代码理解该场景。
结合 «ssrdp t0» 等实际代码理解该场景。
Zicfiss 指令按官方 Zimop/Zcmop 兼容规则退化,不执行影子栈检查或更新。
RISC-V 非特权 ISA 的 Control-flow Integrity 章节定义 LPAD、SSPUSH、SSPOPCHK、SSRDP 和 SSAMOSWAP。