Support setting ISA/subsets with --isa flag
[riscv-isa-sim.git] / riscv / insns / rem.h
index 1bb3051d9692d4d3d7d70fd4bf508cd06225ab0c..858799577ccbc4875aa38932455c5d54261b545b 100644 (file)
@@ -1,2 +1,9 @@
-RC = sext32(int32_t(RA) % int32_t(RB));
-
+require_extension('M');
+sreg_t lhs = sext_xlen(RS1);
+sreg_t rhs = sext_xlen(RS2);
+if(rhs == 0)
+  WRITE_RD(lhs);
+else if(lhs == INT64_MIN && rhs == -1)
+  WRITE_RD(0);
+else
+  WRITE_RD(sext_xlen(lhs % rhs));