Implement clearing-misa.C-while-PC-is-misaligned proposal
[riscv-isa-sim.git] / riscv / insns / csrrsi.h
index 913c20a343ea317817eb32a220932e0c1029d1ea..b673725b54d1cbc8eb0a4e27e4af7d6563eb45b6 100644 (file)
@@ -1,4 +1,8 @@
-int csr = validate_csr(insn.csr(), true);
-reg_t old = p->get_pcr(csr);
-p->set_pcr(csr, old | insn.rs1());
+bool write = insn.rs1() != 0;
+int csr = validate_csr(insn.csr(), write);
+reg_t old = p->get_csr(csr);
+if (write) {
+  p->set_csr(csr, old | insn.rs1());
+}
 WRITE_RD(sext_xlen(old));
+serialize();