Skip to content

Commit f07da5a

Browse files
committed
scons: Recognize LLVM_CONFIG environment variable.
Signed-off-by: Vinson Lee <[email protected]> Reviewed-by: Emil Velikov <[email protected]> Reviewed-by: Jose Fonseca <[email protected]>
1 parent a794f09 commit f07da5a

File tree

3 files changed

+12
-10
lines changed

3 files changed

+12
-10
lines changed

common.py

+1-1
Original file line numberDiff line numberDiff line change
@@ -59,7 +59,7 @@
5959

6060

6161
# find default_llvm value
62-
if 'LLVM' in os.environ:
62+
if 'LLVM' in os.environ or 'LLVM_CONFIG' in os.environ:
6363
default_llvm = 'yes'
6464
else:
6565
default_llvm = 'no'

scons/llvm.py

+9-8
Original file line numberDiff line numberDiff line change
@@ -194,11 +194,12 @@ def generate(env):
194194
# that.
195195
env.Append(LINKFLAGS = ['/nodefaultlib:LIBCMT'])
196196
else:
197-
if not env.Detect('llvm-config'):
198-
print 'scons: llvm-config script not found'
197+
llvm_config = os.environ.get('LLVM_CONFIG', 'llvm-config')
198+
if not env.Detect(llvm_config):
199+
print 'scons: %s script not found' % llvm_config
199200
return
200201

201-
llvm_version = env.backtick('llvm-config --version').rstrip()
202+
llvm_version = env.backtick('%s --version' % llvm_config).rstrip()
202203
llvm_version = distutils.version.LooseVersion(llvm_version)
203204

204205
if llvm_version < distutils.version.LooseVersion(required_llvm_version):
@@ -208,24 +209,24 @@ def generate(env):
208209
try:
209210
# Treat --cppflags specially to prevent NDEBUG from disabling
210211
# assertion failures in debug builds.
211-
cppflags = env.ParseFlags('!llvm-config --cppflags')
212+
cppflags = env.ParseFlags('!%s --cppflags' % llvm_config)
212213
try:
213214
cppflags['CPPDEFINES'].remove('NDEBUG')
214215
except ValueError:
215216
pass
216217
env.MergeFlags(cppflags)
217218

218219
# Match llvm --fno-rtti flag
219-
cxxflags = env.backtick('llvm-config --cxxflags').split()
220+
cxxflags = env.backtick('%s --cxxflags' % llvm_config).split()
220221
if '-fno-rtti' in cxxflags:
221222
env.Append(CXXFLAGS = ['-fno-rtti'])
222223

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

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

src/gallium/drivers/swr/SConscript

+2-1
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,8 @@ if env['platform'] == 'windows':
3131
# on windows there is no llvm-config, so LLVM is defined
3232
llvm_includedir = os.path.join(os.environ['LLVM'], 'include')
3333
else:
34-
llvm_includedir = env.backtick('llvm-config --includedir').rstrip()
34+
llvm_config = os.environ.get('LLVM_CONFIG', 'llvm-config')
35+
llvm_includedir = env.backtick('%s --includedir' % llvm_config).rstrip()
3536
print "llvm include dir %s" % llvm_includedir
3637

3738
# the loader is included in the mesa lib itself

0 commit comments

Comments
 (0)