Files
gem5/util/cpt_upgraders/memory-per-range.py
Bobby R. Bruce 298119e402 misc,python: Run pre-commit run --all-files
Applies the `pyupgrade` hook to all files in the repo.

Change-Id: I9879c634a65c5fcaa9567c63bc5977ff97d5d3bf
2023-10-10 21:47:07 -07:00

35 lines
1.5 KiB
Python

# The backing store supporting the memories in the system has changed
# in that it is now stored globally per address range. As a result the
# actual storage is separate from the memory controllers themselves.
def upgrader(cpt):
for sec in cpt.sections():
import re
# Search for a physical memory
if re.search(r".*sys.*\.physmem$", sec):
# Add the number of stores attribute to the global physmem
cpt.set(sec, "nbr_of_stores", "1")
# Get the filename and size as this is moving to the
# specific backing store
mem_filename = cpt.get(sec, "filename")
mem_size = cpt.get(sec, "_size")
cpt.remove_option(sec, "filename")
cpt.remove_option(sec, "_size")
# Get the name so that we can create the new section
system_name = str(sec).split(".")[0]
section_name = system_name + ".physmem.store0"
cpt.add_section(section_name)
cpt.set(section_name, "store_id", "0")
cpt.set(section_name, "range_size", mem_size)
cpt.set(section_name, "filename", mem_filename)
elif re.search(r".*sys.*\.\w*mem$", sec):
# Due to the lack of information about a start address,
# this migration only works if there is a single memory in
# the system, thus starting at 0
raise ValueError("more than one memory detected (" + sec + ")")
legacy_version = 2