From: Srikant Bharadwaj Date: Fri, 22 Feb 2019 22:43:33 +0000 (-0500) Subject: ruby: Fix garnet's round robin arbitration for vc selection X-Git-Tag: v19.0.0.0~1083 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=21a4cc9692e30390547bf99887840ee32a75233b;p=gem5.git 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 Maintainer: Jason Lowe-Power --- 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 +}