Move towards RVC v1.8
[riscv-isa-sim.git] / riscv / insns / c_mv.h
index bc05cfe9d72e86a5bef14ef943171e319ab9c490..4a23063741c03e119a49916713102d27249dd387 100644 (file)
@@ -1,2 +1,7 @@
 require_extension('C');
-WRITE_RD(RVC_RS1);
+if (insn.rvc_rs2() == 0) {
+  require(insn.rvc_rd() != 0);
+  set_pc(RVC_RS1 & ~reg_t(1));
+} else {
+  WRITE_RD(RVC_RS2);
+}