SConscript revision 8745
1# -*- mode:python -*- 2 3# Copyright (c) 2009 The University of Edinburgh 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: Timothy M. Jones 30 31Import('*') 32 33if env['TARGET_ISA'] == 'power': 34# Workaround for bug in SCons version > 0.97d20071212 35# Scons bug id: 2006 M5 Bug id: 308 36 Dir('isa/formats') 37 Source('insts/branch.cc') 38 Source('insts/mem.cc') 39 Source('insts/integer.cc') 40 Source('insts/floating.cc') 41 Source('insts/condition.cc') 42 Source('insts/static_inst.cc') 43 Source('interrupts.cc') 44 Source('pagetable.cc') 45 Source('tlb.cc') 46 Source('utility.cc') 47 48 SimObject('PowerInterrupts.py') 49 SimObject('PowerTLB.py') 50 51 DebugFlag('Power') 52 53 if not env['FULL_SYSTEM']: 54 Source('process.cc') 55 Source('linux/linux.cc') 56 Source('linux/process.cc') 57 58 # Add in files generated by the ISA description. 59 isa_desc_files = env.ISADesc('isa/main.isa') 60 61 # Only non-header files need to be compiled. 62 for f in isa_desc_files: 63 if not f.path.endswith('.hh'): 64 Source(f) 65 66