diff options
| author | Siddarth Suresh <155843085+SiddarthSuresh98@users.noreply.github.com> | 2025-04-16 16:46:50 -0400 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-04-16 16:46:50 -0400 | 
| commit | a2381acb5489a735576a43f25053a7a5551a7667 (patch) | |
| tree | 317463528410f56039df9d67f8a52fbc624014ff /src/cache.cc | |
| parent | 43e660152ebf1d8c8aa46f5478d4d26885d4a12c (diff) | |
| parent | 24fd3ac34fe955818542a8eaa7f76f87644f10bf (diff) | |
Merge pull request #3 from bdunahu/bdunahu
Add untested support for configurable ways
Diffstat (limited to 'src/cache.cc')
| -rw-r--r-- | src/cache.cc | 70 | 
1 files changed, 45 insertions, 25 deletions
| diff --git a/src/cache.cc b/src/cache.cc index 08545fd..a2d4525 100644 --- a/src/cache.cc +++ b/src/cache.cc @@ -1,5 +1,6 @@  #include "cache.h"  #include "definitions.h" +#include <cstdlib>  #include <iostream>  #include <iterator> @@ -61,53 +62,72 @@ Cache::read_word(void *id, int address, signed int &data)  int  Cache::process(void *id, int address, std::function<void(int index, int offset)> request_handler)  { -	if (!preprocess(id) || is_address_missing(address) || !this->is_data_ready()) +	if (!preprocess(id) || priming_address(address) || !this->is_data_ready())  		return 0;  	int tag, index, offset;  	GET_FIELDS(address, &tag, &index, &offset); +	index = this->get_true_index(index);  	request_handler(index, offset);  	return 1;  }  int -Cache::is_address_missing(int expected) +Cache::priming_address(int address)  { -	int r, q, tag, index, offset; -	std::array<signed int, LINE_SIZE> *actual; +	int tag, index, offset; +	int r1, r2; +	std::array<signed int, LINE_SIZE> *evict;  	std::array<int, 3> *meta; -	GET_FIELDS(expected, &tag, &index, &offset); -	r = 0; -	meta = &this->meta.at(index); -	actual = &this->data->at(index); +	r1 = 0; +	GET_FIELDS(address, &tag, &index, &offset); +	index = this->get_true_index(index); + +	if (this->is_address_missing(index, tag)) { +		r1 = 1; + +		index = this->get_replacement_index(index); +		meta = &this->meta.at(index); +		evict = &this->data->at(index); -	if (meta->at(0) != tag) { -		r = 1; +		// handle eviction of dirty cache lines  		if (meta->at(1) >= 0) { -			q = this->lower->write_line( -				this, *actual, ((index << LINE_SPEC) + (meta->at(0) << (this->size + LINE_SPEC)))); -			if (q) { +			r2 = this->lower->write_line( +				this, *evict, ((index << LINE_SPEC) + (meta->at(0) << (this->size + LINE_SPEC)))); +			if (r2)  				meta->at(1) = -1; -			}  		} else { -			q = this->lower->read_line(this, expected, *actual); -			if (q) { +			r2 = this->lower->read_line(this, address, *evict); +			if (r2) {  				meta->at(0) = tag;  			}  		}  	} -	return r; +	return r1; +} + +int +Cache::is_address_missing(int index, int tag) +{ +	int i; + +	for (i = 0; i < (1 << this->ways); ++i) +		if (this->meta.at(index + i).at(0) == tag) +			return i; +	return -1;  } -// unsigned int -// Cache::get_true_index(unsigned int index) -// { -// } +int +Cache::get_true_index(int index) +{ +	return index * (1 << this->ways); +} -// unsigned int -// Cache::get_replacement_index(unsigned int index) -// { -// } +int +Cache::get_replacement_index(int index) +{ +	return index + (rand() % (1 << this->ways)); +} | 
