diff options
author | Nilay Vaish <nilay@cs.wisc.edu> | 2012-11-10 17:18:01 -0600 |
---|---|---|
committer | Nilay Vaish <nilay@cs.wisc.edu> | 2012-11-10 17:18:01 -0600 |
commit | 90c45c29fe11b478ea20564b1f4a94614b03ec4e (patch) | |
tree | 64eddd39a76481c085447a60cdb5a7ccedd21461 /src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc | |
parent | 1492ab066da6f683178638137bd395960d07c004 (diff) | |
download | gem5-90c45c29fe11b478ea20564b1f4a94614b03ec4e.tar.xz |
ruby: support functional accesses in garnet flexible network
Diffstat (limited to 'src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc')
-rw-r--r-- | src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc b/src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc index e8aca533a..9916f4ba5 100644 --- a/src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc +++ b/src/mem/ruby/network/garnet/flexible-pipeline/GarnetNetwork.cc @@ -192,6 +192,54 @@ GarnetNetwork::checkNetworkAllocation(NodeID id, bool ordered, m_in_use[network_num] = true; } +/* + * Go through all the routers, network interfaces and the interconnecting + * links for reading/writing all the messages. + */ +bool +GarnetNetwork::functionalRead(Packet *pkt) +{ + for (unsigned int i = 0; i < m_router_ptr_vector.size(); i++) { + if (m_router_ptr_vector[i]->functionalRead(pkt)) { + return true; + } + } + + for (unsigned int i = 0; i < m_ni_ptr_vector.size(); ++i) { + if (m_ni_ptr_vector[i]->functionalRead(pkt)) { + return true; + } + } + + for (unsigned int i = 0; i < m_link_ptr_vector.size(); ++i) { + if (m_link_ptr_vector[i]->functionalRead(pkt)) { + return true; + } + } + + return false; +} + +uint32_t +GarnetNetwork::functionalWrite(Packet *pkt) +{ + uint32_t num_functional_writes = 0; + + for (unsigned int i = 0; i < m_router_ptr_vector.size(); i++) { + num_functional_writes += m_router_ptr_vector[i]->functionalWrite(pkt); + } + + for (unsigned int i = 0; i < m_ni_ptr_vector.size(); ++i) { + num_functional_writes += m_ni_ptr_vector[i]->functionalWrite(pkt); + } + + for (unsigned int i = 0; i < m_link_ptr_vector.size(); ++i) { + num_functional_writes += m_link_ptr_vector[i]->functionalWrite(pkt); + } + + return num_functional_writes; +} + void GarnetNetwork::printLinkStats(ostream& out) const { |