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:
parent
e5dca84c3f
commit
1c7aa665bf
1 changed files with 35 additions and 25 deletions
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue