added rsp map
This commit is contained in:
94
hw/unit_tests/cache/cachesim.cpp
vendored
94
hw/unit_tests/cache/cachesim.cpp
vendored
@@ -3,6 +3,7 @@
|
||||
#include <iomanip>
|
||||
#include <iostream>
|
||||
#include <vector>
|
||||
#include <map>
|
||||
|
||||
uint64_t timestamp = 0;
|
||||
|
||||
@@ -33,6 +34,7 @@ CacheSim::~CacheSim() {
|
||||
trace_->close();
|
||||
//#endif
|
||||
delete cache_;
|
||||
//need to delete the req and rsp vectors
|
||||
}
|
||||
|
||||
void CacheSim::attach_ram(RAM* ram) {
|
||||
@@ -74,24 +76,33 @@ void CacheSim::eval() {
|
||||
}
|
||||
|
||||
void CacheSim::run(){
|
||||
#ifndef NDEBUG
|
||||
//#ifndef NDEBUG
|
||||
std::cout << timestamp << ": [sim] run()" << std::endl;
|
||||
#endif
|
||||
|
||||
// reset the device
|
||||
this->reset();
|
||||
this->step();
|
||||
|
||||
//#endif
|
||||
|
||||
this->step();
|
||||
int valid = 15;
|
||||
// execute program
|
||||
|
||||
while (!core_req_vec_.empty()) {
|
||||
|
||||
for(int i = 0; i < 10; ++i){
|
||||
if(i == 1){
|
||||
this->clear_req(); //invalidate reqs
|
||||
}
|
||||
|
||||
this->step();
|
||||
}
|
||||
|
||||
}
|
||||
/*
|
||||
while(valid > 10){
|
||||
this->step();
|
||||
if(!cache_->core_req_valid && !cache_->core_rsp_valid){
|
||||
valid--;
|
||||
}
|
||||
}
|
||||
*/
|
||||
}
|
||||
|
||||
void CacheSim::clear_req(){
|
||||
@@ -101,6 +112,8 @@ void CacheSim::clear_req(){
|
||||
|
||||
void CacheSim::send_req(core_req_t *req){
|
||||
core_req_vec_.push(req);
|
||||
unsigned int *data = new unsigned int[4];
|
||||
core_rsp_vec_.insert(std::pair<unsigned int, unsigned int*>(req->tag, data));
|
||||
}
|
||||
|
||||
bool CacheSim::get_core_req_ready(){
|
||||
@@ -111,49 +124,11 @@ bool CacheSim::get_core_rsp_ready(){
|
||||
return cache_->core_rsp_ready;
|
||||
}
|
||||
|
||||
void CacheSim::set_core_req(){
|
||||
cache_->core_req_valid = 0xf;
|
||||
cache_->core_req_rw = 0xf;
|
||||
cache_->core_req_byteen = 0xffff;
|
||||
cache_->core_req_addr[0] = 0x00;
|
||||
cache_->core_req_addr[1] = 0xab;
|
||||
cache_->core_req_addr[2] = 0xcd;
|
||||
cache_->core_req_addr[3] = 0xe1;
|
||||
cache_->core_req_data[0] = 0xffffffff;
|
||||
cache_->core_req_data[1] = 0x11111111;
|
||||
cache_->core_req_data[2] = 0x22222222;
|
||||
cache_->core_req_data[3] = 0x33333333;
|
||||
cache_->core_req_tag = 0xff;
|
||||
}
|
||||
|
||||
void CacheSim::set_core_req2(){
|
||||
cache_->core_req_valid = 0xf; //b1000
|
||||
cache_->core_req_rw = 0x0; //b0000
|
||||
cache_->core_req_byteen = 0xffff;
|
||||
cache_->core_req_addr[0] = 0x00;
|
||||
cache_->core_req_addr[1] = 0xab;
|
||||
cache_->core_req_addr[2] = 0xcd;
|
||||
cache_->core_req_addr[3] = 0xe1;
|
||||
cache_->core_req_data[0] = 0x1111111;
|
||||
cache_->core_req_data[1] = 0x4444444;
|
||||
cache_->core_req_data[2] = 0x5555555;
|
||||
cache_->core_req_data[3] = 0x6666666;
|
||||
cache_->core_req_tag = 0xff;
|
||||
}
|
||||
|
||||
|
||||
void CacheSim::eval_reqs(){
|
||||
//check to see if cache is accepting reqs
|
||||
if(!core_req_vec_.empty() && cache_->core_req_ready){
|
||||
core_req_t *req = core_req_vec_.front();
|
||||
|
||||
std::cout << "Display Req Data Contents " << std::endl;
|
||||
|
||||
std::cout << std::hex << "Data[0]: " << req->data[0] << std::endl;
|
||||
std::cout << std::hex << "Data[1]: " << req->data[1] << std::endl;
|
||||
std::cout << std::hex << "Data[2]: " << req->data[2] << std::endl;
|
||||
std::cout << std::hex << "Data[3]: " << req->data[3] << std::endl;
|
||||
|
||||
cache_->core_req_valid = req->valid;
|
||||
cache_->core_req_rw = req->rw;
|
||||
cache_->core_req_byteen = req->byteen;
|
||||
@@ -170,19 +145,22 @@ void CacheSim::eval_reqs(){
|
||||
|
||||
cache_->core_req_tag = req->tag;
|
||||
|
||||
|
||||
std::cout << "Display Cache Data inputs: " << std::endl;
|
||||
get_core_req();
|
||||
|
||||
core_req_vec_.pop();
|
||||
std::cout << "Req Popped" << std::endl;
|
||||
|
||||
} else {
|
||||
clear_req();
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
void CacheSim::eval_rsps(){
|
||||
//check to see if a request has been responded to
|
||||
//if core_rsp tag equal to the front queue tag pop it from the queue
|
||||
//while the req tag == rsp tag
|
||||
if (cache_->core_rsp_valid){
|
||||
core_rsp_vec_.at(cache_->core_rsp_tag)[0] = cache_->core_rsp_data[0];
|
||||
core_rsp_vec_.at(cache_->core_rsp_tag)[1] = cache_->core_rsp_data[1];
|
||||
core_rsp_vec_.at(cache_->core_rsp_tag)[2] = cache_->core_rsp_data[2];
|
||||
core_rsp_vec_.at(cache_->core_rsp_tag)[3] = cache_->core_rsp_data[3];
|
||||
}
|
||||
}
|
||||
|
||||
void CacheSim::eval_dram_bus() {
|
||||
@@ -264,10 +242,14 @@ void CacheSim::eval_dram_bus() {
|
||||
|
||||
//DEBUG
|
||||
|
||||
void CacheSim::get_core_rsp(){
|
||||
std::cout << std::hex << "core_rsp_valid: " << cache_->core_rsp_valid << std::endl;
|
||||
std::cout << std::hex << "core_rsp_data: " << cache_->core_rsp_data << std::endl;
|
||||
std::cout << std::hex << "core_rsp_tag: " << cache_->core_rsp_tag << std::endl;
|
||||
void CacheSim::get_core_rsp(unsigned int (&rsp)[4]){
|
||||
rsp[0] = cache_->core_rsp_data[0];
|
||||
rsp[1] = cache_->core_rsp_data[1];
|
||||
rsp[2] = cache_->core_rsp_data[2];
|
||||
rsp[3] = cache_->core_rsp_data[3];
|
||||
//std::cout << std::hex << "core_rsp_valid: " << cache_->core_rsp_valid << std::endl;
|
||||
//std::cout << std::hex << "core_rsp_data: " << cache_->core_rsp_data << std::endl;
|
||||
//std::cout << std::hex << "core_rsp_tag: " << cache_->core_rsp_tag << std::endl;
|
||||
}
|
||||
|
||||
void CacheSim::get_core_req(){
|
||||
|
||||
Reference in New Issue
Block a user