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:
parent
a4cf86268e
commit
a2896b9bd0
@ -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 ®isters = 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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user