SConscript revision 5800
14202Sbinkertn@umich.edu# -*- mode:python -*-
24202Sbinkertn@umich.edu
34202Sbinkertn@umich.edu# Copyright (c) 2004-2005 The Regents of The University of Michigan
44202Sbinkertn@umich.edu# All rights reserved.
54202Sbinkertn@umich.edu#
64202Sbinkertn@umich.edu# Redistribution and use in source and binary forms, with or without
74202Sbinkertn@umich.edu# modification, are permitted provided that the following conditions are
84202Sbinkertn@umich.edu# met: redistributions of source code must retain the above copyright
94202Sbinkertn@umich.edu# notice, this list of conditions and the following disclaimer;
104202Sbinkertn@umich.edu# redistributions in binary form must reproduce the above copyright
114202Sbinkertn@umich.edu# notice, this list of conditions and the following disclaimer in the
124202Sbinkertn@umich.edu# documentation and/or other materials provided with the distribution;
134202Sbinkertn@umich.edu# neither the name of the copyright holders nor the names of its
144202Sbinkertn@umich.edu# contributors may be used to endorse or promote products derived from
154202Sbinkertn@umich.edu# this software without specific prior written permission.
164202Sbinkertn@umich.edu#
174202Sbinkertn@umich.edu# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
184202Sbinkertn@umich.edu# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
194202Sbinkertn@umich.edu# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
204202Sbinkertn@umich.edu# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
214202Sbinkertn@umich.edu# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
224202Sbinkertn@umich.edu# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
234202Sbinkertn@umich.edu# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
244202Sbinkertn@umich.edu# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
254202Sbinkertn@umich.edu# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
264202Sbinkertn@umich.edu# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
274202Sbinkertn@umich.edu# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
284202Sbinkertn@umich.edu#
294202Sbinkertn@umich.edu# Authors: Nathan Binkert
304202Sbinkertn@umich.edu
314202Sbinkertn@umich.eduimport os, subprocess
324202Sbinkertn@umich.edu
334486Sbinkertn@umich.eduImport('env')
344486Sbinkertn@umich.edu
356165Ssanchezd@stanford.eduelf_files = []
366168Snate@binkert.orgdef ElfFile(filename):
374202Sbinkertn@umich.edu    elf_files.append(File(filename))
384202Sbinkertn@umich.edu
394202Sbinkertn@umich.eduElfFile('elf_begin.c')
408761Sgblack@eecs.umich.eduElfFile('elf_cntl.c')
414202Sbinkertn@umich.eduElfFile('elf_data.c')
424202Sbinkertn@umich.eduElfFile('elf_end.c')
438914Sandreas.hansson@arm.comElfFile('elf_fill.c')
444202Sbinkertn@umich.eduElfFile('elf_flag.c')
458853Sandreas.hansson@arm.comElfFile('elf_getarhdr.c')
468799Sgblack@eecs.umich.eduElfFile('elf_getarsym.c')
478799Sgblack@eecs.umich.eduElfFile('elf_getbase.c')
486168Snate@binkert.orgElfFile('elf_getident.c')
497768SAli.Saidi@ARM.comElfFile('elf_hash.c')
508931Sandreas.hansson@arm.comElfFile('elf_kind.c')
518931Sandreas.hansson@arm.comElfFile('elf_memory.c')
528931Sandreas.hansson@arm.comElfFile('elf_next.c')
538931Sandreas.hansson@arm.comElfFile('elf_phnum.c')
548763Sgblack@eecs.umich.eduElfFile('elf_rand.c')
557768SAli.Saidi@ARM.comElfFile('elf_rawfile.c')
567768SAli.Saidi@ARM.comElfFile('elf_scn.c')
578335Snate@binkert.orgElfFile('elf_shnum.c')
588335Snate@binkert.orgElfFile('elf_shstrndx.c')
598335Snate@binkert.orgElfFile('elf_strptr.c')
608335Snate@binkert.orgElfFile('elf_update.c')
618335Snate@binkert.orgElfFile('elf_version.c')
628335Snate@binkert.orgElfFile('gelf_checksum.c')
638914Sandreas.hansson@arm.comElfFile('gelf_dyn.c')
647780Snilay@cs.wisc.eduElfFile('gelf_ehdr.c')
658335Snate@binkert.orgElfFile('gelf_fsize.c')
668335Snate@binkert.orgElfFile('gelf_getclass.c')
678683Snilay@cs.wisc.eduElfFile('gelf_phdr.c')
688335Snate@binkert.orgElfFile('gelf_rel.c')
698335Snate@binkert.orgElfFile('gelf_rela.c')
708335Snate@binkert.orgElfFile('gelf_shdr.c')
718335Snate@binkert.orgElfFile('gelf_sym.c')
728335Snate@binkert.orgElfFile('gelf_symshndx.c')
738335Snate@binkert.orgElfFile('gelf_xlate.c')
748615Snilay@cs.wisc.eduElfFile('libelf.c')
758335Snate@binkert.orgElfFile('libelf_align.c')
768687Snilay@cs.wisc.eduElfFile('libelf_allocate.c')
778335Snate@binkert.orgElfFile('libelf_ar.c')
787780Snilay@cs.wisc.eduElfFile('libelf_checksum.c')
797780Snilay@cs.wisc.eduElfFile('libelf_data.c')
808687Snilay@cs.wisc.eduElfFile('libelf_ehdr.c')
818683Snilay@cs.wisc.eduElfFile('libelf_extended.c')
82ElfFile('libelf_phdr.c')
83ElfFile('libelf_shdr.c')
84ElfFile('libelf_xlate.c')
85
86ElfFile('libelf_convert.c')
87ElfFile('libelf_fsize.c')
88ElfFile('libelf_msize.c')
89
90m4env = env.Copy()
91if env['GCC']:
92    major,minor,dot = [ int(x) for x in env['CXXVERSION'].split('.')]
93    if major >= 4:
94        m4env.Append(CCFLAGS=['-Wno-pointer-sign'])
95m4env.Append(CCFLAGS=['-Wno-implicit'])
96del m4env['CPPPATH']
97
98# If we have gm4 use it
99if m4env.Detect('gm4'):
100    m4env['M4'] = 'gm4'
101
102# Check that m4 is available
103import SCons.Tool.m4
104if not SCons.Tool.m4.exists(m4env):
105   print "Error: Can't find version of M4 macro processor.  " + \
106         "Please install M4 and try again."
107   Exit(1)
108
109m4env.Append(M4FLAGS='-DSRCDIR=%s' % Dir('.').path)
110m4env['M4COM'] = '$M4 $M4FLAGS $SOURCES > $TARGET'
111m4env.M4(target=File('libelf_convert.c'),
112         source=[File('elf_types.m4'), File('libelf_convert.m4')])
113m4env.M4(target=File('libelf_fsize.c'),
114         source=[File('elf_types.m4'), File('libelf_fsize.m4')])
115m4env.M4(target=File('libelf_msize.c'),
116         source=[File('elf_types.m4'), File('libelf_msize.m4')])
117
118# Build libelf as a static library with PIC code so it can be linked
119# into either m5 or the library
120m4env.Library('elf', [m4env.SharedObject(f) for f in elf_files])
121
122env.Append(CPPPATH=Dir('.'))
123env.Append(LIBS=['elf'])
124env.Append(LIBPATH=[Dir('.')])
125
126