SConscript revision 5192
16019Shines@cs.fsu.edu# -*- mode:python -*-
26019Shines@cs.fsu.edu
310037SARM gem5 Developers# Copyright (c) 2004-2005 The Regents of The University of Michigan
47100Sgblack@eecs.umich.edu# All rights reserved.
57100Sgblack@eecs.umich.edu#
67100Sgblack@eecs.umich.edu# Redistribution and use in source and binary forms, with or without
77100Sgblack@eecs.umich.edu# modification, are permitted provided that the following conditions are
87100Sgblack@eecs.umich.edu# met: redistributions of source code must retain the above copyright
97100Sgblack@eecs.umich.edu# notice, this list of conditions and the following disclaimer;
107100Sgblack@eecs.umich.edu# redistributions in binary form must reproduce the above copyright
117100Sgblack@eecs.umich.edu# notice, this list of conditions and the following disclaimer in the
127100Sgblack@eecs.umich.edu# documentation and/or other materials provided with the distribution;
137100Sgblack@eecs.umich.edu# neither the name of the copyright holders nor the names of its
147100Sgblack@eecs.umich.edu# contributors may be used to endorse or promote products derived from
156019Shines@cs.fsu.edu# this software without specific prior written permission.
166019Shines@cs.fsu.edu#
176019Shines@cs.fsu.edu# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
186019Shines@cs.fsu.edu# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
196019Shines@cs.fsu.edu# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
206019Shines@cs.fsu.edu# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
216019Shines@cs.fsu.edu# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
226019Shines@cs.fsu.edu# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
236019Shines@cs.fsu.edu# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
246019Shines@cs.fsu.edu# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
256019Shines@cs.fsu.edu# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
266019Shines@cs.fsu.edu# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
276019Shines@cs.fsu.edu# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
286019Shines@cs.fsu.edu#
296019Shines@cs.fsu.edu# Authors: Nathan Binkert
306019Shines@cs.fsu.edu
316019Shines@cs.fsu.eduimport os, subprocess
326019Shines@cs.fsu.edu
336019Shines@cs.fsu.eduImport('env')
346019Shines@cs.fsu.edu
356019Shines@cs.fsu.eduelf_files = []
366019Shines@cs.fsu.edudef ElfFile(filename):
376019Shines@cs.fsu.edu    elf_files.append(File(filename))
386019Shines@cs.fsu.edu
396019Shines@cs.fsu.eduElfFile('elf_begin.c')
406019Shines@cs.fsu.eduElfFile('elf_cntl.c')
416019Shines@cs.fsu.eduElfFile('elf_data.c')
426757SAli.Saidi@ARM.comElfFile('elf_end.c')
436019Shines@cs.fsu.eduElfFile('elf_fill.c')
446019Shines@cs.fsu.eduElfFile('elf_flag.c')
456019Shines@cs.fsu.eduElfFile('elf_getarhdr.c')
466019Shines@cs.fsu.eduElfFile('elf_getarsym.c')
476019Shines@cs.fsu.eduElfFile('elf_getbase.c')
4811320Ssteve.reinhardt@amd.comElfFile('elf_getident.c')
496019Shines@cs.fsu.eduElfFile('elf_hash.c')
509022Sgblack@eecs.umich.eduElfFile('elf_kind.c')
516019Shines@cs.fsu.eduElfFile('elf_memory.c')
5212640Sgiacomo.travaglini@arm.comElfFile('elf_next.c')
5310037SARM gem5 DevelopersElfFile('elf_phnum.c')
5410037SARM gem5 DevelopersElfFile('elf_rand.c')
557170Sgblack@eecs.umich.eduElfFile('elf_rawfile.c')
566253Sgblack@eecs.umich.eduElfFile('elf_scn.c')
5710037SARM gem5 DevelopersElfFile('elf_shnum.c')
587202Sgblack@eecs.umich.eduElfFile('elf_shstrndx.c')
5910037SARM gem5 DevelopersElfFile('elf_strptr.c')
606253Sgblack@eecs.umich.eduElfFile('elf_update.c')
6110611SAndreas.Sandberg@ARM.comElfFile('elf_version.c')
626253Sgblack@eecs.umich.eduElfFile('gelf_checksum.c')
637396Sgblack@eecs.umich.eduElfFile('gelf_dyn.c')
6410037SARM gem5 DevelopersElfFile('gelf_ehdr.c')
658745Sgblack@eecs.umich.eduElfFile('gelf_fsize.c')
667405SAli.Saidi@ARM.comElfFile('gelf_getclass.c')
6710461SAndreas.Sandberg@ARM.comElfFile('gelf_phdr.c')
688782Sgblack@eecs.umich.eduElfFile('gelf_rel.c')
698782Sgblack@eecs.umich.eduElfFile('gelf_rela.c')
708782Sgblack@eecs.umich.eduElfFile('gelf_shdr.c')
7110810Sbr@bsdpad.comElfFile('gelf_sym.c')
7210810Sbr@bsdpad.comElfFile('gelf_symshndx.c')
7310810Sbr@bsdpad.comElfFile('gelf_xlate.c')
747259Sgblack@eecs.umich.eduElfFile('libelf.c')
758757Sgblack@eecs.umich.eduElfFile('libelf_align.c')
7610461SAndreas.Sandberg@ARM.comElfFile('libelf_allocate.c')
778782Sgblack@eecs.umich.eduElfFile('libelf_ar.c')
788757Sgblack@eecs.umich.eduElfFile('libelf_checksum.c')
7912531Sandreas.sandberg@arm.comElfFile('libelf_data.c')
808777Sgblack@eecs.umich.eduElfFile('libelf_ehdr.c')
818782Sgblack@eecs.umich.eduElfFile('libelf_extended.c')
828756Sgblack@eecs.umich.eduElfFile('libelf_phdr.c')
8310037SARM gem5 DevelopersElfFile('libelf_shdr.c')
8410037SARM gem5 DevelopersElfFile('libelf_xlate.c')
856019Shines@cs.fsu.edu
8612605Sgiacomo.travaglini@arm.comElfFile('libelf_convert.c')
876757SAli.Saidi@ARM.comElfFile('libelf_fsize.c')
888757Sgblack@eecs.umich.eduElfFile('libelf_msize.c')
896019Shines@cs.fsu.edu
908745Sgblack@eecs.umich.edum4env = Environment(ENV=os.environ)
919384SAndreas.Sandberg@arm.comif env.get('CC'):
926397Sgblack@eecs.umich.edu    m4env['CC'] = env['CC']
9312531Sandreas.sandberg@arm.comif env.get('CXX'):
948782Sgblack@eecs.umich.edu    m4env['CXX'] = env['CXX']
956019Shines@cs.fsu.edu
9610461SAndreas.Sandberg@ARM.com# If we have gm4 use it
976397Sgblack@eecs.umich.eduif m4env.Detect('gm4'):
988335Snate@binkert.org    m4env['M4'] = 'gm4'
9912531Sandreas.sandberg@arm.com
1009023Sgblack@eecs.umich.edu# Check that m4 is available
1019023Sgblack@eecs.umich.eduimport SCons.Tool.m4
10210461SAndreas.Sandberg@ARM.comif not SCons.Tool.m4.exists(m4env):
1038335Snate@binkert.org   print "Error: Can't find version of M4 macro processor.  " + \
1046019Shines@cs.fsu.edu         "Please install M4 and try again."
10510196SCurtis.Dunham@arm.com   Exit(1)
10612222Sgabeblack@google.com
107m4env.Append(M4FLAGS='-DSRCDIR=%s' % Dir('.').path)
108m4env['M4COM'] = '$M4 $M4FLAGS $SOURCES > $TARGET'
109m4env.M4(target=File('libelf_convert.c'),
110         source=[File('elf_types.m4'), File('libelf_convert.m4')])
111m4env.M4(target=File('libelf_fsize.c'),
112         source=[File('elf_types.m4'), File('libelf_fsize.m4')])
113m4env.M4(target=File('libelf_msize.c'),
114         source=[File('elf_types.m4'), File('libelf_msize.m4')])
115m4env.Library('elf', elf_files)
116
117env.Append(CPPPATH=Dir('.'))
118env.Append(LIBS=['elf'])
119env.Append(LIBPATH=[Dir('.')])
120
121