cm.mvsa01

Move a0-a1 into two registers of s0-s7

This instruction is defined by:

  • anyOf:

    • Zcmp, version >= 0

This instruction is included in the following profiles:

Encoding

svg

Assembly format

cm.mvsa01 r1s, r2s

Synopsis

This instruction moves a0 into r1s' and a1 into r2s'. r1s' and r2s' must be different. The execution is atomic, so it is not possible to observe state where only one of r1s' or r2s' has been updated. The encoding uses sreg number specifiers instead of xreg number specifiers to save encoding space. The mapping between them is specified in the pseudo-code below.

Access

M HS U VS VU

Always

Always

Always

Always

Always

Decode Variables

Bits<3> r1s = $encoding[9:7];
Bits<3> r2s = $encoding[4:2];

Execution

  • IDL

if (implemented?(ExtensionName::Zcmp) && (CSR[misa].C == 1'b0)) {
  raise(ExceptionCode::IllegalInstruction, mode(), $encoding);
}
XReg xreg1 = (r1s[2:1] > 0) ? {1, 0, r1s[2:0]} : {0, 1, r1s[2:0]};
XReg xreg2 = (r2s[2:1] > 0) ? {1, 0, r2s[2:0]} : {0, 1, r2s[2:0]};
X[xreg1] = X[10];
X[xreg2] = X[11];

Exceptions

This instruction may result in the following synchronous exceptions:

  • IllegalInstruction