1
0
mirror of https://github.com/mnaberez/py65.git synced 2025-01-21 06:30:15 +00:00

Fix bugs in cycle counting and CPY ().

This commit is contained in:
Mike Naberezny 2008-09-08 03:43:11 +00:00
parent 2f178e3fb7
commit e7ee1d0b6e

12
mpu.py
View File

@ -1,4 +1,4 @@
from bcd_conversion import convert_to_bin, convert_to_bcd
from util import convert_to_bin, convert_to_bcd
class MPU:
# vectors
@ -86,7 +86,7 @@ class MPU:
a1 = self.WordAt(self.ByteAt(self.pc))
a2 = (a1+self.y) & 0xffff
if (a1 & 0xff00) != (a2 & 0xff00):
self.extracycles += 1
self.excycles += 1
return a2
else:
return (self.WordAt(self.ByteAt(self.pc))+self.y)&0xffff
@ -99,7 +99,7 @@ class MPU:
a1 = self.WordAt(self.pc)
a2 = (a1 + self.x) & 0xffff
if (a1 & 0xff00) != (a2 & 0xff00):
self.extracycles += 1
self.excycles += 1
return a2
else:
return (self.WordAt(self.pc)+self.x)&0xffff
@ -109,7 +109,7 @@ class MPU:
a1 = self.WordAt(self.pc)
a2 = (a1 + self.y) & 0xffff
if (a1 & 0xff00) != (a2 & 0xff00):
self.extracycles += 1
self.excycles += 1
return a2
else:
return (self.WordAt(self.pc)+self.y)&0xffff
@ -916,9 +916,9 @@ class MPU:
def ic0(self):
tbyte = self.ImmediateByte()
self.flags &= ~(self.CARRY+self.ZERO+self.NEGATIVE)
if y == tbyte:
if self.y == tbyte:
self.flags |= self.CARRY+self.ZERO
elif y > tbyte:
elif self.y > tbyte:
self.flags |= self.CARRY
else:
self.flags |= self.NEGATIVE