14418Ssaidi@eecs.umich.edu# Copyright (c) 2006-2007 The Regents of The University of Michigan
22995Ssaidi@eecs.umich.edu# All rights reserved.
32995Ssaidi@eecs.umich.edu#
42995Ssaidi@eecs.umich.edu# Redistribution and use in source and binary forms, with or without
52995Ssaidi@eecs.umich.edu# modification, are permitted provided that the following conditions are
62995Ssaidi@eecs.umich.edu# met: redistributions of source code must retain the above copyright
72995Ssaidi@eecs.umich.edu# notice, this list of conditions and the following disclaimer;
82995Ssaidi@eecs.umich.edu# redistributions in binary form must reproduce the above copyright
92995Ssaidi@eecs.umich.edu# notice, this list of conditions and the following disclaimer in the
102995Ssaidi@eecs.umich.edu# documentation and/or other materials provided with the distribution;
112995Ssaidi@eecs.umich.edu# neither the name of the copyright holders nor the names of its
122995Ssaidi@eecs.umich.edu# contributors may be used to endorse or promote products derived from
132995Ssaidi@eecs.umich.edu# this software without specific prior written permission.
142995Ssaidi@eecs.umich.edu#
152995Ssaidi@eecs.umich.edu# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
162995Ssaidi@eecs.umich.edu# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
172995Ssaidi@eecs.umich.edu# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
182995Ssaidi@eecs.umich.edu# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
192995Ssaidi@eecs.umich.edu# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
202995Ssaidi@eecs.umich.edu# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
212995Ssaidi@eecs.umich.edu# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
222995Ssaidi@eecs.umich.edu# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
232995Ssaidi@eecs.umich.edu# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
242995Ssaidi@eecs.umich.edu# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
252995Ssaidi@eecs.umich.edu# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
262995Ssaidi@eecs.umich.edu#
272995Ssaidi@eecs.umich.edu# Authors: Ali Saidi
282995Ssaidi@eecs.umich.edu
2912564Sgabeblack@google.comfrom __future__ import print_function
3013774Sandreas.sandberg@arm.comfrom __future__ import absolute_import
3112564Sgabeblack@google.com
3213774Sandreas.sandberg@arm.comfrom .SysPaths import script, disk, binary
338088Sgblack@eecs.umich.edufrom os import environ as env
347869Sgblack@eecs.umich.edufrom m5.defines import buildEnv
352995Ssaidi@eecs.umich.edu
363304Sstever@eecs.umich.educlass SysConfig:
3710747SChris.Emmons@arm.com    def __init__(self, script=None, mem=None, disk=None, rootdev=None,
3810747SChris.Emmons@arm.com                 os_type='linux'):
392995Ssaidi@eecs.umich.edu        self.scriptname = script
402995Ssaidi@eecs.umich.edu        self.diskname = disk
412995Ssaidi@eecs.umich.edu        self.memsize = mem
4210697SCurtis.Dunham@arm.com        self.root = rootdev
4310747SChris.Emmons@arm.com        self.ostype = os_type
442995Ssaidi@eecs.umich.edu
452995Ssaidi@eecs.umich.edu    def script(self):
462995Ssaidi@eecs.umich.edu        if self.scriptname:
472995Ssaidi@eecs.umich.edu            return script(self.scriptname)
482995Ssaidi@eecs.umich.edu        else:
492995Ssaidi@eecs.umich.edu            return ''
502995Ssaidi@eecs.umich.edu
512995Ssaidi@eecs.umich.edu    def mem(self):
522995Ssaidi@eecs.umich.edu        if self.memsize:
532995Ssaidi@eecs.umich.edu            return self.memsize
542995Ssaidi@eecs.umich.edu        else:
552995Ssaidi@eecs.umich.edu            return '128MB'
562995Ssaidi@eecs.umich.edu
572995Ssaidi@eecs.umich.edu    def disk(self):
582995Ssaidi@eecs.umich.edu        if self.diskname:
592995Ssaidi@eecs.umich.edu            return disk(self.diskname)
607869Sgblack@eecs.umich.edu        elif buildEnv['TARGET_ISA'] == 'alpha':
617869Sgblack@eecs.umich.edu            return env.get('LINUX_IMAGE', disk('linux-latest.img'))
627869Sgblack@eecs.umich.edu        elif buildEnv['TARGET_ISA'] == 'x86':
637869Sgblack@eecs.umich.edu            return env.get('LINUX_IMAGE', disk('x86root.img'))
648212SAli.Saidi@ARM.com        elif buildEnv['TARGET_ISA'] == 'arm':
6510512SAli.Saidi@ARM.com            return env.get('LINUX_IMAGE', disk('linux-aarch32-ael.img'))
6611949Sgabeblack@google.com        elif buildEnv['TARGET_ISA'] == 'sparc':
6711949Sgabeblack@google.com            return env.get('LINUX_IMAGE', disk('disk.s10hw2'))
682995Ssaidi@eecs.umich.edu        else:
6912564Sgabeblack@google.com            print("Don't know what default disk image to use for %s ISA" %
7012564Sgabeblack@google.com                buildEnv['TARGET_ISA'])
719059Snilay@cs.wisc.edu            exit(1)
722995Ssaidi@eecs.umich.edu
7310697SCurtis.Dunham@arm.com    def rootdev(self):
7410697SCurtis.Dunham@arm.com        if self.root:
7510697SCurtis.Dunham@arm.com            return self.root
7610697SCurtis.Dunham@arm.com        else:
7710697SCurtis.Dunham@arm.com            return '/dev/sda1'
7810697SCurtis.Dunham@arm.com
7910747SChris.Emmons@arm.com    def os_type(self):
8010747SChris.Emmons@arm.com        return self.ostype
8110747SChris.Emmons@arm.com
823304Sstever@eecs.umich.edu# Benchmarks are defined as a key in a dict which is a list of SysConfigs
832995Ssaidi@eecs.umich.edu# The first defined machine is the test system, the others are driving systems
842995Ssaidi@eecs.umich.edu
853304Sstever@eecs.umich.eduBenchmarks = {
863304Sstever@eecs.umich.edu    'PovrayBench':  [SysConfig('povray-bench.rcS', '512MB', 'povray.img')],
873304Sstever@eecs.umich.edu    'PovrayAutumn': [SysConfig('povray-autumn.rcS', '512MB', 'povray.img')],
882995Ssaidi@eecs.umich.edu
895543Ssaidi@eecs.umich.edu    'NetperfStream':    [SysConfig('netperf-stream-client.rcS'),
903304Sstever@eecs.umich.edu                         SysConfig('netperf-server.rcS')],
915543Ssaidi@eecs.umich.edu    'NetperfStreamUdp': [SysConfig('netperf-stream-udp-client.rcS'),
924418Ssaidi@eecs.umich.edu                         SysConfig('netperf-server.rcS')],
935543Ssaidi@eecs.umich.edu    'NetperfUdpLocal':  [SysConfig('netperf-stream-udp-local.rcS')],
945543Ssaidi@eecs.umich.edu    'NetperfStreamNT':  [SysConfig('netperf-stream-nt-client.rcS'),
953304Sstever@eecs.umich.edu                         SysConfig('netperf-server.rcS')],
965543Ssaidi@eecs.umich.edu    'NetperfMaerts':    [SysConfig('netperf-maerts-client.rcS'),
973304Sstever@eecs.umich.edu                         SysConfig('netperf-server.rcS')],
985543Ssaidi@eecs.umich.edu    'SurgeStandard':    [SysConfig('surge-server.rcS', '512MB'),
993304Sstever@eecs.umich.edu                         SysConfig('surge-client.rcS', '256MB')],
1005543Ssaidi@eecs.umich.edu    'SurgeSpecweb':     [SysConfig('spec-surge-server.rcS', '512MB'),
1013304Sstever@eecs.umich.edu                         SysConfig('spec-surge-client.rcS', '256MB')],
1025543Ssaidi@eecs.umich.edu    'Nhfsstone':        [SysConfig('nfs-server-nhfsstone.rcS', '512MB'),
1033304Sstever@eecs.umich.edu                         SysConfig('nfs-client-nhfsstone.rcS')],
1045543Ssaidi@eecs.umich.edu    'Nfs':              [SysConfig('nfs-server.rcS', '900MB'),
1053304Sstever@eecs.umich.edu                         SysConfig('nfs-client-dbench.rcS')],
1065543Ssaidi@eecs.umich.edu    'NfsTcp':           [SysConfig('nfs-server.rcS', '900MB'),
1073304Sstever@eecs.umich.edu                         SysConfig('nfs-client-tcp.rcS')],
1085543Ssaidi@eecs.umich.edu    'IScsiInitiator':   [SysConfig('iscsi-client.rcS', '512MB'),
1093304Sstever@eecs.umich.edu                         SysConfig('iscsi-server.rcS', '512MB')],
1105543Ssaidi@eecs.umich.edu    'IScsiTarget':      [SysConfig('iscsi-server.rcS', '512MB'),
1113304Sstever@eecs.umich.edu                         SysConfig('iscsi-client.rcS', '512MB')],
1125543Ssaidi@eecs.umich.edu    'Validation':       [SysConfig('iscsi-server.rcS', '512MB'),
1133304Sstever@eecs.umich.edu                         SysConfig('iscsi-client.rcS', '512MB')],
1145543Ssaidi@eecs.umich.edu    'Ping':             [SysConfig('ping-server.rcS',),
1153304Sstever@eecs.umich.edu                         SysConfig('ping-client.rcS')],
1162995Ssaidi@eecs.umich.edu
1175543Ssaidi@eecs.umich.edu    'ValAccDelay':      [SysConfig('devtime.rcS', '512MB')],
1185543Ssaidi@eecs.umich.edu    'ValAccDelay2':     [SysConfig('devtimewmr.rcS', '512MB')],
1195543Ssaidi@eecs.umich.edu    'ValMemLat':        [SysConfig('micro_memlat.rcS', '512MB')],
1205543Ssaidi@eecs.umich.edu    'ValMemLat2MB':     [SysConfig('micro_memlat2mb.rcS', '512MB')],
1215543Ssaidi@eecs.umich.edu    'ValMemLat8MB':     [SysConfig('micro_memlat8mb.rcS', '512MB')],
1225543Ssaidi@eecs.umich.edu    'ValMemLat':        [SysConfig('micro_memlat8.rcS', '512MB')],
1235543Ssaidi@eecs.umich.edu    'ValTlbLat':        [SysConfig('micro_tlblat.rcS', '512MB')],
1245543Ssaidi@eecs.umich.edu    'ValSysLat':        [SysConfig('micro_syscall.rcS', '512MB')],
1255543Ssaidi@eecs.umich.edu    'ValCtxLat':        [SysConfig('micro_ctx.rcS', '512MB')],
1265543Ssaidi@eecs.umich.edu    'ValStream':        [SysConfig('micro_stream.rcS', '512MB')],
1275543Ssaidi@eecs.umich.edu    'ValStreamScale':   [SysConfig('micro_streamscale.rcS', '512MB')],
1285543Ssaidi@eecs.umich.edu    'ValStreamCopy':    [SysConfig('micro_streamcopy.rcS', '512MB')],
1292995Ssaidi@eecs.umich.edu
1303372Sstever@eecs.umich.edu    'MutexTest':        [SysConfig('mutex-test.rcS', '128MB')],
1319070Satgutier@umich.edu    'ArmAndroid-GB':    [SysConfig('null.rcS', '256MB',
13210747SChris.Emmons@arm.com                    'ARMv7a-Gingerbread-Android.SMP.mouse.nolock.clean.img',
13310747SChris.Emmons@arm.com                    None, 'android-gingerbread')],
1349070Satgutier@umich.edu    'bbench-gb':        [SysConfig('bbench-gb.rcS', '256MB',
13510747SChris.Emmons@arm.com                            'ARMv7a-Gingerbread-Android.SMP.mouse.nolock.img',
13610747SChris.Emmons@arm.com                            None, 'android-gingerbread')],
1379070Satgutier@umich.edu    'ArmAndroid-ICS':   [SysConfig('null.rcS', '256MB',
13810747SChris.Emmons@arm.com                            'ARMv7a-ICS-Android.SMP.nolock.clean.img',
13910747SChris.Emmons@arm.com                            None, 'android-ics')],
1409070Satgutier@umich.edu    'bbench-ics':       [SysConfig('bbench-ics.rcS', '256MB',
14110747SChris.Emmons@arm.com                            'ARMv7a-ICS-Android.SMP.nolock.img',
14210747SChris.Emmons@arm.com                            None, 'android-ics')]
1433304Sstever@eecs.umich.edu}
1443089Ssaidi@eecs.umich.edu
14513731Sandreas.sandberg@arm.combenchs = list(Benchmarks.keys())
1462995Ssaidi@eecs.umich.edubenchs.sort()
1472995Ssaidi@eecs.umich.eduDefinedBenchmarks = ", ".join(benchs)
148