application exit error handing

This commit is contained in:
Blaise Tine
2021-06-29 02:04:07 -04:00
parent 3a0a9edaca
commit d684a2e632
43 changed files with 89446 additions and 212932 deletions

View File

@@ -243,19 +243,26 @@ bool Simulator::is_busy() const {
return vortex_->busy;
}
void Simulator::run() {
int Simulator::run() {
int exitcode = 0;
#ifndef NDEBUG
std::cout << std::dec << timestamp << ": [sim] run()" << std::endl;
#endif
// execute program
while (vortex_->busy
&& !get_ebreak()) {
while (vortex_->busy) {
if (get_ebreak()) {
exitcode = get_last_wb_value(3);
break;
}
this->step();
}
// wait 5 cycles to flush the pipeline
this->wait(5);
return exitcode;
}
bool Simulator::get_ebreak() const {

View File

@@ -42,11 +42,7 @@ public:
void step();
void wait(uint32_t cycles);
void run();
int get_last_wb_value(int reg) const;
bool get_ebreak() const;
int run();
void print_stats(std::ostream& out);
@@ -63,7 +59,11 @@ private:
void eval();
void eval_mem_bus();
void eval_mem_bus();
int get_last_wb_value(int reg) const;
bool get_ebreak() const;
std::list<mem_req_t> mem_rsp_vec_ [MEMORY_BANKS];
uint32_t last_mem_rsp_bank_;

View File

@@ -106,49 +106,54 @@ int main(int argc, char **argv) {
};
for (std::string test : tests) {
std::cout << "\n---------------------------------------\n";
std::cout << "\n***************************************\n";
std::cout << test << std::endl;
RAM ram;
Simulator simulator;
simulator.attach_ram(&ram);
simulator.load_ihex(test.c_str());
simulator.run();
int exitcode = simulator.run();
bool status = (1 == simulator.get_last_wb_value(3));
if (1 == exitcode) {
std::cout << "Passed" << std::endl;
} else {
std::cout << "Failed: exitcode=" << exitcode << std::endl;
passed = false;
}
if (status) std::cout << "Passed: " << test << std::endl;
if (!status) std::cout << "Failed: " << test << std::endl;
passed = passed && status;
if (!passed)
break;
}
for (std::string test : tests_fp) {
std::cout << "\n---------------------------------------\n";
std::cout << "\n***************************************\n";
std::cout << test << std::endl;
RAM ram;
Simulator simulator;
simulator.attach_ram(&ram);
simulator.load_ihex(test.c_str());
simulator.run();
int exitcode = simulator.run();
bool status = (1 == simulator.get_last_wb_value(3));
if (1 == exitcode) {
std::cout << "Passed" << std::endl;
} else {
std::cout << "Failed: exitcode=" << exitcode << std::endl;
passed = false;
}
if (status) std::cout << "Passed: " << test << std::endl;
if (!status) std::cout << "Failed: " << test << std::endl;
passed = passed && status;
if (!passed)
break;
}
std::cout << "\n***************************************\n";
if (passed) std::cout << "PASSED ALL TESTS\n";
if (!passed) std::cout << "Failed one or more tests\n";
if (passed) {
std::cout << "PASSED ALL TESTS\n";
} else {
std::cout << "Failed one or more tests\n";
}
#else
@@ -160,30 +165,43 @@ int main(int argc, char **argv) {
Simulator simulator;
simulator.attach_ram(&ram);
simulator.load_ihex(test);
simulator.run();
int exitcode = simulator.run();
if (exitcode != 0) {
std::cout << "*** error: exitcode=" << exitcode << std::endl;
passed = false;
}
#endif
} else {
} else {
parse_args(argc, argv);
for (auto program : programs) {
std::cout << "Running " << program << " .." << std::endl;
std::cout << "Running " << program << " ..." << std::endl;
RAM ram;
Simulator simulator;
simulator.attach_ram(&ram);
simulator.load_ihex(program);
simulator.run();
int exitcode = simulator.run();
if (riscv_test) {
bool status = (1 == simulator.get_last_wb_value(3));
if (status) std::cout << "Passed." << std::endl;
if (!status) std::cout << "Failed." << std::endl;
passed = passed && status;
if (!passed)
break;
if (1 == exitcode) {
std::cout << "Passed" << std::endl;
} else {
std::cout << "Failed: exitcode=" << exitcode << std::endl;
passed = false;
}
} else {
if (exitcode != 0) {
std::cout << "*** error: exitcode=" << exitcode << std::endl;
passed = false;
}
}
if (!passed)
break;
}
}