aboutsummaryrefslogtreecommitdiff
path: root/riscv/trap.h
diff options
context:
space:
mode:
authorAndrew Waterman <waterman@cs.berkeley.edu>2016-02-05 18:18:06 -0800
committerAndrew Waterman <waterman@cs.berkeley.edu>2016-03-02 12:15:25 -0800
commit66a37a5104172a874ae72c80480cba4edceb7505 (patch)
treeb9d3f329a0f83b158e570ae59410cea8f1470504 /riscv/trap.h
parent3bfc00ef2a1b1f0b0472a39a866261b00f67027e (diff)
downloadspike-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.h16
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; } \
};