2019-04-29 16:11:01 -04:00
|
|
|
//
|
|
|
|
// Comparative68000.hpp
|
|
|
|
// Clock SignalTests
|
|
|
|
//
|
|
|
|
// Created by Thomas Harte on 29/04/2019.
|
|
|
|
// Copyright © 2019 Thomas Harte. All rights reserved.
|
|
|
|
//
|
|
|
|
|
2024-01-16 23:34:46 -05:00
|
|
|
#pragma once
|
2019-04-29 16:11:01 -04:00
|
|
|
|
|
|
|
#include <zlib.h>
|
|
|
|
|
2023-05-10 17:13:01 -05:00
|
|
|
#include "68000.hpp"
|
2019-04-29 16:11:01 -04:00
|
|
|
|
2023-05-10 17:13:01 -05:00
|
|
|
class ComparativeBusHandler: public CPU::MC68000::BusHandler {
|
2019-04-29 16:11:01 -04:00
|
|
|
public:
|
|
|
|
ComparativeBusHandler(const char *trace_name) {
|
|
|
|
trace = gzopen(trace_name, "rt");
|
|
|
|
}
|
|
|
|
|
|
|
|
~ComparativeBusHandler() {
|
|
|
|
gzclose(trace);
|
|
|
|
}
|
|
|
|
|
2020-09-26 22:31:50 -04:00
|
|
|
void will_perform(uint32_t address, uint16_t) {
|
2019-04-29 16:11:01 -04:00
|
|
|
// Obtain the next line from the trace file.
|
|
|
|
char correct_state[300] = "\n";
|
|
|
|
gzgets(trace, correct_state, sizeof(correct_state));
|
|
|
|
++line_count;
|
|
|
|
|
|
|
|
// Generate state locally.
|
2022-05-25 11:32:00 -04:00
|
|
|
const auto state = get_state().registers;
|
2019-04-29 16:11:01 -04:00
|
|
|
char local_state[300];
|
2022-11-11 20:29:59 -05:00
|
|
|
snprintf(local_state, sizeof(local_state), "%04x: %02x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x %08x\n",
|
2019-04-29 16:11:01 -04:00
|
|
|
address,
|
|
|
|
state.status,
|
|
|
|
state.data[0], state.data[1], state.data[2], state.data[3], state.data[4], state.data[5], state.data[6], state.data[7],
|
|
|
|
state.address[0], state.address[1], state.address[2], state.address[3], state.address[4], state.address[5], state.address[6],
|
2022-05-25 11:32:00 -04:00
|
|
|
state.stack_pointer()
|
2019-04-29 16:11:01 -04:00
|
|
|
);
|
|
|
|
|
|
|
|
// Check that the two coincide.
|
|
|
|
if(strcmp(correct_state, local_state)) {
|
|
|
|
fprintf(stderr, "Diverges at line %d\n", line_count);
|
2019-04-29 16:55:21 -04:00
|
|
|
fprintf(stderr, "Good: %s", correct_state);
|
|
|
|
fprintf(stderr, "Bad: %s", local_state);
|
2020-09-26 22:31:50 -04:00
|
|
|
throw std::exception();
|
2019-04-29 16:11:01 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-05-10 17:13:01 -05:00
|
|
|
virtual CPU::MC68000::State get_state() = 0;
|
2019-04-29 16:11:01 -04:00
|
|
|
|
|
|
|
private:
|
|
|
|
int line_count = 0;
|
|
|
|
gzFile trace;
|
|
|
|
};
|