首页/指令库/CM-MVA01S
CM.MVA01S

RISC-V CM.MVA01S 指令详解

指令手册C-type

将两个不同的 s0-s7 寄存器移动到 a0 和 a1

指令语法

cm.mva01s r1s', r2s'
操作数说明
压缩指令仅 16 位,寄存器选择通常限制在 x8–x15。
立即数字段较窄,查看特定压缩指令的完整编码。
Zcmp栈与函数压缩指令

指令行为说明

CM.MVA01S (Zcmp) 将 r1s' 写入 a0、将 r2s' 写入 a1;两个源寄存器来自 s0-s7 且必须不同。它用于把已保存寄存器中的值放入 a0/a1。该指令复用 c.fsdsp 编码,与 Zcd 不兼容,属于 Zcmp 并依赖 Zca。

快速理解与检索要点

CM.MVA01S 是 Zcmp 的 16 位寄存器搬移指令,方向是从两个不同的 s0-s7 源寄存器写入 a0/a1。

官方操作为 X[10]=X[xreg1]、X[11]=X[xreg2];不要把它写成 a0/a1 -> s 寄存器。
r1s' 与 r2s' 必须不同,且编码只覆盖 s0-s7。

常见使用场景

函数调用与返回

使用 jal ra, label 或 jalr ra, rs, imm。

压缩与代码优化

结合 «cm.mva01s s0, s1 # a0 = s0; a1 = s1» 等实际代码理解该场景。

寄存器操作

结合 «cm.mva01s s0, s1 # a0 = s0; a1 = s1» 等实际代码理解该场景。

使用前检查清单

语法检查
  • 确认当前指令格式为 C-type。
  • 确认操作数排列顺序与示例一致。
语义检查
  • 确认目标寄存器用途和调用约定兼容。
  • 确认该指令不是伪指令展开后的底层形式。

容易混淆 / 常见误区

r1s' 和 r2s' 是源寄存器,方向是 s0-s7 -> a0/a1。
两个源寄存器必须不同,且只能来自 s0-s7。
与 Zcd 不兼容。

常见问题

它一定等价于同名 32 位指令吗?

不一定。有些 C/Zc 指令是常见 32 位指令的压缩形式,有些有专门的栈帧或查表语义。

为什么要关注寄存器限制?

许多 16 位编码只能表示压缩寄存器子集或固定寄存器,如 sp、ra、a0/a1。