Browse Source

Autodetect no-strict-aliasing, propagate toolchain option to SCons

BUG=v8:884
v0.7.4-release
Bert Belder 14 years ago
committed by Ryan Dahl
parent
commit
4a34692903
  1. 121
      deps/v8/SConstruct
  2. 3
      deps/v8/src/SConscript

121
deps/v8/SConstruct

@ -27,6 +27,7 @@
import platform import platform
import re import re
import subprocess
import sys import sys
import os import os
from os.path import join, dirname, abspath from os.path import join, dirname, abspath
@ -142,6 +143,9 @@ LIBRARY_FLAGS = {
# Use visibility=default to disable this. # Use visibility=default to disable this.
'CXXFLAGS': ['-fvisibility=hidden'] 'CXXFLAGS': ['-fvisibility=hidden']
}, },
'strictaliasing:off': {
'CCFLAGS': ['-fno-strict-aliasing']
},
'mode:debug': { 'mode:debug': {
'CCFLAGS': ['-g', '-O0'], 'CCFLAGS': ['-g', '-O0'],
'CPPDEFINES': ['ENABLE_DISASSEMBLER', 'DEBUG'], 'CPPDEFINES': ['ENABLE_DISASSEMBLER', 'DEBUG'],
@ -652,8 +656,16 @@ def Abort(message):
sys.exit(1) sys.exit(1)
def GuessToolchain(os): def GuessOS(env):
tools = Environment()['TOOLS'] return utils.GuessOS()
def GuessArch(env):
return utils.GuessArchitecture()
def GuessToolchain(env):
tools = env['TOOLS']
if 'gcc' in tools: if 'gcc' in tools:
return 'gcc' return 'gcc'
elif 'msvc' in tools: elif 'msvc' in tools:
@ -662,7 +674,9 @@ def GuessToolchain(os):
return None return None
def GuessVisibility(os, toolchain): def GuessVisibility(env):
os = env['os']
toolchain = env['toolchain'];
if (os == 'win32' or os == 'cygwin') and toolchain == 'gcc': if (os == 'win32' or os == 'cygwin') and toolchain == 'gcc':
# MinGW / Cygwin can't do it. # MinGW / Cygwin can't do it.
return 'default' return 'default'
@ -672,27 +686,35 @@ def GuessVisibility(os, toolchain):
return 'hidden' return 'hidden'
OS_GUESS = utils.GuessOS() def GuessStrictAliasing(env):
TOOLCHAIN_GUESS = GuessToolchain(OS_GUESS) # There seems to be a problem with gcc 4.5.x
ARCH_GUESS = utils.GuessArchitecture() # see http://code.google.com/p/v8/issues/detail?id=884
VISIBILITY_GUESS = GuessVisibility(OS_GUESS, TOOLCHAIN_GUESS) # it can be worked around by disabling strict aliasing
toolchain = env['toolchain'];
if toolchain == 'gcc':
env = Environment(tools=['gcc'])
version = subprocess.Popen([env['CC'], '-dumpversion'],
stdout=subprocess.PIPE).communicate()[0]
if version.find('4.5.') == 0:
return 'off'
return 'default'
SIMPLE_OPTIONS = { SIMPLE_OPTIONS = {
'toolchain': { 'toolchain': {
'values': ['gcc', 'msvc'], 'values': ['gcc', 'msvc'],
'default': TOOLCHAIN_GUESS, 'guess': GuessToolchain,
'help': 'the toolchain to use (%s)' % TOOLCHAIN_GUESS 'help': 'the toolchain to use'
}, },
'os': { 'os': {
'values': ['freebsd', 'linux', 'macos', 'win32', 'android', 'openbsd', 'solaris', 'cygwin'], 'values': ['freebsd', 'linux', 'macos', 'win32', 'android', 'openbsd', 'solaris', 'cygwin'],
'default': OS_GUESS, 'guess': GuessOS,
'help': 'the os to build for (%s)' % OS_GUESS 'help': 'the os to build for'
}, },
'arch': { 'arch': {
'values':['arm', 'ia32', 'x64', 'mips'], 'values':['arm', 'ia32', 'x64', 'mips'],
'default': ARCH_GUESS, 'guess': GuessArch,
'help': 'the architecture to build for (%s)' % ARCH_GUESS 'help': 'the architecture to build for'
}, },
'regexp': { 'regexp': {
'values': ['native', 'interpreted'], 'values': ['native', 'interpreted'],
@ -801,8 +823,15 @@ SIMPLE_OPTIONS = {
}, },
'visibility': { 'visibility': {
'values': ['default', 'hidden'], 'values': ['default', 'hidden'],
'default': VISIBILITY_GUESS, 'guess': GuessVisibility,
'help': 'shared library symbol visibility (%s)' % VISIBILITY_GUESS 'depends': ['os', 'toolchain'],
'help': 'shared library symbol visibility'
},
'strictaliasing': {
'values': ['default', 'off'],
'guess': GuessStrictAliasing,
'depends': ['toolchain'],
'help': 'assume strict aliasing while optimizing'
}, },
'pgo': { 'pgo': {
'values': ['off', 'instrument', 'optimize'], 'values': ['off', 'instrument', 'optimize'],
@ -812,6 +841,26 @@ SIMPLE_OPTIONS = {
} }
def AddOption(result, name, option):
if 'guess' in option:
# Option has a guess function
guess = option.get('guess')
guess_env = Environment(options=result)
# Check if all options that the guess function depends on are set
if 'depends' in option:
for dependency in option.get('depends'):
if not dependency in guess_env:
return False
default = guess(guess_env)
else:
# Option has a fixed default
default = option.get('default')
help = '%s (%s)' % (option.get('help'), ", ".join(option['values']))
result.Add(name, help, default)
return True
def GetOptions(): def GetOptions():
result = Options() result = Options()
result.Add('mode', 'compilation mode (debug, release)', 'release') result.Add('mode', 'compilation mode (debug, release)', 'release')
@ -819,12 +868,28 @@ def GetOptions():
result.Add('cache', 'directory to use for scons build cache', '') result.Add('cache', 'directory to use for scons build cache', '')
result.Add('env', 'override environment settings (NAME0:value0,NAME1:value1,...)', '') result.Add('env', 'override environment settings (NAME0:value0,NAME1:value1,...)', '')
result.Add('importenv', 'import environment settings (NAME0,NAME1,...)', '') result.Add('importenv', 'import environment settings (NAME0,NAME1,...)', '')
for (name, option) in SIMPLE_OPTIONS.iteritems(): options = SIMPLE_OPTIONS
help = '%s (%s)' % (name, ", ".join(option['values'])) while len(options):
result.Add(name, help, option.get('default')) postpone = {}
for (name, option) in options.iteritems():
if not AddOption(result, name, option):
postpone[name] = option
options = postpone
return result return result
def GetTools(opts):
env = Environment(options=opts)
os = env['os']
toolchain = env['toolchain']
if os == 'win32' and toolchain == 'gcc':
return ['mingw']
elif os == 'win32' and toolchain == 'msvc':
return ['msvc', 'mslink', 'mslib', 'msvs']
else:
return ['default']
def GetVersionComponents(): def GetVersionComponents():
MAJOR_VERSION_PATTERN = re.compile(r"#define\s+MAJOR_VERSION\s+(.*)") MAJOR_VERSION_PATTERN = re.compile(r"#define\s+MAJOR_VERSION\s+(.*)")
MINOR_VERSION_PATTERN = re.compile(r"#define\s+MINOR_VERSION\s+(.*)") MINOR_VERSION_PATTERN = re.compile(r"#define\s+MINOR_VERSION\s+(.*)")
@ -905,7 +970,7 @@ def VerifyOptions(env):
print env['simulator'] print env['simulator']
Abort("Option unalignedaccesses only supported for the ARM architecture.") Abort("Option unalignedaccesses only supported for the ARM architecture.")
for (name, option) in SIMPLE_OPTIONS.iteritems(): for (name, option) in SIMPLE_OPTIONS.iteritems():
if (not option.get('default')) and (name not in ARGUMENTS): if (not name in env):
message = ("A value for option %s must be specified (%s)." % message = ("A value for option %s must be specified (%s)." %
(name, ", ".join(option['values']))) (name, ", ".join(option['values'])))
Abort(message) Abort(message)
@ -1033,7 +1098,7 @@ def ParseEnvOverrides(arg, imports):
return overrides return overrides
def BuildSpecific(env, mode, env_overrides): def BuildSpecific(env, mode, env_overrides, tools):
options = {'mode': mode} options = {'mode': mode}
for option in SIMPLE_OPTIONS: for option in SIMPLE_OPTIONS:
options[option] = env[option] options[option] = env[option]
@ -1086,7 +1151,7 @@ def BuildSpecific(env, mode, env_overrides):
(object_files, shell_files, mksnapshot) = env.SConscript( (object_files, shell_files, mksnapshot) = env.SConscript(
join('src', 'SConscript'), join('src', 'SConscript'),
build_dir=join('obj', target_id), build_dir=join('obj', target_id),
exports='context', exports='context tools',
duplicate=False duplicate=False
) )
@ -1106,21 +1171,21 @@ def BuildSpecific(env, mode, env_overrides):
library = env.SharedLibrary(library_name, object_files, PDB=pdb_name) library = env.SharedLibrary(library_name, object_files, PDB=pdb_name)
context.library_targets.append(library) context.library_targets.append(library)
d8_env = Environment() d8_env = Environment(tools=tools)
d8_env.Replace(**context.flags['d8']) d8_env.Replace(**context.flags['d8'])
context.ApplyEnvOverrides(d8_env) context.ApplyEnvOverrides(d8_env)
shell = d8_env.Program('d8' + suffix, object_files + shell_files) shell = d8_env.Program('d8' + suffix, object_files + shell_files)
context.d8_targets.append(shell) context.d8_targets.append(shell)
for sample in context.samples: for sample in context.samples:
sample_env = Environment() sample_env = Environment(tools=tools)
sample_env.Replace(**context.flags['sample']) sample_env.Replace(**context.flags['sample'])
sample_env.Prepend(LIBS=[library_name]) sample_env.Prepend(LIBS=[library_name])
context.ApplyEnvOverrides(sample_env) context.ApplyEnvOverrides(sample_env)
sample_object = sample_env.SConscript( sample_object = sample_env.SConscript(
join('samples', 'SConscript'), join('samples', 'SConscript'),
build_dir=join('obj', 'sample', sample, target_id), build_dir=join('obj', 'sample', sample, target_id),
exports='sample context', exports='sample context tools',
duplicate=False duplicate=False
) )
sample_name = sample + suffix sample_name = sample + suffix
@ -1133,7 +1198,7 @@ def BuildSpecific(env, mode, env_overrides):
cctest_program = cctest_env.SConscript( cctest_program = cctest_env.SConscript(
join('test', 'cctest', 'SConscript'), join('test', 'cctest', 'SConscript'),
build_dir=join('obj', 'test', target_id), build_dir=join('obj', 'test', target_id),
exports='context object_files', exports='context object_files tools',
duplicate=False duplicate=False
) )
context.cctest_targets.append(cctest_program) context.cctest_targets.append(cctest_program)
@ -1143,7 +1208,9 @@ def BuildSpecific(env, mode, env_overrides):
def Build(): def Build():
opts = GetOptions() opts = GetOptions()
env = Environment(options=opts) tools = GetTools(opts)
env = Environment(options=opts, tools=tools)
Help(opts.GenerateHelpText(env)) Help(opts.GenerateHelpText(env))
VerifyOptions(env) VerifyOptions(env)
env_overrides = ParseEnvOverrides(env['env'], env['importenv']) env_overrides = ParseEnvOverrides(env['env'], env['importenv'])
@ -1157,7 +1224,7 @@ def Build():
d8s = [] d8s = []
modes = SplitList(env['mode']) modes = SplitList(env['mode'])
for mode in modes: for mode in modes:
context = BuildSpecific(env.Copy(), mode, env_overrides) context = BuildSpecific(env.Copy(), mode, env_overrides, tools)
libraries += context.library_targets libraries += context.library_targets
mksnapshots += context.mksnapshot_targets mksnapshots += context.mksnapshot_targets
cctests += context.cctest_targets cctests += context.cctest_targets

3
deps/v8/src/SConscript

@ -31,6 +31,7 @@ root_dir = dirname(File('SConstruct').rfile().abspath)
sys.path.append(join(root_dir, 'tools')) sys.path.append(join(root_dir, 'tools'))
import js2c import js2c
Import('context') Import('context')
Import('tools')
SOURCES = { SOURCES = {
@ -305,7 +306,7 @@ def Abort(message):
def ConfigureObjectFiles(): def ConfigureObjectFiles():
env = Environment() env = Environment(tools=tools)
env.Replace(**context.flags['v8']) env.Replace(**context.flags['v8'])
context.ApplyEnvOverrides(env) context.ApplyEnvOverrides(env)
env['BUILDERS']['JS2C'] = Builder(action=js2c.JS2C) env['BUILDERS']['JS2C'] = Builder(action=js2c.JS2C)

Loading…
Cancel
Save