SConscript revision 5647
1# -*- mode:python -*- 2 3# Copyright (c) 2004-2006 The Regents of The University of Michigan 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: Gabe Black 30# Steve Reinhardt 31# Korey Sewell 32 33Import('*') 34 35if env['TARGET_ISA'] == 'mips': 36# Workaround for bug in SCons version > 0.97d20071212 37# Scons bug id: 2006 M5 Bug id: 308 38 Dir('isa/formats') 39 Source('faults.cc') 40 Source('regfile/int_regfile.cc') 41 Source('regfile/float_regfile.cc') 42 Source('regfile/misc_regfile.cc') 43 Source('regfile/regfile.cc') 44 Source('tlb.cc') 45 Source('pagetable.cc') 46 Source('utility.cc') 47 Source('dsp.cc') 48 49 SimObject('MipsTLB.py') 50 TraceFlag('MipsPRA') 51 52 if env['FULL_SYSTEM']: 53 SimObject('MipsSystem.py') 54 SimObject('MipsInterrupts.py') 55 Source('idle_event.cc') 56 Source('mips_core_specific.cc') 57 Source('vtophys.cc') 58 Source('system.cc') 59 Source('stacktrace.cc') 60 Source('linux/system.cc') 61 Source('interrupts.cc') 62 Source('bare_iron/system.cc') 63 else: 64 Source('process.cc') 65 Source('linux/linux.cc') 66 Source('linux/process.cc') 67 68 # Add in files generated by the ISA description. 69 isa_desc_files = env.ISADesc('isa/main.isa') 70 # Only non-header files need to be compiled. 71 for f in isa_desc_files: 72 if not f.path.endswith('.hh'): 73 Source(f) 74