Browse Source

scons: Recognize LLVM_CONFIG environment variable.

Signed-off-by: Vinson Lee <vlee@freedesktop.org>
Reviewed-by: Emil Velikov <emil.velikov@collabora.com>
Reviewed-by: Jose Fonseca <jfonseca@vmware.com>
tags/17.0-branchpoint
Vinson Lee 8 years ago
parent
commit
f07da5aa5e
3 changed files with 12 additions and 10 deletions
  1. 1
    1
      common.py
  2. 9
    8
      scons/llvm.py
  3. 2
    1
      src/gallium/drivers/swr/SConscript

+ 1
- 1
common.py View File





# find default_llvm value # find default_llvm value
if 'LLVM' in os.environ:
if 'LLVM' in os.environ or 'LLVM_CONFIG' in os.environ:
default_llvm = 'yes' default_llvm = 'yes'
else: else:
default_llvm = 'no' default_llvm = 'no'

+ 9
- 8
scons/llvm.py View File

# that. # that.
env.Append(LINKFLAGS = ['/nodefaultlib:LIBCMT']) env.Append(LINKFLAGS = ['/nodefaultlib:LIBCMT'])
else: else:
if not env.Detect('llvm-config'):
print 'scons: llvm-config script not found'
llvm_config = os.environ.get('LLVM_CONFIG', 'llvm-config')
if not env.Detect(llvm_config):
print 'scons: %s script not found' % llvm_config
return return


llvm_version = env.backtick('llvm-config --version').rstrip()
llvm_version = env.backtick('%s --version' % llvm_config).rstrip()
llvm_version = distutils.version.LooseVersion(llvm_version) llvm_version = distutils.version.LooseVersion(llvm_version)


if llvm_version < distutils.version.LooseVersion(required_llvm_version): if llvm_version < distutils.version.LooseVersion(required_llvm_version):
try: try:
# Treat --cppflags specially to prevent NDEBUG from disabling # Treat --cppflags specially to prevent NDEBUG from disabling
# assertion failures in debug builds. # assertion failures in debug builds.
cppflags = env.ParseFlags('!llvm-config --cppflags')
cppflags = env.ParseFlags('!%s --cppflags' % llvm_config)
try: try:
cppflags['CPPDEFINES'].remove('NDEBUG') cppflags['CPPDEFINES'].remove('NDEBUG')
except ValueError: except ValueError:
env.MergeFlags(cppflags) env.MergeFlags(cppflags)


# Match llvm --fno-rtti flag # Match llvm --fno-rtti flag
cxxflags = env.backtick('llvm-config --cxxflags').split()
cxxflags = env.backtick('%s --cxxflags' % llvm_config).split()
if '-fno-rtti' in cxxflags: if '-fno-rtti' in cxxflags:
env.Append(CXXFLAGS = ['-fno-rtti']) env.Append(CXXFLAGS = ['-fno-rtti'])


components = ['engine', 'mcjit', 'bitwriter', 'x86asmprinter', 'mcdisassembler', 'irreader'] components = ['engine', 'mcjit', 'bitwriter', 'x86asmprinter', 'mcdisassembler', 'irreader']


env.ParseConfig('llvm-config --libs ' + ' '.join(components))
env.ParseConfig('llvm-config --ldflags')
env.ParseConfig('%s --libs ' % llvm_config + ' '.join(components))
env.ParseConfig('%s --ldflags' % llvm_config)
if llvm_version >= distutils.version.LooseVersion('3.5'): if llvm_version >= distutils.version.LooseVersion('3.5'):
env.ParseConfig('llvm-config --system-libs')
env.ParseConfig('%s --system-libs' % llvm_config)
env.Append(CXXFLAGS = ['-std=c++11']) env.Append(CXXFLAGS = ['-std=c++11'])
except OSError: except OSError:
print 'scons: llvm-config version %s failed' % llvm_version print 'scons: llvm-config version %s failed' % llvm_version

+ 2
- 1
src/gallium/drivers/swr/SConscript View File

# on windows there is no llvm-config, so LLVM is defined # on windows there is no llvm-config, so LLVM is defined
llvm_includedir = os.path.join(os.environ['LLVM'], 'include') llvm_includedir = os.path.join(os.environ['LLVM'], 'include')
else: else:
llvm_includedir = env.backtick('llvm-config --includedir').rstrip()
llvm_config = os.environ.get('LLVM_CONFIG', 'llvm-config')
llvm_includedir = env.backtick('%s --includedir' % llvm_config).rstrip()
print "llvm include dir %s" % llvm_includedir print "llvm include dir %s" % llvm_includedir


# the loader is included in the mesa lib itself # the loader is included in the mesa lib itself

Loading…
Cancel
Save