summaryrefslogtreecommitdiff
path: root/util/cpt_upgraders
diff options
context:
space:
mode:
authorKarthik Sangaiah <karthik.sangaiah@arm.com>2015-09-18 16:49:28 +0100
committerKarthik Sangaiah <karthik.sangaiah@arm.com>2015-09-18 16:49:28 +0100
commit6fa936b021ac4d3030d20de5d037f1e7dd902cd9 (patch)
treebbbaf5a03f3b79caeae43a6c7bc257dc208b3f52 /util/cpt_upgraders
parent413f3088eabf385507e854d74c0a5861e4d2856b (diff)
downloadgem5-6fa936b021ac4d3030d20de5d037f1e7dd902cd9.tar.xz
dev, arm: Add gem5 extensions to support more than 8 cores
Previous ARM-based simulations were limited to 8 cores due to limitations in GICv2 and earlier. This changeset adds a set of gem5-specific extensions that enable support for up to 256 cores. When the gem5 extensions are enabled, the GIC uses CPU IDs instead of a CPU bitmask in the GIC's register interface. To OS can enable the extensions by setting bit 0x200 in ICDICTR. This changeset is based on previous work by Matt Evans.
Diffstat (limited to 'util/cpt_upgraders')
-rw-r--r--util/cpt_upgraders/arm-gem5-gic-ext.py77
1 files changed, 77 insertions, 0 deletions
diff --git a/util/cpt_upgraders/arm-gem5-gic-ext.py b/util/cpt_upgraders/arm-gem5-gic-ext.py
new file mode 100644
index 000000000..b71dbf882
--- /dev/null
+++ b/util/cpt_upgraders/arm-gem5-gic-ext.py
@@ -0,0 +1,77 @@
+# Copyright (c) 2015 ARM Limited
+# All rights reserved
+#
+# The license below extends only to copyright in the software and shall
+# not be construed as granting a license to any other intellectual
+# property including but not limited to intellectual property relating
+# to a hardware implementation of the functionality of the software
+# licensed hereunder. You may use the software subject to the license
+# terms below provided that you ensure that this notice is replicated
+# unmodified and in its entirety in all distributions of the software,
+# modified or unmodified, in source code or in binary form.
+#
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions are
+# met: redistributions of source code must retain the above copyright
+# notice, this list of conditions and the following disclaimer;
+# redistributions in binary form must reproduce the above copyright
+# notice, this list of conditions and the following disclaimer in the
+# documentation and/or other materials provided with the distribution;
+# neither the name of the copyright holders nor the names of its
+# contributors may be used to endorse or promote products derived from
+# this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+#
+# Authors: Andreas Sandberg
+#
+
+def upgrader(cpt):
+ """The gem5 GIC extensions change the size of many GIC data
+ structures. Resize them to match the new GIC."""
+
+ import re
+ if cpt.get('root','isa') != 'arm':
+ return
+
+ old_cpu_max = 8
+ new_cpu_max = 256
+ sgi_max = 16
+ ppi_max = 16
+ per_cpu_regs = (
+ ("iccrpr", [ "0xff", ]),
+ ("cpuEnabled", [ "false", ]),
+ ("cpuPriority", [ "0xff", ]),
+ ("cpuBpr", [ "0", ]),
+ ("cpuHighestInt", [ "1023", ]),
+ ("cpuPpiPending", [ "0", ]),
+ ("cpuPpiActive", [ "0", ] ),
+ ("interrupt_time", [ "0", ]),
+ ("*bankedIntPriority", ["0", ] * (sgi_max + ppi_max)),
+ )
+ new_per_cpu_regs = (
+ ("cpuSgiPendingExt", "0"),
+ ("cpuSgiActiveExt", "0"),
+ )
+
+ for sec in cpt.sections():
+ if re.search('.*\.gic$', sec):
+ for reg, default in per_cpu_regs:
+ value = cpt.get(sec, reg).split(" ")
+ assert len(value) / len(default) == old_cpu_max, \
+ "GIC register size mismatch"
+ value += [ " ".join(default), ] * (new_cpu_max - old_cpu_max)
+ cpt.set(sec, reg, " ".join(value))
+
+ for reg, default in new_per_cpu_regs:
+ cpt.set(sec, reg, " ".join([ default, ] * new_cpu_max))