它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
RV64C:压缩加载64位双字;RV32 Zclsd:压缩加载64位值到偶/奇寄存器对。
C.LDSP (CI格式,rd为全部32个寄存器,仅RV64C)从sp(x2)加零扩展偏移(×8)加载64位值到rd。展开为ld rd,offset(x2)。仅rd≠x0有效。
C.LDSP 是 压缩栈双字加载 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
结合 «c.ldsp x10, 16(sp) # x10 = *(sp+16)» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。