它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
将6位立即数(缩放16倍)加到栈指针。CI格式,与C.LUI共享操作码。
C.ADDI16SP 是 C.ADDI 的栈指针专用形式,将非零、按 16 字节缩放编码的有符号立即数加到 x2/sp。有效立即数范围为 -512 到 +496,且 nzimm 不得为 0。
C.ADDI16SP 是 压缩栈指针立即数加法 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
使用 jal ra, label 或 jalr ra, rs, imm。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。