Scons: Drop RUBY as compile time option.

This patch drops RUBY as a compile time option. Instead the PROTOCOL option
is used to figure out whether or not to build Ruby. If the specified protocol
is 'None', then Ruby is not compiled.
This commit is contained in:
Nilay Vaish 2011-08-02 00:10:08 -05:00
parent 206c2e9a0e
commit 1b49c56679
9 changed files with 11 additions and 32 deletions

View file

@ -810,7 +810,6 @@ sticky_vars.AddVariables(
BoolVariable('USE_FENV', 'Use <fenv.h> IEEE mode control', have_fenv), BoolVariable('USE_FENV', 'Use <fenv.h> IEEE mode control', have_fenv),
BoolVariable('USE_CHECKER', 'Use checker for detailed CPU models', False), BoolVariable('USE_CHECKER', 'Use checker for detailed CPU models', False),
BoolVariable('CP_ANNOTATE', 'Enable critical path annotation capability', False), BoolVariable('CP_ANNOTATE', 'Enable critical path annotation capability', False),
BoolVariable('RUBY', 'Build with Ruby', False),
) )
# These variables get exported to #defines in config/*.hh (see src/SConscript). # These variables get exported to #defines in config/*.hh (see src/SConscript).
@ -985,6 +984,11 @@ for variant_path in variant_paths:
if env['USE_SSE2']: if env['USE_SSE2']:
env.Append(CCFLAGS=['-msse2']) env.Append(CCFLAGS=['-msse2'])
if env['PROTOCOL'] != 'None':
env['RUBY'] = True
else:
env['RUBY'] = False
# The src/SConscript file sets up the build rules in 'env' according # The src/SConscript file sets up the build rules in 'env' according
# to the configured variables. It returns a list of environments, # to the configured variables. It returns a list of environments,
# one for each variant build (debug, opt, etc.) # one for each variant build (debug, opt, etc.)

View file

@ -2,4 +2,3 @@ FULL_SYSTEM = 0
SS_COMPATIBLE_FP = 1 SS_COMPATIBLE_FP = 1
CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU' CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU'
PROTOCOL = 'MESI_CMP_directory' PROTOCOL = 'MESI_CMP_directory'
RUBY = True

View file

@ -2,4 +2,3 @@ FULL_SYSTEM = 0
SS_COMPATIBLE_FP = 1 SS_COMPATIBLE_FP = 1
CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU' CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU'
PROTOCOL = 'MOESI_CMP_directory' PROTOCOL = 'MOESI_CMP_directory'
RUBY = True

View file

@ -2,4 +2,3 @@ FULL_SYSTEM = 0
SS_COMPATIBLE_FP = 1 SS_COMPATIBLE_FP = 1
CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU' CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU'
PROTOCOL = 'MOESI_CMP_token' PROTOCOL = 'MOESI_CMP_token'
RUBY = True

View file

@ -2,4 +2,3 @@ FULL_SYSTEM = 0
SS_COMPATIBLE_FP = 1 SS_COMPATIBLE_FP = 1
CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU' CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU'
PROTOCOL = 'MOESI_hammer' PROTOCOL = 'MOESI_hammer'
RUBY = True

View file

@ -2,4 +2,3 @@ FULL_SYSTEM = 0
SS_COMPATIBLE_FP = 1 SS_COMPATIBLE_FP = 1
CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU' CPU_MODELS = 'AtomicSimpleCPU,TimingSimpleCPU,O3CPU,InOrderCPU'
PROTOCOL = 'Network_test' PROTOCOL = 'Network_test'
RUBY = True

View file

@ -71,11 +71,10 @@ parser.add_option("-i", "--input", default="", help="Read stdin from a file.")
parser.add_option("--output", default="", help="Redirect stdout to a file.") parser.add_option("--output", default="", help="Redirect stdout to a file.")
parser.add_option("--errout", default="", help="Redirect stderr to a file.") parser.add_option("--errout", default="", help="Redirect stderr to a file.")
if 'PROTOCOL' in buildEnv:
parser.add_option("--ruby", action="store_true")
execfile(os.path.join(config_root, "common", "Options.py")) execfile(os.path.join(config_root, "common", "Options.py"))
if buildEnv['PROTOCOL'] != 'None':
parser.add_option("--ruby", action="store_true")
if '--ruby' in sys.argv: if '--ruby' in sys.argv:
Ruby.define_options(parser) Ruby.define_options(parser)

View file

@ -34,24 +34,15 @@ Import('*')
all_protocols = [ all_protocols = [
'MESI_CMP_directory', 'MESI_CMP_directory',
'MESI_SCMP_bankdirectory',
'MESI_SCMP_bankdirectory_m',
'MI_example', 'MI_example',
'MOESI_CMP_directory', 'MOESI_CMP_directory',
'MOESI_CMP_directory_m',
'MOESI_CMP_token', 'MOESI_CMP_token',
'MOESI_SMP_directory',
'MOESI_SMP_token',
'MOSI_SMP_bcast',
'MOSI_SMP_bcast_1level',
'MOSI_SMP_bcast_m',
'MOSI_SMP_directory_1level',
'MSI_MOSI_CMP_directory',
'MOESI_hammer', 'MOESI_hammer',
'Network_test', 'Network_test',
'None'
] ]
opt = EnumVariable('PROTOCOL', 'Coherence protocol for Ruby', 'MI_example', opt = EnumVariable('PROTOCOL', 'Coherence protocol for Ruby', 'None',
all_protocols) all_protocols)
sticky_vars.AddVariables(opt) sticky_vars.AddVariables(opt)

View file

@ -289,16 +289,6 @@ else:
'inorder-timing', 'rubytest'] 'inorder-timing', 'rubytest']
if env['RUBY']: if env['RUBY']:
# With Ruby, A protocol must be specified in the environment
assert(env['PROTOCOL'])
#
# Is there a way to determine what is Protocol EnumVariable
# default and eliminate the need to hard code the default protocol below?
#
# If the binary includes the default ruby protocol, run both ruby and
# non-ruby versions of the tests. Otherwise just run the ruby versions.
#
if env['PROTOCOL'] == 'MI_example': if env['PROTOCOL'] == 'MI_example':
configs += [c + "-ruby" for c in configs] configs += [c + "-ruby" for c in configs]
else: else: