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

RISC-V CM.MVSA01 指令详解

指令手册C-type

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

指令语法

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

指令行为说明

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

快速理解与检索要点

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

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

常见使用场景

压缩与代码优化

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

寄存器操作

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

使用前检查清单

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

容易混淆 / 常见误区

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

常见问题

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

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

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

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