1
0
mirror of https://github.com/TomHarte/CLK.git synced 2025-01-15 05:31:30 +00:00

Removed repeated checking of bus_request_line_. It's now checked only after each outward perform_machine_cycle.

This commit is contained in:
Thomas Harte 2017-08-20 12:39:45 -04:00
parent 4614a56843
commit 6315c22b80

View File

@ -909,6 +909,7 @@ template <class T> class Processor {
while(1) { while(1) {
do_bus_acknowledge:
while(bus_request_line_) { while(bus_request_line_) {
static PartialMachineCycle bus_acknowledge_cycle = {PartialMachineCycle::BusAcknowledge, HalfCycles(2), nullptr, nullptr, false}; static PartialMachineCycle bus_acknowledge_cycle = {PartialMachineCycle::BusAcknowledge, HalfCycles(2), nullptr, nullptr, false};
number_of_cycles_ -= bus_handler_.perform_machine_cycle(bus_acknowledge_cycle) + HalfCycles(1); number_of_cycles_ -= bus_handler_.perform_machine_cycle(bus_acknowledge_cycle) + HalfCycles(1);
@ -918,7 +919,7 @@ template <class T> class Processor {
} }
} }
while(!bus_request_line_) { while(true) {
const MicroOp *operation = scheduled_program_counter_; const MicroOp *operation = scheduled_program_counter_;
scheduled_program_counter_++; scheduled_program_counter_++;
@ -945,6 +946,7 @@ template <class T> class Processor {
number_of_cycles_ -= operation->machine_cycle.length; number_of_cycles_ -= operation->machine_cycle.length;
last_request_status_ = request_status_; last_request_status_ = request_status_;
number_of_cycles_ -= bus_handler_.perform_machine_cycle(operation->machine_cycle); number_of_cycles_ -= bus_handler_.perform_machine_cycle(operation->machine_cycle);
if(bus_request_line_) goto do_bus_acknowledge;
break; break;
case MicroOp::MoveToNextProgram: case MicroOp::MoveToNextProgram:
advance_operation(); advance_operation();