| # 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 = 'java/gem5/ops.cc' |
| 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 = ct.setup_env(static_env) |
| 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 = ct.setup_env(shared_env, allow_default=False) |
| srcs = [ '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 ct.verifier: |
| srcs.append('abi/${ABI}/%s' % ct.verifier) |
| ct_env.GTest('call_type/%s' % ct.name, *srcs) |
| |
| if env['HAVE_JAVA']: |
| # |
| # A wrapper to make the m5 ops available in Java through the JNI. |
| # |
| java_env = shared_env.Clone() |
| pkg_dir = Dir('java').Dir('gem5') |
| srcs = [ pkg_dir.File('Ops.java') ] |
| if java_env['HAVE_JUNIT']: |
| srcs.append(pkg_dir.File('OpsTest.java')) |
| # 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. |
| jni_header = Dir('java').File('gem5_Ops.h') |
| |
| java_files = [] |
| class_files = [] |
| def check_for_java(arg, dirname, fnames): |
| for filename in fnames: |
| base, extension = os.path.splitext(filename) |
| if extension == '.java': |
| java_files.append(dirname.File(filename)) |
| class_files.append(dirname.File(base + '.class')) |
| |
| Dir('java').walk(check_for_java, None) |
| |
| java_env.Command([ jni_header ] + class_files, java_files, |
| MakeAction('${JAVAC} ${JAVACFLAGS} -d ${JAVA_DIR} ' |
| '${SOURCES} -h ${JAVA_DIR}', |
| 'JAVA'), JAVA_DIR=Dir('java')) |
| |
| # Set include paths to the C headers from the JDK which scons found for us. |
| java_env.Append(CPPPATH='${JAVAINCLUDES}') |
| for ct in all_call_types: |
| if ct.default: |
| java_env.Append(CXXFLAGS=[ '-DCALL_TYPE_DEFAULT=%s' % ct.name ]) |
| java_env.Append(CXXFLAGS=[ '-DCALL_TYPE_%s_ENABLED=%s' % |
| (ct.name, '1' if ct.enabled else '0') ]) |
| jni_lib = java_env.SharedLibrary( |
| 'java/gem5Ops', [ jni ] + m5op_shared + m5_mmap_shared) |
| |
| java_env.Jar(Dir('out').File('gem5Ops.jar'), |
| jni_lib + class_files, JARCHDIR=Dir('java')) |
| |
| 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) |