soc/interconnect/csr: Replace level with sort and fix targets compilation.

This commit is contained in:
Florent Kermarrec 2022-10-21 18:54:12 +02:00
parent 14b2829a5f
commit 096f2184e6
2 changed files with 7 additions and 8 deletions

View file

@ -525,7 +525,7 @@ def _sort_gathered_items(items):
return sorted_items return sorted_items
def _make_gatherer(method, cls, prefix_cb): def _make_gatherer(method, cls, prefix_cb):
def gatherer(self, level=0): def gatherer(self, sort=False):
try: try:
exclude = self.autocsr_exclude exclude = self.autocsr_exclude
except AttributeError: except AttributeError:
@ -540,13 +540,12 @@ def _make_gatherer(method, cls, prefix_cb):
if isinstance(v, cls): if isinstance(v, cls):
r.append(v) r.append(v)
elif hasattr(v, method) and callable(getattr(v, method)): elif hasattr(v, method) and callable(getattr(v, method)):
items = getattr(v, method)(level=level+1) items = getattr(v, method)()
prefix_cb(k + "_", items, prefixed) prefix_cb(k + "_", items, prefixed)
r += items r += items
if level == 0: if sort:
return _sort_gathered_items(r) r = _sort_gathered_items(r)
else: return r
return r
return gatherer return gatherer

View file

@ -226,7 +226,7 @@ class CSRBankArray(Module):
# --------------------- # ---------------------
csrs = [] csrs = []
if hasattr(obj, "get_csrs"): if hasattr(obj, "get_csrs"):
csrs = obj.get_csrs() csrs = obj.get_csrs(sort=True)
# Collect CSR Memories. # Collect CSR Memories.
# --------------------- # ---------------------
@ -252,7 +252,7 @@ class CSRBankArray(Module):
# Collect CSR Constants. # Collect CSR Constants.
# ---------------------- # ----------------------
if hasattr(obj, "get_constants"): if hasattr(obj, "get_constants"):
for constant in obj.get_constants(): for constant in obj.get_constants(sort=True):
self.constants.append((name, constant)) self.constants.append((name, constant))
# Create CSRBank with CSRs found. # Create CSRBank with CSRs found.