SConscript revision 6333:9425c8a86e5c
1# -*- mode:python -*- 2 3# Copyright (c) 2007-2008 The Florida State University 4# All rights reserved. 5# 6# Redistribution and use in source and binary forms, with or without 7# modification, are permitted provided that the following conditions are 8# met: redistributions of source code must retain the above copyright 9# notice, this list of conditions and the following disclaimer; 10# redistributions in binary form must reproduce the above copyright 11# notice, this list of conditions and the following disclaimer in the 12# documentation and/or other materials provided with the distribution; 13# neither the name of the copyright holders nor the names of its 14# contributors may be used to endorse or promote products derived from 15# this software without specific prior written permission. 16# 17# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 18# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 19# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 20# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 21# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, 22# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT 23# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 24# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 25# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 27# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28# 29# Authors: Stephen Hines 30 31Import('*') 32 33if env['TARGET_ISA'] == 'arm': 34# Workaround for bug in SCons version > 0.97d20071212 35# Scons bug id: 2006 M5 Bug id: 308 36 Dir('isa/formats') 37 Source('faults.cc') 38 Source('insts/branch.cc') 39 Source('insts/mem.cc') 40 Source('insts/pred_inst.cc') 41 Source('insts/static_inst.cc') 42 Source('pagetable.cc') 43 Source('tlb.cc') 44 Source('vtophys.cc') 45 46 SimObject('ArmTLB.py') 47 TraceFlag('Arm') 48 49 if env['FULL_SYSTEM']: 50 #Insert Full-System Files Here 51 pass 52 else: 53 Source('process.cc') 54 Source('linux/linux.cc') 55 Source('linux/process.cc') 56 57 # Add in files generated by the ISA description. 58 isa_desc_files = env.ISADesc('isa/main.isa') 59 # Only non-header files need to be compiled. 60 for f in isa_desc_files: 61 if not f.path.endswith('.hh'): 62 Source(f) 63 64