3 /* CDat m_pc, m_pc_next;
7 //void registerExtension() {};
9 const char* expression = "(;.*)|(r0)|(rX)|(r1[0-5])|(r[1-5])|(r[6-9])|(0x[a-fA-F0-9]+)|([-]?\\d+)";
10 const char* format = "(?1$&)"
11 //Return-Register: violett
12 "(?2\033[0m\033[35m$&\033[0m\\3:)"
13 // Callee-saved Register: rot
14 "(?4\033[0m\033[31m$&\033[0m\\3:)"
15 //Argument-Register: gruen
16 "(?5\033[0m\033[32m$&\033[0m\\3:)"
17 // Temporary Register: gelb
18 "(?6\033[0m\033[33m$&\033[0m\\3:)"
19 // Zahlenwerte: tuerkis
20 "(?7\033[0m\033[36m$&\033[0m\\3:)"
21 "(?8\033[0m\033[36m$&\033[0m\\3:)";
24 string CCpu::colorifyInstr(string instr)
28 return boost::regex_replace(instr, e, format, boost::match_default | boost::format_all);
31 void CCpu::registerExtension(Iext* ext)
33 m_exts.push_back(ext);
43 Iinstr* instr = this->getProg(m_pc);
46 throw string("Out of Instructions!");
49 for(auto iter = m_exts.begin(); iter != m_exts.end(); ++iter) {
53 if(this->conditionMet(instr->getCondition())) {
54 cout << color(green,black) << "Executing: " << color(white,black) << colorifyInstr(instr->toString()) << endl;
56 this->incPerfBy(instr->getClockCount());
59 cout << color(red,black) << "Didn't Execute " << color(white,black) << colorifyInstr(instr->toString()) << "; condition wasn't met" << endl;
65 bool CCpu::conditionMet(short cond)
93 return (!this->m_C && !this->m_Z);
96 return (this->m_C || this->m_Z);
99 return (this->m_S == this->m_O);
102 return (this->m_S != this->m_O);
105 return (!this->m_Z && (this->m_S == this->m_O));
108 return (!this->m_Z || (this->m_S != this->m_O));
117 cerr << "What did you do? more than 16 values in 5 bits?!" << endl;
123 CDat CCpu::getNextPC() const
128 CDat CCpu::getCurPC() const
133 void CCpu::setNextPC(CDat val)
138 CDat CCpu::getFlags() const {
140 psw += (this->m_Z ? 1 : 0);
141 psw += (this->m_O ? 2 : 0);
142 psw += (this->m_C ? 4 : 0);
143 psw += (this->m_S ? 8 : 0);
147 void CCpu::setFlags(CDat psw) {
148 this->m_Z = ((psw & 0x1) != 0);
149 this->m_O = ((psw & 0x2) != 0);
150 this->m_C = ((psw & 0x4) != 0);
151 this->m_S = ((psw & 0x8) != 0);
154 void CCpu::updateFlags(CDat val) {
155 this->m_Z = (val == 0);
156 this->m_S = ((val >> (BIT_LEN-1)) & 0x1);
157 /* this->m_C = false;
158 this->m_O = false; */
161 void CCpu::updateFlags(CDatd val, CDat a, CDat b) {
162 this->m_Z = (val == 0);
163 this->m_S = ((val >> (BIT_LEN-1)) & 0x1);
164 this->m_C = ((val >> (BIT_LEN)) & 0x1);
165 bool a_31 = ((a >> (BIT_LEN-1)) & 0x1);
166 bool b_31 = ((b >> (BIT_LEN-1)) & 0x1);
167 bool val_31 = ((val >> (BIT_LEN-1)) & 0x1);
168 this->m_O = ((a_31 && b_31 && !val_31) || (!a_31 && !b_31 && val_31));
171 void CCpu::updateCarry(bool c)
176 bool CCpu::getCarry()
181 void CCpu::updateFlags(bool z, bool o, bool c, bool s)
189 CDat CCpu::getRegister(const int addr) const
191 return m_reg.getDirect(addr);
194 void CCpu::setRegister(const int addr, CDat data)
196 m_reg.setDirect(addr, data);
199 CDat CCpu::getRAM(const int addr) const
201 if((addr & EXT_MODEL_OFFSET) == 0) {
202 return m_ram.get(addr);
206 for(auto iter = m_exts.begin(); iter != m_exts.end(); ++iter) {
207 result = (*iter)->readData(addr);
216 void CCpu::setRAM(const int addr, CDat data)
218 if((addr & EXT_MODEL_OFFSET) == 0) {
219 m_ram.set(addr, data);
222 for(auto iter = m_exts.begin(); iter != m_exts.end(); ++iter) {
223 (*iter)->loadData(addr, data);
228 void CCpu::setProg(int addr, Iinstr* instr)
230 m_prog.set(addr, instr);
233 Iinstr* CCpu::getProg(const int addr) const
235 return m_prog.get(addr);
238 int CCpu::getStack() const
240 return this->m_stack;
243 void CCpu::setStack(const int val)
248 CDat CCpu::getPerf() const
253 void CCpu::setPerf(CDat val)
263 void CCpu::incPerfBy(short inc)
269 CCpu::CCpu(int regs, int ram, int prog) : m_Z(false), m_S(false), m_C(false), m_O(false), m_pc(0), m_pc_next(0), m_perf(0), m_reg(regs), m_ram(ram), m_prog(prog), m_exts(0), m_stack(0)