-if(RS2 == 0)
- RD = RS1;
-else if(sreg_t(RS1) == INT64_MIN && sreg_t(RS2) == -1)
- RD = 0;
+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
- RD = sext_xprlen(sext_xprlen(RS1) % sext_xprlen(RS2));
+ WRITE_RD(sext_xlen(lhs % rhs));