2015-07-16 20:52:16 -04:00
|
|
|
//
|
|
|
|
// KlausDormanTests.swift
|
|
|
|
// Clock Signal
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 16/07/2015.
|
|
|
|
// Copyright © 2015 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
import Foundation
|
|
|
|
import XCTest
|
|
|
|
|
|
|
|
class KlausDormannTests: XCTestCase {
|
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
func testKlausDormann() {
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
func errorForTrapAddress(address: UInt16) -> String? {
|
|
|
|
let hexAddress = String(format:"%04x", address)
|
|
|
|
switch address {
|
|
|
|
case 0x3399: return nil // success!
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
case 0x33a7: return "Decimal ADC result has wrong value"
|
|
|
|
case 0x3502: return "Binary SBC result has wrong value"
|
|
|
|
case 0x33b9: return "Decimal SBC result has wrong value"
|
|
|
|
case 0x33c0: return "Decimal SBC wrong carry flag"
|
2015-07-16 20:52:16 -04:00
|
|
|
case 0x36d1: return "BRK: unexpected BRK or IRQ"
|
|
|
|
case 0x36ac, 0x36f6: return "Improper JSR return address on stack"
|
|
|
|
case 0x36e5: return "BRK flag not set on stack"
|
|
|
|
case 0x26d2: return "ASL zpg,x produced incorrect flags"
|
2015-07-31 16:44:53 -04:00
|
|
|
case 0x36c6: return "Unexpected RESET"
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
default: return "Unknown error at \(hexAddress)"
|
|
|
|
}
|
|
|
|
}
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
if let filename = NSBundle(forClass: self.dynamicType).pathForResource("6502_functional_test", ofType: "bin") {
|
|
|
|
if let functionalTest = NSData(contentsOfFile: filename) {
|
|
|
|
let machine = CSTestMachine()
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
machine.setData(functionalTest, atAddress: 0)
|
|
|
|
machine.setValue(0x400, forRegister: CSTestMachineRegister.ProgramCounter)
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
while true {
|
|
|
|
let oldPC = machine.valueForRegister(CSTestMachineRegister.LastOperationAddress)
|
|
|
|
machine.runForNumberOfCycles(1000)
|
|
|
|
let newPC = machine.valueForRegister(CSTestMachineRegister.LastOperationAddress)
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
if newPC == oldPC {
|
|
|
|
let error = errorForTrapAddress(oldPC)
|
2015-07-16 20:52:16 -04:00
|
|
|
|
2015-07-30 20:51:32 -04:00
|
|
|
if let error = error {
|
|
|
|
NSException(name: "Failed test", reason: error, userInfo: nil).raise()
|
|
|
|
} else {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-07-16 20:52:16 -04:00
|
|
|
}
|