Fix pmp cosim
This commit is contained in:
@@ -212,12 +212,16 @@ extern "C" void cospike_cosim(long long int cycle,
|
|||||||
// 4 => csr
|
// 4 => csr
|
||||||
if ((rd != 0 && type == 0) || type == 1) {
|
if ((rd != 0 && type == 0) || type == 1) {
|
||||||
// Override reads from some CSRs
|
// Override reads from some CSRs
|
||||||
if ((insn & 0xfff0007f) == 0xf1300073 || // mimpid
|
uint64_t csr_addr = insn >> 20;
|
||||||
(insn & 0xfff0007f) == 0xf1200073 || // marchid
|
bool csr_read = (insn & 0x7f) == 0x73;
|
||||||
(insn & 0xfff0007f) == 0xf1100073 || // mvendorid
|
if (csr_read && (
|
||||||
(insn & 0xfff0007f) == 0xb0000073 || // mcycle
|
(csr_addr == 0xf13) || // mimpid
|
||||||
(insn & 0xfff0007f) == 0xb0200073 // minstret
|
(csr_addr == 0xf12) || // marchid
|
||||||
) {
|
(csr_addr == 0xf11) || // mvendorid
|
||||||
|
(csr_addr == 0xb00) || // mcycle
|
||||||
|
(csr_addr == 0xb02) || // minstret
|
||||||
|
(csr_addr >= 0x3b0 && csr_addr <= 0x3ef) // pmpaddr
|
||||||
|
)) {
|
||||||
printf("CSR override\n");
|
printf("CSR override\n");
|
||||||
s->XPR.write(rd, wdata);
|
s->XPR.write(rd, wdata);
|
||||||
} else if (!mem_read.empty() &&
|
} else if (!mem_read.empty() &&
|
||||||
|
|||||||
Reference in New Issue
Block a user