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:
parent
fafd1801fe
commit
0c1c10bc66
@ -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
|
||||||
|
@ -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.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user