aboutsummaryrefslogtreecommitdiff
path: root/riscv/devices.h
diff options
context:
space:
mode:
authorAndrew Waterman <waterman@cs.berkeley.edu>2015-11-12 17:51:46 -0800
committerAndrew Waterman <waterman@cs.berkeley.edu>2015-11-12 17:52:56 -0800
commit0c3af3d73a28c0fc57eac535b2a28f45134b556b (patch)
treea9ad7bab1842bde77d6755d96b22a45a510e7a41 /riscv/devices.h
parenta7bde15c2b79de12484748b462e511e0d1c2eca5 (diff)
downloadspike-0c3af3d73a28c0fc57eac535b2a28f45134b556b.zip
spike-0c3af3d73a28c0fc57eac535b2a28f45134b556b.tar.gz
spike-0c3af3d73a28c0fc57eac535b2a28f45134b556b.tar.bz2
Generate device tree for target machine
Diffstat (limited to 'riscv/devices.h')
-rw-r--r--riscv/devices.h34
1 files changed, 34 insertions, 0 deletions
diff --git a/riscv/devices.h b/riscv/devices.h
new file mode 100644
index 0000000..558ecc7
--- /dev/null
+++ b/riscv/devices.h
@@ -0,0 +1,34 @@
+#ifndef _RISCV_DEVICES_H
+#define _RISCV_DEVICES_H
+
+#include "decode.h"
+#include <map>
+#include <vector>
+
+class abstract_device_t {
+ public:
+ virtual bool load(reg_t addr, size_t len, uint8_t* bytes) = 0;
+ virtual bool store(reg_t addr, size_t len, const uint8_t* bytes) = 0;
+ virtual ~abstract_device_t() {}
+};
+
+class bus_t : public abstract_device_t {
+ public:
+ bool load(reg_t addr, size_t len, uint8_t* bytes);
+ bool store(reg_t addr, size_t len, const uint8_t* bytes);
+ void add_device(reg_t addr, abstract_device_t* dev);
+
+ private:
+ std::map<reg_t, abstract_device_t*> devices;
+};
+
+class rom_device_t : public abstract_device_t {
+ public:
+ rom_device_t(std::vector<char> data);
+ bool load(reg_t addr, size_t len, uint8_t* bytes);
+ bool store(reg_t addr, size_t len, const uint8_t* bytes);
+ private:
+ std::vector<char> data;
+};
+
+#endif