它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
通过跳转向量表间接跳转
CM.JT (Zcmt)根据index在JVT CSR指向的跳转向量表中查找目标地址并跳转。表条目为XLEN位地址。复用c.fsdsp编码,与Zcd(C+D)不兼容。属于Zcmt,依赖Zca和Zicsr。
CM.JT 是 压缩表跳转 的 16 位编码形式;语义和可编码寄存器/立即数范围必须按官方 Zc 扩展规则理解。
结合 «cm.jt 3 # jump via table entry 3» 等实际代码理解该场景。
结合 «cm.jt 3 # jump via table entry 3» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。