mirror of
https://github.com/mnaberez/py65.git
synced 2025-02-08 01:31:07 +00:00
Build lookup tables from decorators.
This commit is contained in:
parent
10228a69b0
commit
9d7615a17e
@ -1,4 +1,5 @@
|
|||||||
from py65.utils.conversions import convert_to_bin, convert_to_bcd
|
from py65.utils.conversions import convert_to_bin, convert_to_bcd
|
||||||
|
from py65.utils.devices import make_instruction_decorator
|
||||||
|
|
||||||
class MPU:
|
class MPU:
|
||||||
# vectors
|
# vectors
|
||||||
@ -408,6 +409,19 @@ class MPU:
|
|||||||
|
|
||||||
# instructions
|
# instructions
|
||||||
|
|
||||||
|
def ini(self):
|
||||||
|
if self.debug:
|
||||||
|
raise NotImplementedError
|
||||||
|
self.pc += 1
|
||||||
|
|
||||||
|
instruct = [ini] * 256
|
||||||
|
cycletime = [0] * 256
|
||||||
|
extracycles = [0] * 256
|
||||||
|
|
||||||
|
instruction = \
|
||||||
|
make_instruction_decorator(instruct, cycletime, extracycles)
|
||||||
|
|
||||||
|
@instruction(0x0, 7, 0)
|
||||||
def i00(self):
|
def i00(self):
|
||||||
pc = (self.pc + 2) & 0xFFFF
|
pc = (self.pc + 2) & 0xFFFF
|
||||||
self.stPushWord(pc)
|
self.stPushWord(pc)
|
||||||
@ -420,26 +434,32 @@ class MPU:
|
|||||||
|
|
||||||
self.breakFlag = True
|
self.breakFlag = True
|
||||||
|
|
||||||
|
@instruction(0x1, 6, 0)
|
||||||
def i01(self):
|
def i01(self):
|
||||||
self.opORA(self.IndirectXAddr)
|
self.opORA(self.IndirectXAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x5, 3, 0)
|
||||||
def i05(self):
|
def i05(self):
|
||||||
self.opORA(self.ZeroPageAddr)
|
self.opORA(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x6, 5, 0)
|
||||||
def i06(self):
|
def i06(self):
|
||||||
self.opASL(self.ZeroPageAddr)
|
self.opASL(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x8, 3, 0)
|
||||||
def i08(self):
|
def i08(self):
|
||||||
self.stPush(self.flags)
|
self.stPush(self.flags)
|
||||||
|
|
||||||
|
@instruction(0x9, 2, 0)
|
||||||
def i09(self):
|
def i09(self):
|
||||||
self.a |= self.ImmediateByte()
|
self.a |= self.ImmediateByte()
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xa, 2, 0)
|
||||||
def i0a(self):
|
def i0a(self):
|
||||||
if self.a & 128:
|
if self.a & 128:
|
||||||
self.flags |= self.CARRY
|
self.flags |= self.CARRY
|
||||||
@ -449,72 +469,90 @@ class MPU:
|
|||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.a &= 255
|
self.a &= 255
|
||||||
|
|
||||||
|
@instruction(0xd, 4, 0)
|
||||||
def i0d(self):
|
def i0d(self):
|
||||||
self.opORA(self.AbsoluteAddr)
|
self.opORA(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xe, 6, 0)
|
||||||
def i0e(self):
|
def i0e(self):
|
||||||
self.opASL(self.AbsoluteAddr)
|
self.opASL(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x10, 2, 2)
|
||||||
def i10(self):
|
def i10(self):
|
||||||
self.opBCL(self.NEGATIVE)
|
self.opBCL(self.NEGATIVE)
|
||||||
|
|
||||||
|
@instruction(0x11, 5, 1)
|
||||||
def i11(self):
|
def i11(self):
|
||||||
self.opORA(self.IndirectYAddr)
|
self.opORA(self.IndirectYAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x15, 4, 0)
|
||||||
def i15(self):
|
def i15(self):
|
||||||
self.opORA(self.ZeroPageXAddr)
|
self.opORA(self.ZeroPageXAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x16, 6, 0)
|
||||||
def i16(self):
|
def i16(self):
|
||||||
self.opASL(self.ZeroPageXAddr)
|
self.opASL(self.ZeroPageXAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x18, 2, 0)
|
||||||
def i18(self):
|
def i18(self):
|
||||||
self.opCLR(self.CARRY)
|
self.opCLR(self.CARRY)
|
||||||
|
|
||||||
|
@instruction(0x19, 4, 1)
|
||||||
def i19(self):
|
def i19(self):
|
||||||
self.opORA(self.AbsoluteYAddr)
|
self.opORA(self.AbsoluteYAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x1d, 4, 1)
|
||||||
def i1d(self):
|
def i1d(self):
|
||||||
self.opORA(self.AbsoluteXAddr)
|
self.opORA(self.AbsoluteXAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x1e, 7, 0)
|
||||||
def i1e(self):
|
def i1e(self):
|
||||||
self.opASL(self.AbsoluteXAddr)
|
self.opASL(self.AbsoluteXAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x20, 6, 0)
|
||||||
def i20(self):
|
def i20(self):
|
||||||
self.stPushWord((self.pc+1)&0xffff)
|
self.stPushWord((self.pc+1)&0xffff)
|
||||||
self.pc=self.WordAt(self.pc)
|
self.pc=self.WordAt(self.pc)
|
||||||
|
|
||||||
|
@instruction(0x21, 6, 0)
|
||||||
def i21(self):
|
def i21(self):
|
||||||
self.opAND(self.IndirectXAddr)
|
self.opAND(self.IndirectXAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x24, 3, 0)
|
||||||
def i24(self):
|
def i24(self):
|
||||||
self.opBIT(self.ZeroPageAddr)
|
self.opBIT(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x25, 3, 0)
|
||||||
def i25(self):
|
def i25(self):
|
||||||
self.opAND(self.ZeroPageAddr)
|
self.opAND(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x26, 5, 0)
|
||||||
def i26(self):
|
def i26(self):
|
||||||
self.opROL(self.ZeroPageAddr)
|
self.opROL(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x28, 4, 0)
|
||||||
def i28(self):
|
def i28(self):
|
||||||
self.flags = self.stPop()
|
self.flags = self.stPop()
|
||||||
|
|
||||||
|
@instruction(0x29, 2, 0)
|
||||||
def i29(self):
|
def i29(self):
|
||||||
self.a &= self.ImmediateByte()
|
self.a &= self.ImmediateByte()
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x2a, 2, 0)
|
||||||
def i2a(self):
|
def i2a(self):
|
||||||
if self.flags & self.CARRY:
|
if self.flags & self.CARRY:
|
||||||
if (self.a & 128) == 0:
|
if (self.a & 128) == 0:
|
||||||
@ -527,72 +565,90 @@ class MPU:
|
|||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.a &= 255
|
self.a &= 255
|
||||||
|
|
||||||
|
@instruction(0x2c, 4, 0)
|
||||||
def i2c(self):
|
def i2c(self):
|
||||||
self.opBIT(self.AbsoluteAddr)
|
self.opBIT(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x2d, 4, 0)
|
||||||
def i2d(self):
|
def i2d(self):
|
||||||
self.opAND(self.AbsoluteAddr)
|
self.opAND(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x2e, 6, 0)
|
||||||
def i2e(self):
|
def i2e(self):
|
||||||
self.opROL(self.AbsoluteAddr)
|
self.opROL(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x30, 2, 2)
|
||||||
def i30(self):
|
def i30(self):
|
||||||
self.opBST(self.NEGATIVE)
|
self.opBST(self.NEGATIVE)
|
||||||
|
|
||||||
|
@instruction(0x31, 5, 1)
|
||||||
def i31(self):
|
def i31(self):
|
||||||
self.opAND(self.IndirectYAddr)
|
self.opAND(self.IndirectYAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x35, 4, 0)
|
||||||
def i35(self):
|
def i35(self):
|
||||||
self.opAND(self.ZeroPageXAddr)
|
self.opAND(self.ZeroPageXAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x36, 6, 0)
|
||||||
def i36(self):
|
def i36(self):
|
||||||
self.opROL(self.ZeroPageXAddr)
|
self.opROL(self.ZeroPageXAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x38, 2, 0)
|
||||||
def i38(self):
|
def i38(self):
|
||||||
self.opSET(self.CARRY)
|
self.opSET(self.CARRY)
|
||||||
|
|
||||||
|
@instruction(0x39, 4, 1)
|
||||||
def i39(self):
|
def i39(self):
|
||||||
self.opAND(self.AbsoluteYAddr)
|
self.opAND(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x3d, 4, 1)
|
||||||
def i3d(self):
|
def i3d(self):
|
||||||
self.opAND(self.AbsoluteXAddr)
|
self.opAND(self.AbsoluteXAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x3e, 7, 0)
|
||||||
def i3e(self):
|
def i3e(self):
|
||||||
self.opROL(self.AbsoluteXAddr)
|
self.opROL(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x40, 6, 0)
|
||||||
def i40(self):
|
def i40(self):
|
||||||
self.flags = self.stPop()
|
self.flags = self.stPop()
|
||||||
self.pc = self.stPopWord()
|
self.pc = self.stPopWord()
|
||||||
|
|
||||||
|
@instruction(0x41, 6, 0)
|
||||||
def i41(self):
|
def i41(self):
|
||||||
self.opEOR(self.IndirectXAddr)
|
self.opEOR(self.IndirectXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x45, 3, 0)
|
||||||
def i45(self):
|
def i45(self):
|
||||||
self.opEOR(self.ZeroPageAddr)
|
self.opEOR(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x46, 5, 0)
|
||||||
def i46(self):
|
def i46(self):
|
||||||
self.opLSR(self.ZeroPageAddr)
|
self.opLSR(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x48, 3, 0)
|
||||||
def i48(self):
|
def i48(self):
|
||||||
self.stPush(self.a)
|
self.stPush(self.a)
|
||||||
|
|
||||||
|
@instruction(0x49, 2, 0)
|
||||||
def i49(self):
|
def i49(self):
|
||||||
self.a ^= self.ImmediateByte()
|
self.a ^= self.ImmediateByte()
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x4a, 2, 0)
|
||||||
def i4a(self):
|
def i4a(self):
|
||||||
self.flags &= ~(self.CARRY+self.NEGATIVE+self.ZERO)
|
self.flags &= ~(self.CARRY+self.NEGATIVE+self.ZERO)
|
||||||
if self.a & 1:
|
if self.a & 1:
|
||||||
@ -605,67 +661,84 @@ class MPU:
|
|||||||
self.flags |= self.ZERO
|
self.flags |= self.ZERO
|
||||||
self.a &= 255
|
self.a &= 255
|
||||||
|
|
||||||
|
@instruction(0x4c, 3, 0)
|
||||||
def i4c(self):
|
def i4c(self):
|
||||||
self.pc=self.WordAt(self.pc)
|
self.pc=self.WordAt(self.pc)
|
||||||
|
|
||||||
|
@instruction(0x4d, 4, 0)
|
||||||
def i4d(self):
|
def i4d(self):
|
||||||
self.opEOR(self.AbsoluteAddr)
|
self.opEOR(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x4e, 6, 0)
|
||||||
def i4e(self):
|
def i4e(self):
|
||||||
self.opLSR(self.AbsoluteAddr)
|
self.opLSR(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0x50, 2, 2)
|
||||||
def i50(self):
|
def i50(self):
|
||||||
self.opBCL(self.OVERFLOW)
|
self.opBCL(self.OVERFLOW)
|
||||||
|
|
||||||
|
@instruction(0x51, 5, 1)
|
||||||
def i51(self):
|
def i51(self):
|
||||||
self.opEOR(self.IndirectYAddr)
|
self.opEOR(self.IndirectYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x55, 4, 0)
|
||||||
def i55(self):
|
def i55(self):
|
||||||
self.opEOR(self.ZeroPageXAddr)
|
self.opEOR(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x56, 6, 0)
|
||||||
def i56(self):
|
def i56(self):
|
||||||
self.opLSR(self.ZeroPageXAddr)
|
self.opLSR(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x58, 2, 0)
|
||||||
def i58(self):
|
def i58(self):
|
||||||
self.opCLR(self.INTERRUPT)
|
self.opCLR(self.INTERRUPT)
|
||||||
|
|
||||||
|
@instruction(0x59, 4, 1)
|
||||||
def i59(self):
|
def i59(self):
|
||||||
self.opEOR(self.AbsoluteYAddr)
|
self.opEOR(self.AbsoluteYAddr)
|
||||||
self.pc +=2
|
self.pc +=2
|
||||||
|
|
||||||
|
@instruction(0x5d, 4, 1)
|
||||||
def i5d(self):
|
def i5d(self):
|
||||||
self.opEOR(self.AbsoluteXAddr)
|
self.opEOR(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x5e, 7, 0)
|
||||||
def i5e(self):
|
def i5e(self):
|
||||||
self.opLSR(self.AbsoluteXAddr)
|
self.opLSR(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x60, 6, 0)
|
||||||
def i60(self):
|
def i60(self):
|
||||||
self.pc=self.stPopWord()
|
self.pc=self.stPopWord()
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x61, 6, 0)
|
||||||
def i61(self):
|
def i61(self):
|
||||||
self.opADC(self.IndirectXAddr)
|
self.opADC(self.IndirectXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x65, 3, 0)
|
||||||
def i65(self):
|
def i65(self):
|
||||||
self.opADC(self.ZeroPageAddr)
|
self.opADC(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x66, 5, 0)
|
||||||
def i66(self):
|
def i66(self):
|
||||||
self.opROR(self.ZeroPageAddr)
|
self.opROR(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x68, 4, 0)
|
||||||
def i68(self):
|
def i68(self):
|
||||||
self.a = self.stPop()
|
self.a = self.stPop()
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
|
|
||||||
|
@instruction(0x69, 2, 0)
|
||||||
def i69(self):
|
def i69(self):
|
||||||
data = self.ImmediateByte()
|
data = self.ImmediateByte()
|
||||||
|
|
||||||
@ -702,6 +775,7 @@ class MPU:
|
|||||||
self.a=data
|
self.a=data
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0x6a, 2, 0)
|
||||||
def i6a(self):
|
def i6a(self):
|
||||||
if self.flags & self.CARRY:
|
if self.flags & self.CARRY:
|
||||||
if (self.a & 1) == 0:
|
if (self.a & 1) == 0:
|
||||||
@ -714,212 +788,265 @@ class MPU:
|
|||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.a &= 255
|
self.a &= 255
|
||||||
|
|
||||||
|
@instruction(0x6c, 5, 0)
|
||||||
def i6c(self):
|
def i6c(self):
|
||||||
ta = self.WordAt(self.pc)
|
ta = self.WordAt(self.pc)
|
||||||
self.pc = self.WordAt(ta)
|
self.pc = self.WordAt(ta)
|
||||||
|
|
||||||
|
@instruction(0x6d, 4, 0)
|
||||||
def i6d(self):
|
def i6d(self):
|
||||||
self.opADC(self.AbsoluteAddr)
|
self.opADC(self.AbsoluteAddr)
|
||||||
self.pc +=2
|
self.pc +=2
|
||||||
|
|
||||||
|
@instruction(0x6e, 6, 0)
|
||||||
def i6e(self):
|
def i6e(self):
|
||||||
self.opROR(self.AbsoluteAddr)
|
self.opROR(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x70, 2, 2)
|
||||||
def i70(self):
|
def i70(self):
|
||||||
self.opBST(self.OVERFLOW)
|
self.opBST(self.OVERFLOW)
|
||||||
|
|
||||||
|
@instruction(0x71, 5, 1)
|
||||||
def i71(self):
|
def i71(self):
|
||||||
self.opADC(self.IndirectYAddr)
|
self.opADC(self.IndirectYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x75, 4, 0)
|
||||||
def i75(self):
|
def i75(self):
|
||||||
self.opADC(self.ZeroPageXAddr)
|
self.opADC(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x76, 6, 0)
|
||||||
def i76(self):
|
def i76(self):
|
||||||
self.opROR(self.ZeroPageXAddr)
|
self.opROR(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x78, 2, 0)
|
||||||
def i78(self):
|
def i78(self):
|
||||||
self.opSET(self.INTERRUPT)
|
self.opSET(self.INTERRUPT)
|
||||||
|
|
||||||
|
@instruction(0x79, 4, 1)
|
||||||
def i79(self):
|
def i79(self):
|
||||||
self.opADC(self.AbsoluteYAddr)
|
self.opADC(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x7d, 4, 1)
|
||||||
def i7d(self):
|
def i7d(self):
|
||||||
self.opADC(self.AbsoluteXAddr)
|
self.opADC(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x7e, 7, 0)
|
||||||
def i7e(self):
|
def i7e(self):
|
||||||
self.opROR(self.AbsoluteXAddr)
|
self.opROR(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x81, 6, 0)
|
||||||
def i81(self):
|
def i81(self):
|
||||||
self.opSTA(self.IndirectXAddr)
|
self.opSTA(self.IndirectXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x84, 3, 0)
|
||||||
def i84(self):
|
def i84(self):
|
||||||
self.opSTY(self.ZeroPageAddr)
|
self.opSTY(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x85, 3, 0)
|
||||||
def i85(self):
|
def i85(self):
|
||||||
self.opSTA(self.ZeroPageAddr)
|
self.opSTA(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x86, 3, 0)
|
||||||
def i86(self):
|
def i86(self):
|
||||||
self.opSTX(self.ZeroPageAddr)
|
self.opSTX(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x88, 2, 0)
|
||||||
def i88(self):
|
def i88(self):
|
||||||
self.y -= 1
|
self.y -= 1
|
||||||
self.y&=255
|
self.y&=255
|
||||||
self.FlagsNZ(self.y)
|
self.FlagsNZ(self.y)
|
||||||
|
|
||||||
|
@instruction(0x8a, 2, 0)
|
||||||
def i8a(self):
|
def i8a(self):
|
||||||
self.a=self.x
|
self.a=self.x
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
|
|
||||||
|
@instruction(0x8c, 4, 0)
|
||||||
def i8c(self):
|
def i8c(self):
|
||||||
self.opSTY(self.AbsoluteAddr)
|
self.opSTY(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x8d, 4, 0)
|
||||||
def i8d(self):
|
def i8d(self):
|
||||||
self.opSTA(self.AbsoluteAddr)
|
self.opSTA(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x8e, 4, 0)
|
||||||
def i8e(self):
|
def i8e(self):
|
||||||
self.opSTX(self.AbsoluteAddr)
|
self.opSTX(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x90, 2, 2)
|
||||||
def i90(self):
|
def i90(self):
|
||||||
self.opBCL(self.CARRY)
|
self.opBCL(self.CARRY)
|
||||||
|
|
||||||
|
@instruction(0x91, 6, 0)
|
||||||
def i91(self):
|
def i91(self):
|
||||||
self.opSTA(self.IndirectYAddr)
|
self.opSTA(self.IndirectYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x94, 4, 0)
|
||||||
def i94(self):
|
def i94(self):
|
||||||
self.opSTY(self.ZeroPageXAddr)
|
self.opSTY(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x95, 4, 0)
|
||||||
def i95(self):
|
def i95(self):
|
||||||
self.opSTA(self.ZeroPageXAddr)
|
self.opSTA(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x96, 4, 0)
|
||||||
def i96(self):
|
def i96(self):
|
||||||
self.opSTX(self.ZeroPageYAddr)
|
self.opSTX(self.ZeroPageYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0x98, 2, 0)
|
||||||
def i98(self):
|
def i98(self):
|
||||||
self.a = self.y
|
self.a = self.y
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
|
|
||||||
|
@instruction(0x99, 5, 0)
|
||||||
def i99(self):
|
def i99(self):
|
||||||
self.opSTA(self.AbsoluteYAddr)
|
self.opSTA(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0x9a, 2, 0)
|
||||||
def i9a(self):
|
def i9a(self):
|
||||||
self.sp=self.x
|
self.sp=self.x
|
||||||
|
|
||||||
|
@instruction(0x9d, 5, 0)
|
||||||
def i9d(self):
|
def i9d(self):
|
||||||
self.opSTA(self.AbsoluteXAddr)
|
self.opSTA(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xa0, 2, 0)
|
||||||
def ia0(self):
|
def ia0(self):
|
||||||
self.y=self.ImmediateByte()
|
self.y=self.ImmediateByte()
|
||||||
self.FlagsNZ(self.y)
|
self.FlagsNZ(self.y)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xa1, 6, 0)
|
||||||
def ia1(self):
|
def ia1(self):
|
||||||
self.opLDA(self.IndirectXAddr)
|
self.opLDA(self.IndirectXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xa2, 2, 0)
|
||||||
def ia2(self):
|
def ia2(self):
|
||||||
self.x=self.ImmediateByte()
|
self.x=self.ImmediateByte()
|
||||||
self.FlagsNZ(self.x)
|
self.FlagsNZ(self.x)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xa4, 3, 0)
|
||||||
def ia4(self):
|
def ia4(self):
|
||||||
self.opLDY(self.ZeroPageAddr)
|
self.opLDY(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xa5, 3, 0)
|
||||||
def ia5(self):
|
def ia5(self):
|
||||||
self.opLDA(self.ZeroPageAddr)
|
self.opLDA(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xa6, 3, 0)
|
||||||
def ia6(self):
|
def ia6(self):
|
||||||
self.opLDX(self.ZeroPageAddr)
|
self.opLDX(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xa8, 2, 0)
|
||||||
def ia8(self):
|
def ia8(self):
|
||||||
self.y = self.a
|
self.y = self.a
|
||||||
self.FlagsNZ(self.y)
|
self.FlagsNZ(self.y)
|
||||||
|
|
||||||
|
@instruction(0xa9, 2, 0)
|
||||||
def ia9(self):
|
def ia9(self):
|
||||||
self.a = self.ImmediateByte()
|
self.a = self.ImmediateByte()
|
||||||
self.FlagsNZ(self.a)
|
self.FlagsNZ(self.a)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xaa, 2, 0)
|
||||||
def iaa(self):
|
def iaa(self):
|
||||||
self.x = self.a
|
self.x = self.a
|
||||||
self.FlagsNZ(self.x)
|
self.FlagsNZ(self.x)
|
||||||
|
|
||||||
|
@instruction(0xac, 4, 0)
|
||||||
def iac(self):
|
def iac(self):
|
||||||
self.opLDY(self.AbsoluteAddr)
|
self.opLDY(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xad, 4, 0)
|
||||||
def iad(self):
|
def iad(self):
|
||||||
self.opLDA(self.AbsoluteAddr)
|
self.opLDA(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xae, 4, 0)
|
||||||
def iae(self):
|
def iae(self):
|
||||||
self.opLDX(self.AbsoluteAddr)
|
self.opLDX(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xb0, 2, 2)
|
||||||
def ib0(self):
|
def ib0(self):
|
||||||
self.opBST(self.CARRY)
|
self.opBST(self.CARRY)
|
||||||
|
|
||||||
|
@instruction(0xb1, 5, 1)
|
||||||
def ib1(self):
|
def ib1(self):
|
||||||
self.opLDA(self.IndirectYAddr)
|
self.opLDA(self.IndirectYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xb4, 4, 0)
|
||||||
def ib4(self):
|
def ib4(self):
|
||||||
self.opLDY(self.ZeroPageXAddr)
|
self.opLDY(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xb5, 4, 0)
|
||||||
def ib5(self):
|
def ib5(self):
|
||||||
self.opLDA(self.ZeroPageXAddr)
|
self.opLDA(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xb6, 4, 0)
|
||||||
def ib6(self):
|
def ib6(self):
|
||||||
self.opLDX(self.ZeroPageYAddr)
|
self.opLDX(self.ZeroPageYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xb8, 2, 0)
|
||||||
def ib8(self):
|
def ib8(self):
|
||||||
self.opCLR(self.OVERFLOW)
|
self.opCLR(self.OVERFLOW)
|
||||||
|
|
||||||
|
@instruction(0xb9, 4, 1)
|
||||||
def ib9(self):
|
def ib9(self):
|
||||||
self.opLDA(self.AbsoluteYAddr)
|
self.opLDA(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xba, 2, 0)
|
||||||
def iba(self):
|
def iba(self):
|
||||||
self.x = self.sp
|
self.x = self.sp
|
||||||
self.FlagsNZ(self.x)
|
self.FlagsNZ(self.x)
|
||||||
|
|
||||||
|
@instruction(0xbc, 4, 1)
|
||||||
def ibc(self):
|
def ibc(self):
|
||||||
self.opLDY(self.AbsoluteXAddr)
|
self.opLDY(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xbd, 4, 1)
|
||||||
def ibd(self):
|
def ibd(self):
|
||||||
self.opLDA(self.AbsoluteXAddr)
|
self.opLDA(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xbe, 4, 1)
|
||||||
def ibe(self):
|
def ibe(self):
|
||||||
self.opLDX(self.AbsoluteYAddr)
|
self.opLDX(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xc0, 2, 0)
|
||||||
def ic0(self):
|
def ic0(self):
|
||||||
tbyte = self.ImmediateByte()
|
tbyte = self.ImmediateByte()
|
||||||
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
|
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
|
||||||
@ -931,27 +1058,33 @@ class MPU:
|
|||||||
self.flags |= self.NEGATIVE
|
self.flags |= self.NEGATIVE
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xc1, 6, 0)
|
||||||
def ic1(self):
|
def ic1(self):
|
||||||
self.opCMP(self.IndirectXAddr)
|
self.opCMP(self.IndirectXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xc4, 3, 0)
|
||||||
def ic4(self):
|
def ic4(self):
|
||||||
self.opCPY(self.ZeroPageAddr)
|
self.opCPY(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xc5, 3, 0)
|
||||||
def ic5(self):
|
def ic5(self):
|
||||||
self.opCMP(self.ZeroPageAddr)
|
self.opCMP(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xc6, 5, 0)
|
||||||
def ic6(self):
|
def ic6(self):
|
||||||
self.opDECR(self.ZeroPageAddr)
|
self.opDECR(self.ZeroPageAddr)
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xc8, 2, 0)
|
||||||
def ic8(self):
|
def ic8(self):
|
||||||
self.y += 1
|
self.y += 1
|
||||||
self.y &= 255
|
self.y &= 255
|
||||||
self.FlagsNZ(self.y)
|
self.FlagsNZ(self.y)
|
||||||
|
|
||||||
|
@instruction(0xc9, 2, 0)
|
||||||
def ic9(self):
|
def ic9(self):
|
||||||
tbyte = self.ImmediateByte()
|
tbyte = self.ImmediateByte()
|
||||||
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
|
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
|
||||||
@ -963,53 +1096,66 @@ class MPU:
|
|||||||
self.flags |= self.NEGATIVE
|
self.flags |= self.NEGATIVE
|
||||||
self.pc +=1
|
self.pc +=1
|
||||||
|
|
||||||
|
@instruction(0xca, 2, 0)
|
||||||
def ica(self):
|
def ica(self):
|
||||||
self.x -= 1
|
self.x -= 1
|
||||||
self.x &= 255
|
self.x &= 255
|
||||||
self.FlagsNZ(self.x)
|
self.FlagsNZ(self.x)
|
||||||
|
|
||||||
|
@instruction(0xcc, 4, 0)
|
||||||
def icc(self):
|
def icc(self):
|
||||||
self.opCPY(self.AbsoluteAddr)
|
self.opCPY(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xcd, 4, 0)
|
||||||
def icd(self):
|
def icd(self):
|
||||||
self.opCMP(self.AbsoluteAddr)
|
self.opCMP(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xce, 3, 0)
|
||||||
def ice(self):
|
def ice(self):
|
||||||
self.opDECR(self.AbsoluteAddr)
|
self.opDECR(self.AbsoluteAddr)
|
||||||
self.pc += 2
|
self.pc += 2
|
||||||
|
|
||||||
|
@instruction(0xd0, 2, 2)
|
||||||
def id0(self):
|
def id0(self):
|
||||||
self.opBCL(self.ZERO)
|
self.opBCL(self.ZERO)
|
||||||
|
|
||||||
|
@instruction(0xd1, 5, 1)
|
||||||
def id1(self):
|
def id1(self):
|
||||||
self.opCMP(self.IndirectYAddr)
|
self.opCMP(self.IndirectYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xd5, 4, 0)
|
||||||
def id5(self):
|
def id5(self):
|
||||||
self.opCMP(self.ZeroPageXAddr)
|
self.opCMP(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xd6, 6, 0)
|
||||||
def id6(self):
|
def id6(self):
|
||||||
self.opDECR(self.ZeroPageXAddr)
|
self.opDECR(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xd8, 2, 0)
|
||||||
def id8(self):
|
def id8(self):
|
||||||
self.opCLR(self.DECIMAL)
|
self.opCLR(self.DECIMAL)
|
||||||
|
|
||||||
|
@instruction(0xd9, 4, 1)
|
||||||
def id9(self):
|
def id9(self):
|
||||||
self.opCMP(self.AbsoluteYAddr)
|
self.opCMP(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xdd, 4, 1)
|
||||||
def idd(self):
|
def idd(self):
|
||||||
self.opCMP(self.AbsoluteXAddr)
|
self.opCMP(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xde, 7, 0)
|
||||||
def ide(self):
|
def ide(self):
|
||||||
self.opDECR(self.AbsoluteXAddr)
|
self.opDECR(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xe0, 2, 0)
|
||||||
def ie0(self):
|
def ie0(self):
|
||||||
tbyte = self.ImmediateByte()
|
tbyte = self.ImmediateByte()
|
||||||
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
|
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
|
||||||
@ -1021,27 +1167,33 @@ class MPU:
|
|||||||
self.flags |= self.NEGATIVE
|
self.flags |= self.NEGATIVE
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xe1, 6, 0)
|
||||||
def ie1(self):
|
def ie1(self):
|
||||||
self.opSBC(self.IndirectXAddr)
|
self.opSBC(self.IndirectXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xe4, 3, 0)
|
||||||
def ie4(self):
|
def ie4(self):
|
||||||
self.opCPX(self.ZeroPageAddr)
|
self.opCPX(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xe5, 3, 0)
|
||||||
def ie5(self):
|
def ie5(self):
|
||||||
self.opSBC(self.ZeroPageAddr)
|
self.opSBC(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xe6, 5, 0)
|
||||||
def ie6(self):
|
def ie6(self):
|
||||||
self.opINCR(self.ZeroPageAddr)
|
self.opINCR(self.ZeroPageAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xe8, 2, 0)
|
||||||
def ie8(self):
|
def ie8(self):
|
||||||
self.x+=1
|
self.x+=1
|
||||||
self.x&=255
|
self.x&=255
|
||||||
self.FlagsNZ(self.x)
|
self.FlagsNZ(self.x)
|
||||||
|
|
||||||
|
@instruction(0xe9, 2, 0)
|
||||||
def ie9(self):
|
def ie9(self):
|
||||||
data=self.ImmediateByte()
|
data=self.ImmediateByte()
|
||||||
|
|
||||||
@ -1078,128 +1230,60 @@ class MPU:
|
|||||||
self.a = data
|
self.a = data
|
||||||
self.pc += 1
|
self.pc += 1
|
||||||
|
|
||||||
|
@instruction(0xea, 2, 0)
|
||||||
def iea(self):
|
def iea(self):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@instruction(0xec, 4, 0)
|
||||||
def iec(self):
|
def iec(self):
|
||||||
self.opCPX(self.AbsoluteAddr)
|
self.opCPX(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xed, 4, 0)
|
||||||
def ied(self):
|
def ied(self):
|
||||||
self.opSBC(self.AbsoluteAddr)
|
self.opSBC(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xee, 6, 0)
|
||||||
def iee(self):
|
def iee(self):
|
||||||
self.opINCR(self.AbsoluteAddr)
|
self.opINCR(self.AbsoluteAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xf0, 2, 2)
|
||||||
def if0(self):
|
def if0(self):
|
||||||
self.opBST(self.ZERO)
|
self.opBST(self.ZERO)
|
||||||
|
|
||||||
|
@instruction(0xf1, 5, 1)
|
||||||
def if1(self):
|
def if1(self):
|
||||||
self.opSBC(self.IndirectYAddr)
|
self.opSBC(self.IndirectYAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xf5, 4, 0)
|
||||||
def if5(self):
|
def if5(self):
|
||||||
self.opSBC(self.ZeroPageXAddr)
|
self.opSBC(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xf6, 6, 0)
|
||||||
def if6(self):
|
def if6(self):
|
||||||
self.opINCR(self.ZeroPageXAddr)
|
self.opINCR(self.ZeroPageXAddr)
|
||||||
self.pc+=1
|
self.pc+=1
|
||||||
|
|
||||||
|
@instruction(0xf8, 2, 0)
|
||||||
def if8(self):
|
def if8(self):
|
||||||
self.opSET(self.DECIMAL)
|
self.opSET(self.DECIMAL)
|
||||||
|
|
||||||
|
@instruction(0xf9, 4, 1)
|
||||||
def if9(self):
|
def if9(self):
|
||||||
self.opSBC(self.AbsoluteYAddr)
|
self.opSBC(self.AbsoluteYAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xfd, 4, 1)
|
||||||
def ifd(self):
|
def ifd(self):
|
||||||
self.opSBC(self.AbsoluteXAddr)
|
self.opSBC(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
|
@instruction(0xfe, 7, 0)
|
||||||
def ife(self):
|
def ife(self):
|
||||||
self.opINCR(self.AbsoluteXAddr)
|
self.opINCR(self.AbsoluteXAddr)
|
||||||
self.pc+=2
|
self.pc+=2
|
||||||
|
|
||||||
def ini(self):
|
|
||||||
if self.debug:
|
|
||||||
raise NotImplementedError
|
|
||||||
self.pc+=1
|
|
||||||
|
|
||||||
|
|
||||||
# code pages
|
|
||||||
|
|
||||||
instruct = [
|
|
||||||
i00, i01, ini, ini, ini, i05, i06, ini,
|
|
||||||
i08, i09, i0a, ini, ini, i0d, i0e, ini,
|
|
||||||
i10, i11, ini, ini, ini, i15, i16, ini,
|
|
||||||
i18, i19, ini, ini, ini, i1d, i1e, ini,
|
|
||||||
i20, i21, ini, ini, i24, i25, i26, ini,
|
|
||||||
i28, i29, i2a, ini, i2c, i2d, i2e, ini,
|
|
||||||
i30, i31, ini, ini, ini, i35, i36, ini,
|
|
||||||
i38, i39, ini, ini, ini, i3d, i3e, ini,
|
|
||||||
i40, i41, ini, ini, ini, i45, i46, ini,
|
|
||||||
i48, i49, i4a, ini, i4c, i4d, i4e, ini,
|
|
||||||
i50, i51, ini, ini, ini, i55, i56, ini,
|
|
||||||
i58, i59, ini, ini, ini, i5d, i5e, ini,
|
|
||||||
i60, i61, ini, ini, ini, i65, i66, ini,
|
|
||||||
i68, i69, i6a, ini, i6c, i6d, i6e, ini,
|
|
||||||
i70, i71, ini, ini, ini, i75, i76, ini,
|
|
||||||
i78, i79, ini, ini, ini, i7d, i7e, ini,
|
|
||||||
ini, i81, ini, ini, i84, i85, i86, ini,
|
|
||||||
i88, ini, i8a, ini, i8c, i8d, i8e, ini,
|
|
||||||
i90, i91, ini, ini, i94, i95, i96, ini,
|
|
||||||
i98, i99, i9a, ini, ini, i9d, ini, ini,
|
|
||||||
ia0, ia1, ia2, ini, ia4, ia5, ia6, ini,
|
|
||||||
ia8, ia9, iaa, ini, iac, iad, iae, ini,
|
|
||||||
ib0, ib1, ini, ini, ib4, ib5, ib6, ini,
|
|
||||||
ib8, ib9, iba, ini, ibc, ibd, ibe, ini,
|
|
||||||
ic0, ic1, ini, ini, ic4, ic5, ic6, ini,
|
|
||||||
ic8, ic9, ica, ini, icc, icd, ice, ini,
|
|
||||||
id0, id1, ini, ini, ini, id5, id6, ini,
|
|
||||||
id8, id9, ini, ini, ini, idd, ide, ini,
|
|
||||||
ie0, ie1, ini, ini, ie4, ie5, ie6, ini,
|
|
||||||
ie8, ie9, iea, ini, iec, ied, iee, ini,
|
|
||||||
if0, if1, ini, ini, ini, if5, if6, ini,
|
|
||||||
if8, if9, ini, ini, ini, ifd, ife, ini
|
|
||||||
]
|
|
||||||
|
|
||||||
cycletime = [
|
|
||||||
7, 6, 0, 0, 0, 3, 5, 0, 3, 2, 2, 0, 0, 4, 6, 0, # 00
|
|
||||||
2, 5, 0, 0, 0, 4, 6, 0, 2, 4, 0, 0, 0, 4, 7, 0, # 10
|
|
||||||
6, 6, 0, 0, 3, 3, 5, 0, 4, 2, 2, 0, 4, 4, 6, 0, # 20
|
|
||||||
2, 5, 0, 0, 0, 4, 6, 0, 2, 4, 0, 0, 0, 4, 7, 0, # 30
|
|
||||||
6, 6, 0, 0, 0, 3, 5, 0, 3, 2, 2, 0, 3, 4, 6, 0, # 40
|
|
||||||
2, 5, 0, 0, 0, 4, 6, 0, 2, 4, 0, 0, 0, 4, 7, 0, # 50
|
|
||||||
6, 6, 0, 0, 0, 3, 5, 0, 4, 2, 2, 0, 5, 4, 6, 0, # 60
|
|
||||||
2, 5, 0, 0, 0, 4, 6, 0, 2, 4, 0, 0, 0, 4, 7, 0, # 70
|
|
||||||
0, 6, 0, 0, 3, 3, 3, 0, 2, 0, 2, 0, 4, 4, 4, 0, # 80
|
|
||||||
2, 6, 0, 0, 4, 4, 4, 0, 2, 5, 2, 0, 0, 5, 0, 0, # 90
|
|
||||||
2, 6, 2, 0, 3, 3, 3, 0, 2, 2, 2, 0, 4, 4, 4, 0, # A0
|
|
||||||
2, 5, 0, 0, 4, 4, 4, 0, 2, 4, 2, 0, 4, 4, 4, 0, # B0
|
|
||||||
2, 6, 0, 0, 3, 3, 5, 0, 2, 2, 2, 0, 4, 4, 3, 0, # C0
|
|
||||||
2, 5, 0, 0, 0, 4, 6, 0, 2, 4, 0, 0, 0, 4, 7, 0, # D0
|
|
||||||
2, 6, 0, 0, 3, 3, 5, 0, 2, 2, 2, 0, 4, 4, 6, 0, # E0
|
|
||||||
2, 5, 0, 0, 0, 4, 6, 0, 2, 4, 0, 0, 0, 4, 7, 0 # F0
|
|
||||||
]
|
|
||||||
|
|
||||||
extracycles = [
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # 00
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, # 10
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # 20
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, # 30
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # 40
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, # 50
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # 60
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, # 70
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # 80
|
|
||||||
2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # 90
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # A0
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 1, 1, 0, # B0
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # C0
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0, # D0
|
|
||||||
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, # E0
|
|
||||||
2, 1, 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 0, 0 # F0
|
|
||||||
]
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user