它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
将有符号6位立即数加到rd(32位结果再符号扩展)。CI格式,RV64C。
C.ADDIW (CI格式,仅RV64)将6位符号扩展立即数加到rd后取低32位符号扩展到64位写入rd。展开为addiw rd,rd,imm。imm=0时等同于sext.w rd。仅rd≠x0有效。
C.ADDIW 是 压缩 32 位立即数加法 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
结合 «c.addiw x10, 5 # x10 = sext_w(x10+5)» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。