config: Remove O3 dependencies

The default cache configuration script currently import the O3_ARM_v7a
model configuration, which depends on the O3 CPU. This breaks if gem5
has been compiled without O3 support. This changeset removes the
dependency by only importing the model if it is requested by the
user. As a bonus, it actually removes some code duplication in the
configuration scripts.
This commit is contained in:
Andreas Sandberg 2013-02-15 17:40:08 -05:00
parent e5dca84c3f
commit 1c7aa665bf

View file

@ -1,3 +1,15 @@
# Copyright (c) 2012 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.
#
# Copyright (c) 2010 Advanced Micro Devices, Inc. # Copyright (c) 2010 Advanced Micro Devices, Inc.
# All rights reserved. # All rights reserved.
# #
@ -32,24 +44,30 @@
import m5 import m5
from m5.objects import * from m5.objects import *
from Caches import * from Caches import *
from O3_ARM_v7a import *
def config_cache(options, system): def config_cache(options, system):
if options.cpu_type == "arm_detailed":
try:
from O3_ARM_v7a import *
except:
print "arm_detailed is unavailable. Did you compile the O3 model?"
sys.exit(1)
dcache_class, icache_class, l2_cache_class = \
O3_ARM_v7a_DCache, O3_ARM_v7a_ICache, O3_ARM_v7aL2
else:
dcache_class, icache_class, l2_cache_class = \
L1Cache, L1Cache, L2Cache
if options.l2cache: if options.l2cache:
# Provide a clock for the L2 and the L1-to-L2 bus here as they # Provide a clock for the L2 and the L1-to-L2 bus here as they
# are not connected using addTwoLevelCacheHierarchy. Use the # are not connected using addTwoLevelCacheHierarchy. Use the
# same clock as the CPUs, and set the L1-to-L2 bus width to 32 # same clock as the CPUs, and set the L1-to-L2 bus width to 32
# bytes (256 bits). # bytes (256 bits).
if options.cpu_type == "arm_detailed": system.l2 = l2_cache_class(clock=options.clock,
system.l2 = O3_ARM_v7aL2(clock = options.clock, size=options.l2_size,
size = options.l2_size, assoc=options.l2_assoc,
assoc = options.l2_assoc, block_size=options.cacheline_size)
block_size=options.cacheline_size)
else:
system.l2 = L2Cache(clock = options.clock,
size = options.l2_size,
assoc = options.l2_assoc,
block_size = options.cacheline_size)
system.tol2bus = CoherentBus(clock = options.clock, width = 32) system.tol2bus = CoherentBus(clock = options.clock, width = 32)
system.l2.cpu_side = system.tol2bus.master system.l2.cpu_side = system.tol2bus.master
@ -57,20 +75,12 @@ def config_cache(options, system):
for i in xrange(options.num_cpus): for i in xrange(options.num_cpus):
if options.caches: if options.caches:
if options.cpu_type == "arm_detailed": icache = icache_class(size=options.l1i_size,
icache = O3_ARM_v7a_ICache(size = options.l1i_size, assoc=options.l1i_assoc,
assoc = options.l1i_assoc, block_size=options.cacheline_size)
block_size=options.cacheline_size) dcache = dcache_class(size=options.l1d_size,
dcache = O3_ARM_v7a_DCache(size = options.l1d_size, assoc=options.l1d_assoc,
assoc = options.l1d_assoc, block_size=options.cacheline_size)
block_size=options.cacheline_size)
else:
icache = L1Cache(size = options.l1i_size,
assoc = options.l1i_assoc,
block_size=options.cacheline_size)
dcache = L1Cache(size = options.l1d_size,
assoc = options.l1d_assoc,
block_size=options.cacheline_size)
# When connecting the caches, the clock is also inherited # When connecting the caches, the clock is also inherited
# from the CPU in question # from the CPU in question