diff options
author | Rupert Swarbrick <rswarbrick@gmail.com> | 2022-02-18 12:57:52 +0000 |
---|---|---|
committer | Rupert Swarbrick <rswarbrick@gmail.com> | 2022-02-18 17:11:55 +0000 |
commit | cd668d2f067d802879a7842bc3bed50fa61b2ead (patch) | |
tree | 5bdc8d9736752de4e9a8f1cf65c31ff7372000e8 /riscv/execute.cc | |
parent | 24953e7c0072e372fc8f7315715f2ba435209e30 (diff) | |
download | spike-cd668d2f067d802879a7842bc3bed50fa61b2ead.zip spike-cd668d2f067d802879a7842bc3bed50fa61b2ead.tar.gz spike-cd668d2f067d802879a7842bc3bed50fa61b2ead.tar.bz2 |
Split out MINSTRET and MCYCLE
Before this change, the MCYCLE CSR was just a proxy for MINSTRET.
Similarly, CYCLE was a proxy for INSTRET. This models a machine where
every instruction takes exactly one cycle to execute.
That's not quite precise enough if you want to do cosimulation: there,
you're going to want to MCYCLE to actually match the behaviour of your
processor (because you need reads from the relevant CSRs to give the
expected result).
This commit splits the two CSRs, leaving the other proxy relationships
unchanged. The code in processor_t::step() which bumps MINSTRET now
bumps MCYCLE by the same amount, maintaining the previous behaviour.
Of course, now a cosimulation environment can update the value of
MCYCLE to fix things up for multi-cycle instructions after they run.
Diffstat (limited to 'riscv/execute.cc')
-rw-r--r-- | riscv/execute.cc | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/riscv/execute.cc b/riscv/execute.cc index 3f7584e..41a15b7 100644 --- a/riscv/execute.cc +++ b/riscv/execute.cc @@ -349,6 +349,14 @@ void processor_t::step(size_t n) } state.minstret->bump(instret); + + // By default, bump the MCYCLE register by the same delta. This models a + // machine where each instruction takes exactly one cycle to retire. In a + // cosimulation environment, the RTL might manually update MCYCLE + // separately. It should do that between the end of this step() and the + // start of the next one. + state.mcycle->bump(instret); + n -= instret; } } |