它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
通过寄存器跳转并将pc+2写入x1。CR格式。rs1!=x0。
C.JALR (CR格式)跳转到rs1中的地址,将pc+2写入x1(ra)。展开为jalr x1,0(rs1)。仅rs1≠x0有效(rs1=x0对应C.EBREAK)。链接地址偏移量为2字节(而非32位指令的4字节)。
C.JALR 是 压缩寄存器间接调用 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 C 扩展规则理解。
使用 jal ra, label 或 jalr ra, rs, imm。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。