Srikant Bharadwaj has uploaded this change for review. ( https://gem5-review.googlesource.com/c/public/gem5/+/16688

Change subject: ruby: Fix garnet's round robin arbitration for vc selection
......................................................................

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
---
M ext/git-commit-msg
M src/mem/ruby/network/garnet2.0/NetworkInterface.cc
M src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
3 files changed, 46 insertions(+), 177 deletions(-)



diff --git a/ext/git-commit-msg b/ext/git-commit-msg
index 60fe59d..a43fd13 100755
--- a/ext/git-commit-msg
+++ b/ext/git-commit-msg
@@ -1,5 +1,5 @@
 #!/bin/sh
-# From Gerrit Code Review 2.13.5-2617-gba50ae91fd
+# From Gerrit Code Review 2.16.5-1083-g707e61a75a
 #
 # Part of Gerrit Code Review (https://www.gerritcodereview.com/)
 #
@@ -16,176 +16,43 @@
 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 # See the License for the specific language governing permissions and
 # limitations under the License.
-#

-unset GREP_OPTIONS
+# avoid [[ which is not POSIX sh.
+if test "$#" != 1 ; then
+  echo "$0 requires an argument."
+  exit 1
+fi

-CHANGE_ID_AFTER="Bug|Depends-On|Issue|Test|Feature|Fixes|Fixed"
-MSG="$1"
+if test ! -f "$1" ; then
+  echo "file does not exist: $1"
+  exit 1
+fi

-# Check for, and add if missing, a unique Change-Id
-#
-add_ChangeId() {
-       clean_message=`sed -e '
-               /^diff --git .*/{
-                       s///
-                       q
-               }
-               /^Signed-off-by:/d
-               /^#/d
-       ' "$MSG" | git stripspace`
-       if test -z "$clean_message"
-       then
-               return
-       fi
+# $RANDOM will be undefined if not using bash, so don't use set -u
+random=$( (whoami ; hostname ; date; cat $1 ; echo $RANDOM) | git hash-object --stdin)
+dest="$1.tmp.${random}"

-       # Do not add Change-Id to temp commits
-       if echo "$clean_message" | head -1 | grep -q '^\(fixup\|squash\)!'
-       then
-               return
-       fi
+trap 'rm -f "${dest}"' EXIT

-       if test "false" = "`git config --bool --get gerrit.createChangeId`"
-       then
-               return
-       fi
+if ! git stripspace --strip-comments < "$1" > "${dest}" ; then
+   echo "cannot strip comments from $1"
+   exit 1
+fi

-       # Does Change-Id: already exist? if so, exit (no change).
-       if grep -i '^Change-Id:' "$MSG" >/dev/null
-       then
-               return
-       fi
+if test ! -s "${dest}" ; then
+  echo "file is empty: $1"
+  exit 1
+fi

-       id=`_gen_ChangeId`
-       T="$MSG.tmp.$$"
-       AWK=awk
-       if [ -x /usr/xpg4/bin/awk ]; then
-               # Solaris AWK is just too broken
-               AWK=/usr/xpg4/bin/awk
-       fi
+# Avoid the --in-place option which only appeared in Git 2.8
+# Avoid the --if-exists option which only appeared in Git 2.15
+if ! git -c trailer.ifexists=doNothing interpret-trailers \
+      --trailer "Change-Id: I${random}" < "$1" > "${dest}" ; then
+  echo "cannot insert change-id line in $1"
+  exit 1
+fi

-       # Get core.commentChar from git config or use default symbol
-       commentChar=`git config --get core.commentChar`
-       commentChar=${commentChar:-#}
-
-       # How this works:
-       # - parse the commit message as (textLine+ blankLine*)*
-       # - assume textLine+ to be a footer until proven otherwise
-       # - exception: the first block is not footer (as it is the title)
-       # - read textLine+ into a variable
-       # - then count blankLines
-       # - once the next textLine appears, print textLine+ blankLine* as these
-       #   aren't footer
-       # - in END, the last textLine+ block is available for footer parsing
-       $AWK '
-       BEGIN {
-               # while we start with the assumption that textLine+
-               # is a footer, the first block is not.
-               isFooter = 0
-               footerComment = 0
-               blankLines = 0
-       }
-
-       # Skip lines starting with commentChar without any spaces before it.
-       /^'"$commentChar"'/ { next }
-
-       # Skip the line starting with the diff command and everything after it,
-       # up to the end of the file, assuming it is only patch data.
-       # If more than one line before the diff was empty, strip all but one.
-       /^diff --git / {
-               blankLines = 0
-               while (getline) { }
-               next
-       }
-
-       # Count blank lines outside footer comments
-       /^$/ && (footerComment == 0) {
-               blankLines++
-               next
-       }
-
-       # Catch footer comment
-       /^\[[a-zA-Z0-9-]+:/ && (isFooter == 1) {
-               footerComment = 1
-       }
-
-       /]$/ && (footerComment == 1) {
-               footerComment = 2
-       }
-
-       # We have a non-blank line after blank lines. Handle this.
-       (blankLines > 0) {
-               print lines
-               for (i = 0; i < blankLines; i++) {
-                       print ""
-               }
-
-               lines = ""
-               blankLines = 0
-               isFooter = 1
-               footerComment = 0
-       }
-
-       # Detect that the current block is not the footer
-       (footerComment == 0) && (!/^\[?[a-zA-Z0-9-]+:/ || 
/^[a-zA-Z0-9-]+:\/\//) {
-               isFooter = 0
-       }
-
-       {
-               # We need this information about the current last comment line
-               if (footerComment == 2) {
-                       footerComment = 0
-               }
-               if (lines != "") {
-                       lines = lines "\n";
-               }
-               lines = lines $0
-       }
-
-       # Footer handling:
-       # If the last block is considered a footer, splice in the Change-Id at 
the
-       # right place.
-       # Look for the right place to inject Change-Id by considering
-       # CHANGE_ID_AFTER. Keys listed in it (case insensitive) come first,
-       # then Change-Id, then everything else (eg. Signed-off-by:).
-       #
-       # Otherwise just print the last block, a new line and the Change-Id as a
-       # block of its own.
-       END {
-               unprinted = 1
-               if (isFooter == 0) {
-                       print lines "\n"
-                       lines = ""
-               }
-               changeIdAfter = "^(" tolower("'"$CHANGE_ID_AFTER"'") "):"
-               numlines = split(lines, footer, "\n")
-               for (line = 1; line <= numlines; line++) {
-                       if (unprinted && match(tolower(footer[line]), 
changeIdAfter) != 1) {
-                               unprinted = 0
-                               print "Change-Id: I'"$id"'"
-                       }
-                       print footer[line]
-               }
-               if (unprinted) {
-                       print "Change-Id: I'"$id"'"
-               }
-       }' "$MSG" > "$T" && mv "$T" "$MSG" || rm -f "$T"
-}
-_gen_ChangeIdInput() {
-       echo "tree `git write-tree`"
-       if parent=`git rev-parse "HEAD^0" 2>/dev/null`
-       then
-               echo "parent $parent"
-       fi
-       echo "author `git var GIT_AUTHOR_IDENT`"
-       echo "committer `git var GIT_COMMITTER_IDENT`"
-       echo
-       printf '%s' "$clean_message"
-}
-_gen_ChangeId() {
-       _gen_ChangeIdInput |
-       git hash-object -t commit --stdin
-}
-
-
-add_ChangeId
+if ! mv "${dest}" "$1" ; then
+  echo "cannot mv ${dest} to $1"
+  exit 1
+fi
diff --git a/src/mem/ruby/network/garnet2.0/NetworkInterface.cc b/src/mem/ruby/network/garnet2.0/NetworkInterface.cc
index b3d89ca..0155500 100644
--- a/src/mem/ruby/network/garnet2.0/NetworkInterface.cc
+++ b/src/mem/ruby/network/garnet2.0/NetworkInterface.cc
@@ -437,15 +437,8 @@
 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++;
-        if (vc == m_num_vcs)
-            vc = 0;
-
         // model buffer backpressure
         if (m_ni_out_vcs[vc]->isReady(curCycle()) &&
             m_out_vc_state[vc]->has_credit()) {
@@ -470,6 +463,10 @@
             if (!is_candidate_vc)
                 continue;

+            m_vc_round_robin = vc + 1;
+            if (m_vc_round_robin == m_num_vcs)
+                m_vc_round_robin = 0;
+
             m_out_vc_state[vc]->decrement_credit();
             // Just removing the flit
             flit *t_flit = m_ni_out_vcs[vc]->getTopFlit();
@@ -484,6 +481,11 @@
             }
             return;
         }
+
+        vc++;
+        if (vc == m_num_vcs)
+            vc = 0;
+
     }
 }

diff --git a/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc b/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
index 836f071..1e9d0e6 100644
--- a/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
+++ b/src/mem/ruby/network/garnet2.0/SwitchAllocator.cc
@@ -136,8 +136,8 @@
                     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 @@
                 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 @@
 {
     m_input_arbiter_activity = 0;
     m_output_arbiter_activity = 0;
-}
\ No newline at end of file
+}

--
To view, visit https://gem5-review.googlesource.com/c/public/gem5/+/16688
To unsubscribe, or for help writing mail filters, visit https://gem5-review.googlesource.com/settings

Gerrit-Project: public/gem5
Gerrit-Branch: master
Gerrit-Change-Id: I9bf805221054f9f25bee14b57ff521f4ce4ca980
Gerrit-Change-Number: 16688
Gerrit-PatchSet: 1
Gerrit-Owner: Srikant Bharadwaj <[email protected]>
Gerrit-MessageType: newchange
_______________________________________________
gem5-dev mailing list
[email protected]
http://m5sim.org/mailman/listinfo/gem5-dev

Reply via email to