它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
将零扩展非零立即数(缩放4)加到sp,结果写入rd'。CIW格式。
C.ADDI4SPN (CIW格式)将零扩展非零立即数(乘以4)加到sp(x2),结果写入rd'(仅x8-x15)。展开为addi rd',x2,nzuimm[9:2]。仅nzuimm≠0时有效。用于生成栈变量指针。
C.ADDI4SPN 是 压缩 sp 非零立即数加法 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
使用 jal ra, label 或 jalr ra, rs, imm。
结合 «c.addi4spn x8, 16 # x8 = sp+16» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。