3 /* CDat m_pc, m_pc_next;
7 //void registerExtension() {};
16 Iinstr* instr = this->getProg(m_pc);
18 throw string("Out of Instructions!");
20 if(this->conditionMet(instr->getCondition())) {
25 bool CCpu::conditionMet(short cond)
53 return (!this->m_C && !this->m_Z);
56 return (this->m_C || this->m_Z);
59 return (this->m_S == this->m_O);
62 return (this->m_S != this->m_O);
65 return (!this->m_Z && (this->m_S == this->m_O));
68 return (!this->m_Z || (this->m_S != this->m_O));
77 cerr << "What did you do? more than 16 values in 5 bits?!" << endl;
83 CDat CCpu::getCurPC() const
88 void CCpu::setNextPC(CDat val)
93 void CCpu::updateFlags(CDat val) {
94 this->m_Z = (val == 0);
95 this->m_S = ((val >> (BIT_LEN-1)) & 0x1);
100 void CCpu::updateFlags(bool z, bool o, bool c, bool s)
108 CDat CCpu::getRegister(const int addr) const
110 return m_reg.get(addr);
113 void CCpu::setRegister(const int addr, CDat data)
115 m_reg.set(addr, data);
118 CDat CCpu::getRAM(const int addr) const
120 return m_ram.get(addr);
122 void CCpu::setRAM(const int addr, CDat data)
124 m_ram.set(addr, data);
127 void CCpu::setProg(int addr, Iinstr* instr)
129 m_prog.set(addr, instr);
132 Iinstr* CCpu::getProg(const int addr) const
134 return m_prog.get(addr);
137 int CCpu::getStack() const
139 return this->m_stack;
142 void CCpu::setStack(const int val)
147 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_reg(regs), m_ram(ram), m_prog(prog), m_stack(0)