diff options
author | Andrew Waterman <waterman@cs.berkeley.edu> | 2016-02-05 18:18:06 -0800 |
---|---|---|
committer | Andrew Waterman <waterman@cs.berkeley.edu> | 2016-03-02 12:15:25 -0800 |
commit | 66a37a5104172a874ae72c80480cba4edceb7505 (patch) | |
tree | b9d3f329a0f83b158e570ae59410cea8f1470504 /riscv/trap.h | |
parent | 3bfc00ef2a1b1f0b0472a39a866261b00f67027e (diff) | |
download | spike-66a37a5104172a874ae72c80480cba4edceb7505.zip spike-66a37a5104172a874ae72c80480cba4edceb7505.tar.gz spike-66a37a5104172a874ae72c80480cba4edceb7505.tar.bz2 |
WIP on priv spec v1.9
Diffstat (limited to 'riscv/trap.h')
-rw-r--r-- | riscv/trap.h | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/riscv/trap.h b/riscv/trap.h index b03bf67..7f35c5f 100644 --- a/riscv/trap.h +++ b/riscv/trap.h @@ -4,6 +4,7 @@ #define _RISCV_TRAP_H #include "decode.h" +#include <stdlib.h> struct state_t; @@ -12,7 +13,8 @@ class trap_t public: trap_t(reg_t which) : which(which) {} virtual const char* name(); - virtual void side_effects(state_t* state) {} + virtual bool has_badaddr() { return false; } + virtual reg_t get_badaddr() { abort(); } reg_t cause() { return which; } private: char _name[16]; @@ -22,12 +24,12 @@ class trap_t class mem_trap_t : public trap_t { public: - mem_trap_t(reg_t which, reg_t badvaddr) - : trap_t(which), badvaddr(badvaddr) {} - void side_effects(state_t* state); - reg_t get_badvaddr() { return badvaddr; } + mem_trap_t(reg_t which, reg_t badaddr) + : trap_t(which), badaddr(badaddr) {} + bool has_badaddr() override { return true; } + reg_t get_badaddr() override { return badaddr; } private: - reg_t badvaddr; + reg_t badaddr; }; #define DECLARE_TRAP(n, x) class trap_##x : public trap_t { \ @@ -38,7 +40,7 @@ class mem_trap_t : public trap_t #define DECLARE_MEM_TRAP(n, x) class trap_##x : public mem_trap_t { \ public: \ - trap_##x(reg_t badvaddr) : mem_trap_t(n, badvaddr) {} \ + trap_##x(reg_t badaddr) : mem_trap_t(n, badaddr) {} \ const char* name() { return "trap_"#x; } \ }; |