1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-12 00:30:31 +00:00

Introduces a test that proves that DIVS' attempt to set proper timing isn't working.

This commit is contained in:
Thomas Harte 2019-06-20 19:29:02 -04:00
parent fafd1801fe
commit 0c1c10bc66
2 changed files with 34 additions and 7 deletions

View File

@ -12,7 +12,7 @@
#include <cassert> #include <cassert>
#define LOG_TRACE #define LOG_TRACE
#include "68000.hpp" #include "../../../Processors/68000/68000.hpp"
using Flag = CPU::MC68000::Flag; using Flag = CPU::MC68000::Flag;
@ -103,7 +103,7 @@ class RAM68000: public CPU::MC68000::BusHandler {
} }
int get_cycle_count() { int get_cycle_count() {
return 0; return (duration_.as_int() >> 1) - 26; // TODO: 26 doesn't sound right for RESET. Check.
} }
private: private:
@ -1048,21 +1048,47 @@ class CPU::MC68000::ProcessorStorageTests {
// MARK: DIVS // MARK: DIVS
- (void)testDIVSOverflow { - (void)performDivide:(uint16_t)divisor a1:(uint32_t)a1 {
_machine->set_program({ _machine->set_program({
0x83fc, 0x0001 // DIVS #1, D1 0x83fc, divisor // DIVS #$eef0, D1
}); });
auto state = _machine->get_processor_state(); auto state = _machine->get_processor_state();
state.data[1] = 0x4768f231; state.data[1] = a1;
state.status = Flag::ConditionCodes; state.status = Flag::ConditionCodes;
_machine->set_processor_state(state); _machine->set_processor_state(state);
_machine->run_for_instructions(2); _machine->run_for_instructions(2);
}
state = _machine->get_processor_state(); - (void)performDIVSOverflowTestDivisor:(uint16_t)divisor {
[self performDivide:divisor a1:0x4768f231];
const auto state = _machine->get_processor_state();
XCTAssertEqual(state.data[1], 0x4768f231); XCTAssertEqual(state.data[1], 0x4768f231);
XCTAssertEqual(state.status & Flag::ConditionCodes, Flag::Extend | Flag::Negative | Flag::Overflow); XCTAssertEqual(state.status & Flag::ConditionCodes, Flag::Extend | Flag::Negative | Flag::Overflow);
// Test: 20 cycles passed. XCTAssertEqual(20, _machine->get_cycle_count());
}
- (void)testDIVSOverflow {
[self performDIVSOverflowTestDivisor:1];
}
- (void)testDIVSOverflow2 {
[self performDIVSOverflowTestDivisor:0x1234];
}
- (void)testDIVSUnderflow {
[self performDIVSOverflowTestDivisor:0xeeff];
}
- (void)testDIVS {
[self performDivide:0xeef0 a1:0x0768f231];
const auto state = _machine->get_processor_state();
XCTAssertEqual(state.data[1], 0x026190D3);
XCTAssertEqual(state.status & Flag::ConditionCodes, Flag::Extend | Flag::Negative);
XCTAssertEqual(138, _machine->get_cycle_count());
} }
// MARK: MOVE USP // MARK: MOVE USP

View File

@ -1051,6 +1051,7 @@ template <class T, bool dtack_is_implicit, bool signal_will_perform> void Proces
int positive_quotient = abs(quotient); int positive_quotient = abs(quotient);
for(int c = 0; c < 15; ++c) { for(int c = 0; c < 15; ++c) {
if(positive_quotient & 0x8000) cycles_expended += 2; if(positive_quotient & 0x8000) cycles_expended += 2;
positive_quotient <<= 1;
} }
// There's then no way to terminate the loop that isn't at least six cycles long. // There's then no way to terminate the loop that isn't at least six cycles long.