2017-06-05 23:24:08 +01:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "FuseTest.h"
|
|
|
|
#include "FuseExpectedTestResult.h"
|
|
|
|
|
2017-09-07 01:04:09 +01:00
|
|
|
#include <Ram.h>
|
|
|
|
#include <Bus.h>
|
|
|
|
#include <InputOutput.h>
|
|
|
|
#include <Z80.h>
|
2017-06-05 23:24:08 +01:00
|
|
|
|
|
|
|
namespace Fuse {
|
2017-09-07 01:04:09 +01:00
|
|
|
class TestRunner : public EightBit::Bus {
|
2017-06-05 23:24:08 +01:00
|
|
|
private:
|
|
|
|
const Test& m_test;
|
|
|
|
const ExpectedTestResult& m_expected;
|
|
|
|
|
2017-12-10 21:41:48 +00:00
|
|
|
bool m_failed = false;
|
|
|
|
bool m_unimplemented = false;
|
2017-06-05 23:24:08 +01:00
|
|
|
|
2017-12-10 21:41:48 +00:00
|
|
|
EightBit::Ram m_ram = 0x10000;
|
2017-06-05 23:24:08 +01:00
|
|
|
EightBit::InputOutput m_ports;
|
|
|
|
EightBit::Z80 m_cpu;
|
|
|
|
|
|
|
|
void initialiseRegisters();
|
|
|
|
void initialiseMemory();
|
|
|
|
|
|
|
|
void check();
|
|
|
|
void checkregisters();
|
|
|
|
void checkMemory();
|
|
|
|
|
|
|
|
void dumpDifference(const std::string& description, uint8_t high, uint8_t low) const;
|
|
|
|
void dumpDifference(
|
|
|
|
const std::string& highDescription,
|
|
|
|
const std::string& lowDescription,
|
|
|
|
EightBit::register16_t actual, EightBit::register16_t expected) const;
|
|
|
|
|
2017-09-07 01:04:09 +01:00
|
|
|
protected:
|
2018-09-15 14:35:59 +01:00
|
|
|
virtual EightBit::MemoryMapping mapping(uint16_t address) final {
|
2018-12-01 15:24:29 +00:00
|
|
|
return { m_ram, 0x0000, 0xffff, EightBit::MemoryMapping::AccessLevel::ReadWrite };
|
2017-09-07 01:04:09 +01:00
|
|
|
}
|
|
|
|
|
2017-06-05 23:24:08 +01:00
|
|
|
public:
|
|
|
|
TestRunner(const Test& test, const ExpectedTestResult& expected);
|
|
|
|
|
|
|
|
void run();
|
|
|
|
bool failed() const { return m_failed; }
|
|
|
|
bool unimplemented() const { return m_unimplemented; }
|
2018-11-11 16:48:44 +00:00
|
|
|
|
2019-01-14 02:10:17 +00:00
|
|
|
virtual void raisePOWER() final;
|
|
|
|
virtual void lowerPOWER() final;
|
|
|
|
|
|
|
|
virtual void initialise() final;
|
2017-06-05 23:24:08 +01:00
|
|
|
};
|
|
|
|
}
|