diff options
author | bd <bdunahu@operationnull.com> | 2025-04-11 21:22:18 -0400 |
---|---|---|
committer | bd <bdunahu@operationnull.com> | 2025-04-11 21:22:18 -0400 |
commit | 1fb7a9bd5eb41e87871bcbb3423caaabdd8ce1d9 (patch) | |
tree | 08549aa6c7cbae114958df62f92c9e60eb5f114c /src/dram.cc | |
parent | 101f0facf8002907ca6e19faabfdcf472c0c3152 (diff) |
First part of storage rework (see description)
- Removed response enum.
- Removed messy ostream override, and cli.cc test class
- Removed accessor enum, and instead used unique pointer to identify accessor.
- Simplified storage by removing is_waiting variables.
- Rewrote DRAM and Cache to use Storage constructor.
Diffstat (limited to 'src/dram.cc')
-rw-r--r-- | src/dram.cc | 113 |
1 files changed, 35 insertions, 78 deletions
diff --git a/src/dram.cc b/src/dram.cc index f90f8db..d81e2d2 100644 --- a/src/dram.cc +++ b/src/dram.cc @@ -1,63 +1,50 @@ #include "dram.h" #include "definitions.h" -#include "response.h" #include <algorithm> #include <bits/stdc++.h> #include <bitset> -#include <iostream> #include <iterator> #include <utils.h> -Dram::Dram(int delay) -{ - this->data = new std::vector<std::array<signed int, LINE_SIZE>>; - this->data->resize(MEM_LINES); - this->delay = delay; - this->is_waiting = false; - this->lower = nullptr; - this->requester = IDLE; - this->wait_time = this->delay; -} +Dram::Dram(int delay) : Storage(delay) { this->data->resize(MEM_LINES); } Dram::~Dram() { delete this->data; } -Response Dram::write_line( - Accessor accessor, std::array<signed int, LINE_SIZE> data_line, int address) +int +Dram::write_line(void *id, std::array<signed int, LINE_SIZE> data_line, int address) { - return process(accessor, address, [&](int line, int word) { + return process(id, address, [&](int line, int word) { (void)word; this->data->at(line) = data_line; }); } -Response Dram::write_word(Accessor accessor, signed int data, int address) +int +Dram::write_word(void *id, signed int data, int address) { - return process(accessor, address, [&](int line, int word) { - this->data->at(line).at(word) = data; - }); + return process(id, address, [&](int line, int word) { this->data->at(line).at(word) = data; }); } // TODO requires testing -Response Dram::read_line( - Accessor accessor, - int address, - std::array<signed int, LINE_SIZE> &data_line) +int +Dram::read_line(void *id, int address, std::array<signed int, LINE_SIZE> &data_line) { - return process(accessor, address, [&](int line, int word) { + return process(id, address, [&](int line, int word) { (void)word; data_line = this->data->at(line); }); } -Response Dram::read_word(Accessor accessor, int address, signed int &data) +int +Dram::read_word(void *id, int address, signed int &data) { - return process(accessor, address, [&](int line, int word) { - data = this->data->at(line).at(word); - }); + return process(id, address, [&](int line, int word) { data = this->data->at(line).at(word); }); } // TODO load a file instead and test this method -void Dram::load(std::vector<signed int> program) { +void +Dram::load(std::vector<signed int> program) +{ unsigned long i; for (i = 0; i < program.size(); ++i) { int line, word; @@ -66,13 +53,12 @@ void Dram::load(std::vector<signed int> program) { } } -Response Dram::process( - Accessor accessor, - int address, - std::function<void(int line, int word)> request_handler) +int +Dram::process(void *id, int address, std::function<void(int line, int word)> request_handler) { - Response r = this->is_access_cleared(accessor); - if (r == OK) { + int r; + r = this->is_access_cleared(id); + if (r) { int line, word; get_memory_index(address, line, word); request_handler(line, word); @@ -80,51 +66,22 @@ Response Dram::process( return r; } -Response Dram::is_access_cleared(Accessor accessor) +int +Dram::is_access_cleared(void *id) { - Response r; - r = WAIT; /* Do this first--then process the first cycle immediately. */ - if (accessor == SIDE) - r = OK; - else { - if (this->requester == IDLE) - this->requester = accessor; - if (this->requester == accessor) { - if (this->wait_time == 0) { - this->requester = IDLE; - this->wait_time = delay; - r = OK; - } else { - --this->wait_time; - } - } - } - return r; -} - -std::ostream &operator<<(std::ostream &os, const Dram &d) -{ - const auto default_flags = std::cout.flags(); - const auto default_fill = std::cout.fill(); - - std::vector<std::array<signed int, LINE_SIZE>> data = d.view(0, MEM_LINES); - - os << " " << std::setfill(' ') << std::setw(MEM_LINE_SPEC + 2 + LINE_SPEC) - << "ADDRESS" - << " | " << std::setfill(' ') << std::setw((8 + 3) * 4 - 1) << "DATA" - << std::endl; - for (int i = 0; i < MEM_LINES; ++i) { - os << " 0b" << std::setw(MEM_LINE_SPEC + LINE_SPEC) << left - << std::bitset<MEM_LINE_SPEC>(i) << " | "; - for (int j = 0; j < LINE_SIZE; ++j) { - os << "0x" << std::setfill('0') << std::setw(8) << std::hex - << data.at(i).at(j) << ' '; + if (id == nullptr) + throw std::invalid_argument("Accessor cannot be nullptr."); + if (this->current_request == nullptr) + this->current_request = id; + if (this->current_request == id) { + if (this->wait_time == 0) { + this->current_request = nullptr; + this->wait_time = delay; + return 1; + } else { + --this->wait_time; } - os << std::endl; } - - std::cout.flags(default_flags); - std::cout.fill(default_fill); - return os; + return 0; } |