1
0
mirror of https://github.com/mnaberez/py65.git synced 2025-01-04 16:30:42 +00:00

Removed duplication in instructions using accumulator mode.

This commit is contained in:
Mike Naberezny 2009-08-10 16:57:36 -07:00
parent 926e2c55b1
commit 3b40ede9bc
2 changed files with 73 additions and 73 deletions

View File

@ -172,24 +172,35 @@ class MPU:
self.FlagsNZ(self.a)
def opASL(self, x):
addr = x()
tbyte = self.ByteAt(addr)
if x is None:
tbyte = self.a
else:
addr = x()
tbyte = self.ByteAt(addr)
self.flags &= ~(self.CARRY + self.NEGATIVE + self.ZERO)
if tbyte & 128:
self.flags |= self.CARRY
tbyte = (tbyte << 1) & 0xFF
if tbyte:
self.flags |= tbyte & 128
else:
self.flags |= self.ZERO
self.memory[addr] = tbyte
if x is None:
self.a = tbyte
else:
self.memory[addr] = tbyte
def opLSR(self, x):
addr = x()
tbyte = self.ByteAt(addr)
if x is None:
tbyte = self.a
else:
addr = x()
tbyte = self.ByteAt(addr)
self.flags &=~(self.CARRY+self.NEGATIVE+self.ZERO)
self.flags |=tbyte&1
@ -198,7 +209,11 @@ class MPU:
pass # {}
else:
self.flags |= self.ZERO
self.memory[addr]=tbyte
if x is None:
self.a = tbyte
else:
self.memory[addr]=tbyte
def opBCL(self, x):
if self.flags & x:
@ -230,8 +245,12 @@ class MPU:
self.flags |= tbyte&(128+64)
def opROL(self, x):
addr = x()
tbyte = self.ByteAt(addr)
if x is None:
tbyte = self.a
else:
addr = x()
tbyte = self.ByteAt(addr)
if self.flags & self.CARRY:
if tbyte & 128:
pass
@ -244,7 +263,11 @@ class MPU:
tbyte = tbyte << 1
tbyte &= 0xFF
self.FlagsNZ(tbyte)
self.memory[addr] = tbyte
if x is None:
self.a = tbyte
else:
self.memory[addr] = tbyte
def opEOR(self, x):
self.a ^= self.ByteAt(x())
@ -286,8 +309,12 @@ class MPU:
self.a = data
def opROR(self, x):
addr=x()
tbyte = self.ByteAt(addr)
if x is None:
tbyte = self.a
else:
addr=x()
tbyte = self.ByteAt(addr)
if self.flags & self.CARRY:
if tbyte & 1:
pass # {}
@ -299,7 +326,11 @@ class MPU:
self.flags |= self.CARRY
tbyte=tbyte>>1
self.FlagsNZ(tbyte)
self.memory[addr]=tbyte
if x is None:
self.a = tbyte
else:
self.memory[addr] = tbyte
def opSTA(self, x):
self.memory[x()] = self.a
@ -377,26 +408,42 @@ class MPU:
self.a = data & 0xFF
def opDECR(self, x):
addr = x()
tbyte = self.ByteAt(addr)
if x is None:
tbyte = self.a
else:
addr = x()
tbyte = self.ByteAt(addr)
self.flags &= ~(self.ZERO + self.NEGATIVE)
tbyte = (tbyte - 1) & 0xFF
if tbyte:
self.flags |= tbyte & self.NEGATIVE
else:
self.flags |= self.ZERO
self.memory[addr] = tbyte
if x is None:
self.a = tbyte
else:
self.memory[addr] = tbyte
def opINCR(self, x):
addr = x()
tbyte = self.ByteAt(addr)
if x is None:
tbyte = self.a
else:
addr = x()
tbyte = self.ByteAt(addr)
self.flags &= ~(self.ZERO + self.NEGATIVE)
tbyte = (tbyte + 1) & 0xFF
if tbyte:
self.flags |= tbyte & self.NEGATIVE
else:
self.flags |= self.ZERO
self.memory[addr] = tbyte
if x is None:
self.a = tbyte
else:
self.memory[addr] = tbyte
def opLDA(self, x):
self.a = self.ByteAt(x())
@ -462,13 +509,7 @@ class MPU:
@instruction(name="ASL", mode="acc", cycles=2)
def inst_0x0a(self):
if self.a & 128:
self.flags |= self.CARRY
else:
self.flags &= ~self.CARRY
self.a = self.a << 1
self.FlagsNZ(self.a)
self.a &= 255
self.opASL(None)
@instruction(name="ORA", mode="abs", cycles=4)
def inst_0x0d(self):
@ -554,16 +595,7 @@ class MPU:
@instruction(name="ROL", mode="acc", cycles=2)
def inst_0x2a(self):
if self.flags & self.CARRY:
if (self.a & 128) == 0:
self.flags &=~self.CARRY
self.a = (self.a<<1) | 1
else:
if self.a & 128:
self.flags |= self.CARRY
self.a = self.a << 1
self.a &= 0xFF
self.FlagsNZ(self.a)
self.opROL(None)
@instruction(name="BIT", mode="abs", cycles=4)
def inst_0x2c(self):
@ -649,16 +681,7 @@ class MPU:
@instruction(name="LSR", mode="acc", cycles=2)
def inst_0x4a(self):
self.flags &= ~(self.CARRY+self.NEGATIVE+self.ZERO)
if self.a & 1:
self.flags |= self.CARRY
self.a = self.a >> 1
if self.a:
pass # {}
else:
self.flags |= self.ZERO
self.a &= 255
self.opLSR(None)
@instruction(name="JMP", mode="abs", cycles=3)
def inst_0x4c(self):
@ -744,16 +767,7 @@ class MPU:
@instruction(name="ROR", mode="acc", cycles=2)
def inst_0x6a(self):
if self.flags & self.CARRY:
if (self.a & 1) == 0:
self.flags &= ~self.CARRY
self.a = (self.a >> 1) | 128
else:
if self.a & 1:
self.flags |= self.CARRY
self.a = self.a >> 1
self.FlagsNZ(self.a)
self.a &= 255
self.opROR(None)
@instruction(name="JMP", mode="ind", cycles=5)
def inst_0x6c(self):

View File

@ -239,14 +239,7 @@ class MPU(mpu6502.MPU):
@instruction(name="INC", mode="acc", cycles=2)
def inst_0x1a(self):
tbyte = self.a
self.flags &= ~(self.ZERO + self.NEGATIVE)
tbyte = (tbyte + 1) & 0xFF
if tbyte:
self.flags |= tbyte & self.NEGATIVE
else:
self.flags |= self.ZERO
self.a = tbyte
self.opINCR(None)
@instruction(name="TRB", mode="abs", cycles=6)
def inst_0x1c(self):
@ -255,14 +248,7 @@ class MPU(mpu6502.MPU):
@instruction(name="DEC", mode="acc", cycles=2)
def inst_0x3a(self):
tbyte = self.a
self.flags &= ~(self.ZERO + self.NEGATIVE)
tbyte = (tbyte - 1) & 0xFF
if tbyte:
self.flags |= tbyte & self.NEGATIVE
else:
self.flags |= self.ZERO
self.a = tbyte
self.opDECR(None)
@instruction(name="BRA", mode="rel", cycles=1, extracycles=1)
def inst_0x80(self):