copyleft: gplv3 added and set repo to public
[calu.git] / 3b_sim / extensions / cprog.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 #include "../iext.hpp"
23
24 class Cprog : public Iext {
25         public:
26                 Cprog() : m_writeAddress(0) {};
27                 void applyTick() {};
28                 void loadData(const int address, CDat value);
29                 CDat readData(const int) { return 0; }
30                 void parseInput(const vector<string>&)  {};
31         private:
32                 int m_writeAddress;
33 };
34
35 void Cprog::loadData(const int address, CDat value)
36 {
37         if(address == 0x2034) {
38                 m_writeAddress = (value*4);
39                 //adress pointer
40         }
41         else if(address == 0x2038) {
42                 this->m_cpu->setProg(m_writeAddress, m_disasm->decodeNum(value));
43                 m_writeAddress += 4;
44                 //data pointer
45         }
46 }