它一定等价于同名 32 位指令吗?
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
将两个不同的 s0-s7 寄存器移动到 a0 和 a1
CM.MVA01S (Zcmp) 将 r1s' 写入 a0、将 r2s' 写入 a1;两个源寄存器来自 s0-s7 且必须不同。它用于把已保存寄存器中的值放入 a0/a1。该指令复用 c.fsdsp 编码,与 Zcd 不兼容,属于 Zcmp 并依赖 Zca。
CM.MVA01S 是 Zcmp 的 16 位寄存器搬移指令,方向是从两个不同的 s0-s7 源寄存器写入 a0/a1。
使用 jal ra, label 或 jalr ra, rs, imm。
结合 «cm.mva01s s0, s1 # a0 = s0; a1 = s1» 等实际代码理解该场景。
结合 «cm.mva01s s0, s1 # a0 = s0; a1 = s1» 等实际代码理解该场景。
不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。
许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。