From: Andreas Hansson Date: Wed, 12 Nov 2014 14:05:21 +0000 (-0500) Subject: sim: Sort SimObject descendants and ports X-Git-Tag: stable_2015_04_15~135 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=7d0589512089402cf7bbf585c0e2b4878dc1dd6a;p=gem5.git sim: Sort SimObject descendants and ports This patch fixes a number of occurences where the sorting order of the objects was implementation defined. --- diff --git a/src/python/m5/SimObject.py b/src/python/m5/SimObject.py index 40203a307..71091ce6c 100644 --- a/src/python/m5/SimObject.py +++ b/src/python/m5/SimObject.py @@ -1289,7 +1289,9 @@ class SimObject(object): match_obj = self._values[pname] if not isproxy(match_obj) and not isNullPointer(match_obj): all[match_obj] = True - return all.keys(), True + # Also make sure to sort the keys based on the objects' path to + # ensure that the order is the same on all hosts + return sorted(all.keys(), key = lambda o: o.path()), True def unproxy(self, base): return self @@ -1437,7 +1439,10 @@ class SimObject(object): def descendants(self): yield self - for child in self._children.itervalues(): + # The order of the dict is implementation dependent, so sort + # it based on the key (name) to ensure the order is the same + # on all hosts + for (name, child) in sorted(self._children.iteritems()): for obj in child.descendants(): yield obj @@ -1452,7 +1457,9 @@ class SimObject(object): # Create C++ port connections corresponding to the connections in # _port_refs def connectPorts(self): - for portRef in self._port_refs.itervalues(): + # Sort the ports based on their attribute name to ensure the + # order is the same on all hosts + for (attr, portRef) in sorted(self._port_refs.iteritems()): portRef.ccConnect() # Function to provide to C++ so it can look up instances based on paths