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

Test register values.

This commit is contained in:
Thomas Harte 2024-03-09 15:11:12 -05:00
parent a4cf86268e
commit a2896b9bd0

View File

@ -61,6 +61,18 @@ struct Memory {
std::array<uint8_t, 4*1024*1024> ram_{}; std::array<uint8_t, 4*1024*1024> ram_{};
}; };
struct MemoryLedger {
template <typename IntT>
bool write(uint32_t address, IntT source, Mode, bool) {
return false; // TODO.
}
template <typename IntT>
bool read(uint32_t address, IntT &source, Mode, bool) {
return false; // TODO.
}
};
} }
@interface ARMDecoderTests : XCTestCase @interface ARMDecoderTests : XCTestCase
@ -293,31 +305,48 @@ struct Memory {
input >> std::hex; input >> std::hex;
uint32_t instruction; using Exec = Executor<Model::ARMv2, MemoryLedger>;
std::unique_ptr<Exec> test;
uint32_t instruction = 0;
while(!input.eof()) { while(!input.eof()) {
std::string label; std::string label;
input >> label; input >> label;
if(label == "**") { if(label == "**") {
input >> instruction; input >> instruction;
test = std::make_unique<Exec>();
continue; continue;
} }
if(label == "Before:" || label == "After:") { if(label == "Before:" || label == "After:") {
// Read register state. // Read register state.
uint32_t regs[17]; uint32_t regs[16];
for(int c = 0; c < 17; c++) { for(int c = 0; c < 16; c++) {
input >> regs[c]; input >> regs[c];
} }
auto &registers = test->registers();
if(label == "Before:") { if(label == "Before:") {
// This is the start of a new test. // This is the start of a new test.
registers.set_pc(regs[15] - 8);
registers.set_status(regs[15]);
for(uint32_t c = 0; c < 15; c++) {
registers[c] = regs[c];
}
} else { } else {
// Execute test and compare. // Execute test and compare.
execute<Model::ARMv2>(instruction, *test);
for(uint32_t c = 0; c < 15; c++) {
XCTAssertEqual(regs[c], registers[c]);
}
} }
continue; continue;
} }
// TODO: supply information below to ledger, and then use and test it.
uint32_t address; uint32_t address;
uint32_t value; uint32_t value;
input >> address >> value; input >> address >> value;