aboutsummaryrefslogtreecommitdiff
path: root/riscv/processor.h
diff options
context:
space:
mode:
authorMegan Wachs <megan@sifive.com>2017-04-17 10:59:38 -0700
committerMegan Wachs <megan@sifive.com>2017-04-17 10:59:38 -0700
commit84e1ac19ed5a69224aa8c3f920e3840fbc670771 (patch)
tree7bc2ba170fc237a4e5cfd2551800c7909620ac04 /riscv/processor.h
parent773fab34d46e2ddaf4318b851ab23bd813f168ad (diff)
parentd6fce459767509249311a120fddb21c844dc9b2c (diff)
downloadspike-84e1ac19ed5a69224aa8c3f920e3840fbc670771.zip
spike-84e1ac19ed5a69224aa8c3f920e3840fbc670771.tar.gz
spike-84e1ac19ed5a69224aa8c3f920e3840fbc670771.tar.bz2
Merge remote-tracking branch 'origin/priv-1.10' into HEAD
Diffstat (limited to 'riscv/processor.h')
-rw-r--r--riscv/processor.h11
1 files changed, 5 insertions, 6 deletions
diff --git a/riscv/processor.h b/riscv/processor.h
index 3268029..4d94d5b 100644
--- a/riscv/processor.h
+++ b/riscv/processor.h
@@ -105,8 +105,8 @@ struct state_t
reg_t mip;
reg_t medeleg;
reg_t mideleg;
- uint32_t mucounteren;
- uint32_t mscounteren;
+ uint32_t mcounteren;
+ uint32_t scounteren;
reg_t sepc;
reg_t sbadaddr;
reg_t sscratch;
@@ -167,7 +167,6 @@ public:
void reset();
void step(size_t n); // run for n cycles
void set_csr(int which, reg_t val);
- void raise_interrupt(reg_t which);
reg_t get_csr(int which);
mmu_t* get_mmu() { return mmu; }
state_t* get_state() { return &state; }
@@ -304,8 +303,8 @@ private:
static const size_t OPCODE_CACHE_SIZE = 8191;
insn_desc_t opcode_cache[OPCODE_CACHE_SIZE];
- void check_timer();
- void take_interrupt(); // take a trap if any interrupts are pending
+ void take_pending_interrupt() { take_interrupt(state.mip & state.mie); }
+ void take_interrupt(reg_t mask); // take first enabled interrupt in mask
void take_trap(trap_t& t, reg_t epc); // take an exception
void disasm(insn_t insn); // disassemble and print an instruction
int paddr_bits();
@@ -314,7 +313,7 @@ private:
friend class sim_t;
friend class mmu_t;
- friend class rtc_t;
+ friend class clint_t;
friend class extension_t;
void parse_isa_string(const char* isa);