735df144d12431ff19d3a5a930acd2b31f3580c0
[calu.git] / 3b_sim / iext.hpp
1 /*   `Deep Thought', a softcore CPU implemented on a FPGA
2
3     Copyright (C) 2010 Markus Hofstaetter <markus.manrow@gmx.at>
4     Copyright (C) 2010 Martin Perner <e0725782@student.tuwien.ac.at>
5     Copyright (C) 2010 Stefan Rebernig <stefan.rebernig@gmail.com>
6     Copyright (C) 2010 Manfred Schwarz <e0725898@student.tuwien.ac.at>
7     Copyright (C) 2010 Bernhard Urban <lewurm@gmail.com>
8
9     This program is free software: you can redistribute it and/or modify
10     it under the terms of the GNU General Public License as published by
11     the Free Software Foundation, either version 3 of the License, or
12     (at your option) any later version.
13
14     This program is distributed in the hope that it will be useful,
15     but WITHOUT ANY WARRANTY; without even the implied warranty of
16     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17     GNU General Public License for more details.
18
19     You should have received a copy of the GNU General Public License
20     along with this program.  If not, see <http://www.gnu.org/licenses/>. */
21
22 #ifndef __IEXT_I_
23 #define __IEXT_I_
24
25 class CCpu;
26
27 #include "ccpu.hpp"
28
29 class disasm;
30
31 #include "disasm.h"
32
33
34 class Iext {
35         public:
36                 static void setCPU(CCpu* cpu) {m_cpu = cpu;}
37                 static void setDisasm(disasm* dasm) { m_disasm = dasm; }
38
39                 virtual ~Iext() {}
40                 //called by cpu before every tick
41                 virtual void applyTick() = 0;
42                 virtual void parseInput(const vector<string>& in) = 0;
43                 virtual void loadData(const int address, CDat value) = 0;
44                 virtual CDat readData(const int address) = 0;
45                 static CCpu* m_cpu;
46                 static disasm* m_disasm;
47 };
48
49 #endif