SConscript revision 4486
16226Snate@binkert.org# -*- mode:python -*- 26226Snate@binkert.org 36226Snate@binkert.org# Copyright (c) 2006 The Regents of The University of Michigan 46226Snate@binkert.org# All rights reserved. 56226Snate@binkert.org# 66226Snate@binkert.org# Redistribution and use in source and binary forms, with or without 76226Snate@binkert.org# modification, are permitted provided that the following conditions are 86226Snate@binkert.org# met: redistributions of source code must retain the above copyright 96226Snate@binkert.org# notice, this list of conditions and the following disclaimer; 106226Snate@binkert.org# redistributions in binary form must reproduce the above copyright 116226Snate@binkert.org# notice, this list of conditions and the following disclaimer in the 126226Snate@binkert.org# documentation and/or other materials provided with the distribution; 136226Snate@binkert.org# neither the name of the copyright holders nor the names of its 146226Snate@binkert.org# contributors may be used to endorse or promote products derived from 156226Snate@binkert.org# this software without specific prior written permission. 166226Snate@binkert.org# 176226Snate@binkert.org# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 186226Snate@binkert.org# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 196226Snate@binkert.org# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 206226Snate@binkert.org# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 216226Snate@binkert.org# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 226226Snate@binkert.org# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 236226Snate@binkert.org# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 246226Snate@binkert.org# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 256226Snate@binkert.org# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 266226Snate@binkert.org# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 276226Snate@binkert.org# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 286226Snate@binkert.org# 296226Snate@binkert.org# Authors: Nathan Binkert 306226Snate@binkert.org 316226Snate@binkert.orgImport('*') 326226Snate@binkert.org 3310281SAndreas.Sandberg@ARM.comdef make_cc(target, source, env): 3410281SAndreas.Sandberg@ARM.com assert(len(source) == 1) 359480Snilay@cs.wisc.edu assert(len(target) == 1) 3610281SAndreas.Sandberg@ARM.com 3710281SAndreas.Sandberg@ARM.com traceflags = {} 3811433Smitch.hayenga@arm.com execfile(str(source[0]), traceflags) 3910281SAndreas.Sandberg@ARM.com func = traceflags['gen_cc'] 4010281SAndreas.Sandberg@ARM.com func(str(target[0])) 4110281SAndreas.Sandberg@ARM.com 4213957Sjairo.balart@metempsy.comdef make_hh(target, source, env): 4311433Smitch.hayenga@arm.com assert(len(source) == 1) 4410281SAndreas.Sandberg@ARM.com assert(len(target) == 1) 4510281SAndreas.Sandberg@ARM.com 4610281SAndreas.Sandberg@ARM.com traceflags = {} 4713626Sjairo.balart@metempsy.com execfile(str(source[0]), traceflags) 4813454Spau.cabre@metempsy.com func = traceflags['gen_hh'] 4913627Sjavier.bueno@metempsy.com func(str(target[0])) 5011784Sarthur.perais@inria.fr 5113685Sjavier.bueno@metempsy.comenv.Command('traceflags.hh', 'traceflags.py', make_hh) 5213685Sjavier.bueno@metempsy.comenv.Command('traceflags.cc', 'traceflags.py', make_cc) 5313685Sjavier.bueno@metempsy.com 5413685Sjavier.bueno@metempsy.comSource('annotate.cc') 5510281SAndreas.Sandberg@ARM.comSource('bigint.cc') 5610281SAndreas.Sandberg@ARM.comSource('circlebuf.cc') 5713454Spau.cabre@metempsy.comSource('cprintf.cc') 5810785Sgope@wisc.eduSource('crc.cc') 5913685Sjavier.bueno@metempsy.comSource('fast_alloc.cc') 60Source('fenv.c') 61Source('fifo_buffer.cc') 62Source('hostinfo.cc') 63Source('hybrid_pred.cc') 64Source('inet.cc') 65Source('inifile.cc') 66Source('intmath.cc') 67Source('match.cc') 68Source('misc.cc') 69Source('output.cc') 70Source('pollevent.cc') 71Source('random.cc') 72Source('range.cc') 73Source('remote_gdb.cc') 74Source('sat_counter.cc') 75Source('socket.cc') 76Source('statistics.cc') 77Source('str.cc') 78Source('time.cc') 79Source('trace.cc') 80Source('traceflags.cc') 81Source('userinfo.cc') 82 83Source('compression/lzss_compression.cc') 84 85Source('loader/aout_object.cc') 86Source('loader/ecoff_object.cc') 87Source('loader/elf_object.cc') 88Source('loader/object_file.cc') 89Source('loader/raw_object.cc') 90Source('loader/symtab.cc') 91 92Source('stats/events.cc') 93Source('stats/output.cc') 94Source('stats/statdb.cc') 95Source('stats/text.cc') 96Source('stats/visit.cc') 97 98if env['USE_MYSQL']: 99 Source('mysql.cc') 100 Source('stats/mysql.cc') 101 102PySource('m5', 'traceflags.py') 103