summaryrefslogtreecommitdiff
path: root/src/mem/ruby
diff options
context:
space:
mode:
authorSrikant Bharadwaj <srikant.bharadwaj@amd.com>2019-02-22 17:43:33 -0500
committerSrikant Bharadwaj <srikant.bharadwaj@amd.com>2019-02-28 19:46:58 +0000
commit21a4cc9692e30390547bf99887840ee32a75233b (patch)
tree92881278a2d8e1240106e94718997a04c9b68fe1 /src/mem/ruby
parent365ed5b9160486c20db192c3df4f025523100d74 (diff)
downloadgem5-21a4cc9692e30390547bf99887840ee32a75233b.tar.xz
ruby: Fix garnet's round robin arbitration for vc selection
Garnet utilizes round robin policy to select a VC for transmission ar Network Interface and Routers. The current logic for round robin is only fair if all the virtual networks are active at a given router. If the router or network interface is not receiving traffic in from any vnet then the priority is always taken up by the next vnet in numerically (or loops back to 0). This fix changes the way we perform round robin arbitration. When a VC is selected in a cycle, the round robin pointer is set to the VC next to it and is iterated from there on. If any VC does not have a flit in a given cycle, it will lose its turn until the next round. At maximum traffic this will model round robin correctly even if a certain VNET is not active at that unit. Change-Id: I9bf805221054f9f25bee14b57ff521f4ce4ca980 Reviewed-on: https://gem5-review.googlesource.com/c/16688 Reviewed-by: Jieming Yin <Jieming.Yin@amd.com> Maintainer: Jason Lowe-Power <jason@lowepower.com>
Diffstat (limited to 'src/mem/ruby')
-rw-r--r--src/mem/ruby/network/garnet2.0/NetworkInterface.cc5
-rw-r--r--src/mem/ruby/network/garnet2.0/SwitchAllocator.cc8
2 files changed, 6 insertions, 7 deletions
diff --git a/src/mem/ruby/network/garnet2.0/NetworkInterface.cc b/src/mem/ruby/network/garnet2.0/NetworkInterface.cc
index b3d89cab8..4e692704d 100644
--- a/src/mem/ruby/network/garnet2.0/NetworkInterface.cc
+++ b/src/mem/ruby/network/garnet2.0/NetworkInterface.cc
@@ -437,9 +437,6 @@ void
NetworkInterface::scheduleOutputLink()
{
int vc = m_vc_round_robin;
- m_vc_round_robin++;
- if (m_vc_round_robin == m_num_vcs)
- m_vc_round_robin = 0;
for (int i = 0; i < m_num_vcs; i++) {
vc++;
@@ -470,6 +467,8 @@ NetworkInterface::scheduleOutputLink()
if (!is_candidate_vc)
continue;
+ m_vc_round_robin = vc;
+
m_out_vc_state[vc]->decrement_credit();
// Just removing the flit
flit *t_flit = m_ni_out_vcs[vc]->getTopFlit();
diff --git a/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc b/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
index 836f071fe..1e9d0e6f7 100644
--- a/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
+++ b/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
@@ -136,8 +136,8 @@ SwitchAllocator::arbitrate_inports()
m_port_requests[outport][inport] = true;
m_vc_winners[outport][inport]= invc;
- // Update Round Robin pointer
- m_round_robin_invc[inport]++;
+ // Update Round Robin pointer to the next VC
+ m_round_robin_invc[inport] = invc + 1;
if (m_round_robin_invc[inport] >= m_num_vcs)
m_round_robin_invc[inport] = 0;
@@ -252,7 +252,7 @@ SwitchAllocator::arbitrate_outports()
m_port_requests[outport][inport] = false;
// Update Round Robin pointer
- m_round_robin_inport[outport]++;
+ m_round_robin_inport[outport] = inport + 1;
if (m_round_robin_inport[outport] >= m_num_inports)
m_round_robin_inport[outport] = 0;
@@ -393,4 +393,4 @@ SwitchAllocator::resetStats()
{
m_input_arbiter_activity = 0;
m_output_arbiter_activity = 0;
-} \ No newline at end of file
+}