diff options
| author | bd <bdunahu@operationnull.com> | 2025-03-22 14:19:10 -0400 | 
|---|---|---|
| committer | bd <bdunahu@operationnull.com> | 2025-03-22 14:19:10 -0400 | 
| commit | 2416cce2eec7ecdf0587896620806c465747eada (patch) | |
| tree | abcff26473cc45b23a7b9bd501f2974050479efa /src/sim | |
| parent | b73f7fbe952494e245c44fdd4b6123bac1b4ec97 (diff) | |
Add controller.h, implementation and tests.
Diffstat (limited to 'src/sim')
| -rw-r--r-- | src/sim/controller.cc | 37 | ||||
| -rw-r--r-- | src/sim/stage.cc | 5 | 
2 files changed, 42 insertions, 0 deletions
| diff --git a/src/sim/controller.cc b/src/sim/controller.cc new file mode 100644 index 0000000..c6d1bff --- /dev/null +++ b/src/sim/controller.cc @@ -0,0 +1,37 @@ +#include "controller.h" +#include "storage.h" + +Controller::Controller(Storage *storage, bool is_pipelined) +{ +	this->storage = storage; +	this->is_pipelined = is_pipelined; +	this->pc = 0x0; +	this->gprs = {0}; + +	// setup the other pipeline stages +	this->next = nullptr; +} + +Controller::~Controller() { ; } + +void Controller::run_for(int number) +{ +	int i; +	for (i = 0; i < number; ++i) { +		this->advance(); +	} +} + +int Controller::get_clock_cycle() { return this->clock_cycle; } + +std::array<int, GPR_NUM> Controller::get_gprs() { +	return this->gprs; +} + +int Controller::get_pc() { return this->pc; } + +void Controller::advance() { +	; +	// this->next->advance() +	++this->clock_cycle; +} diff --git a/src/sim/stage.cc b/src/sim/stage.cc new file mode 100644 index 0000000..7d3a678 --- /dev/null +++ b/src/sim/stage.cc @@ -0,0 +1,5 @@ +#include "stage.h" + +std::array<int, GPR_NUM> Stage::gprs; +int Stage::pc; +Storage *Stage::storage; | 
