These will be filled out in later changes. This CL just adds the plumbing to the build script. Change-Id: If58ea023d0c85eae0160f88217c83fca70346da2 Reviewed-on: https://gem5-review.googlesource.com/c/public/gem5/+/27688 Maintainer: Gabe Black <gabeblack@google.com> Tested-by: kokoro <noreply+kokoro@google.com> Reviewed-by: Jason Lowe-Power <power.jg@gmail.com>
125 lines
4.9 KiB
Python
125 lines
4.9 KiB
Python
# Copyright 2020 Google, Inc.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are
|
|
# met: redistributions of source code must retain the above copyright
|
|
# notice, this list of conditions and the following disclaimer;
|
|
# redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution;
|
|
# neither the name of the copyright holders nor the names of its
|
|
# contributors may be used to endorse or promote products derived from
|
|
# this software without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
|
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
|
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
|
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
|
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
import os
|
|
|
|
Import('*')
|
|
|
|
env.Append(CPPPATH=Dir('.'))
|
|
|
|
# Raw source files.
|
|
args = 'args.cc'
|
|
call_type = 'call_type.cc'
|
|
command = 'command.cc'
|
|
m5 = 'm5.cc'
|
|
m5_mmap = 'm5_mmap.c'
|
|
usage = 'usage.cc'
|
|
|
|
jni = 'jni_gem5Op.c'
|
|
lua = 'lua_gem5Op.cc'
|
|
|
|
all_call_types = list(env['CALL_TYPE'].values())
|
|
call_types = list([ ct for ct in all_call_types if ct.enabled ])
|
|
m5ops = { ct.name: 'abi/${ABI}/%s' % ct.impl_file
|
|
for ct in call_types }
|
|
all_m5ops = list(m5ops.values())
|
|
|
|
default_call_type = list([ ct for ct in call_types if ct.default ])
|
|
assert len(default_call_type) == 1, \
|
|
'There should be exactly one default call type for %s, found %d' % \
|
|
(env['ABI'], len(default_call_type))
|
|
default_call_type = default_call_type[0]
|
|
|
|
static_env = env.Clone()
|
|
static_env.Append(LINKFLAGS=[ '-no-pie', '-static' ])
|
|
|
|
#
|
|
# The m5 library for use in other C/C++ programs.
|
|
#
|
|
libm5 = static_env.StaticLibrary('out/m5', [ m5_mmap ] + all_m5ops)
|
|
|
|
commands = env.SConscript('command/SConscript', exports={ "env": static_env })
|
|
|
|
#
|
|
# The m5 stand alone command line utility.
|
|
#
|
|
ct_support = []
|
|
for ct in call_types:
|
|
ct_env = static_env.Clone()
|
|
is_default = 'true' if ct.default else 'false'
|
|
ct_env.Append(CXXFLAGS=[ '-DCALL_TYPE_IS_DEFAULT=%s' % is_default ])
|
|
ct_support.extend(ct_env.StaticObject('call_type/%s.cc' % ct.name))
|
|
m5_bin = static_env.Program('out/m5', ct_support +
|
|
[ args, call_type, command, commands, m5, m5_mmap, libm5, usage ])
|
|
|
|
|
|
# The shared version of the m5 op call sights, used by mutliple targets below.
|
|
shared_env = env.Clone()
|
|
shared_env.Append(ASFLAGS='-DM5OP_PIC')
|
|
m5op_shared = shared_env.SharedObject(all_m5ops)
|
|
|
|
#
|
|
# Unit tests for enabled call types.
|
|
#
|
|
call_type_shared = shared_env.SharedObject(call_type)
|
|
args_shared = shared_env.SharedObject(args)
|
|
m5_mmap_shared = shared_env.SharedObject(m5_mmap)
|
|
for ct in call_types:
|
|
ct_env = shared_env.Clone()
|
|
ct_env.Append(CXXFLAGS=[ '-DCALL_TYPE_IS_DEFAULT=false' ])
|
|
ct_env.GTest('call_type/%s' % ct.name, 'call_type/%s.test.cc' % ct.name,
|
|
'call_type/%s.cc' % ct.name, call_type_shared, args_shared,
|
|
m5_mmap_shared, m5ops[ct.name])
|
|
|
|
if env['HAVE_JAVA']:
|
|
#
|
|
# A wrapper to make the m5 ops available in Java through the JNI.
|
|
#
|
|
java_env = shared_env.Clone()
|
|
# SCons provides Java and JavaH builders, but the JavaH builder assumes
|
|
# that the javah tool exists. Java has dropped that tool in favor of a -h
|
|
# option on javac which the Java builder doesn't know how to use. To get
|
|
# around this, we set up our own builder which does the "right thing" here.
|
|
java_env.Command([ 'jni_gem5Op.h', 'out/gem5OpJni.jar' ],
|
|
'jni/gem5Op.java',
|
|
[ '${JAVAC} ${JAVACFLAGS} -d ${OUT} ${SOURCES} -h ${CWD}',
|
|
'${JAR} cvf ${TARGETS[1]} ${JNI_DIR}/*.class' ],
|
|
JNI_DIR=Dir('out').Dir('jni'),
|
|
OUT=Dir('out'), CWD=Dir('.'))
|
|
# Set include paths to the C headers from the JDK which scons found for us.
|
|
java_env.Append(CPPPATH='${JAVAINCLUDES}')
|
|
java_env.SharedLibrary('out/gem5OpJni', [ jni ] + m5op_shared)
|
|
|
|
|
|
if env['HAVE_LUA51']:
|
|
#
|
|
# A wrapper to make the m5 ops available in lua version 5.1.
|
|
#
|
|
lua_env = shared_env.Clone()
|
|
# Extract the include paths needed for lua51 using pkg-config.
|
|
lua_env.ParseConfig('pkg-config --cflags lua51')
|
|
lib = lua_env.SharedLibrary('out/gem5OpLua',
|
|
[ lua, m5_mmap_shared ] + m5op_shared)
|