blob: 63f5adab3c32c4b26af8498e6bd68f062e426e84 [file] [log] [blame]
Tom Stellard55d37462014-02-12 14:54:17 +00001#!/usr/bin/python
Peter Collingbourned5395fb2012-01-08 22:09:58 +00002
3def c_compiler_rule(b, name, description, compiler, flags):
4 command = "%s -MMD -MF $out.d %s -c -o $out $in" % (compiler, flags)
5 b.rule(name, command, description + " $out", depfile="$out.d")
6
Tom Stellard1de77612013-06-26 18:20:03 +00007version_major = 0;
Jeroen Ketemad9157392015-08-07 08:31:37 +00008version_minor = 2;
Tom Stellard1d770712014-12-31 15:27:53 +00009version_patch = 0;
Tom Stellard1de77612013-06-26 18:20:03 +000010
Peter Collingbourned5395fb2012-01-08 22:09:58 +000011from optparse import OptionParser
12import os
Aaron Watryb38037f2013-12-29 16:39:53 +000013import string
Peter Collingbourned5395fb2012-01-08 22:09:58 +000014from subprocess import *
15import sys
16
17srcdir = os.path.dirname(sys.argv[0])
18
19sys.path.insert(0, os.path.join(srcdir, 'build'))
20import metabuild
21
22p = OptionParser()
23p.add_option('--with-llvm-config', metavar='PATH',
24 help='use given llvm-config script')
Tom Stellard9f48bb32013-10-23 02:49:27 +000025p.add_option('--with-cxx-compiler', metavar='PATH',
26 help='use given C++ compiler')
Peter Collingbournebae68332012-06-01 17:29:59 +000027p.add_option('--prefix', metavar='PATH',
28 help='install to given prefix')
Tom Stellard1de77612013-06-26 18:20:03 +000029p.add_option('--libexecdir', metavar='PATH',
30 help='install *.bc to given dir')
31p.add_option('--includedir', metavar='PATH',
32 help='install include files to given dir')
33p.add_option('--pkgconfigdir', metavar='PATH',
34 help='install clc.pc to given dir')
Peter Collingbourned5395fb2012-01-08 22:09:58 +000035p.add_option('-g', metavar='GENERATOR', default='make',
36 help='use given generator (default: make)')
Tom Stellardd9ca1f12015-04-20 18:49:50 +000037p.add_option('--enable-runtime-subnormal', action="store_true", default=False,
38 help='Allow runtimes to choose subnormal support')
Peter Collingbourned5395fb2012-01-08 22:09:58 +000039(options, args) = p.parse_args()
40
41llvm_config_exe = options.with_llvm_config or "llvm-config"
42
Tom Stellard1de77612013-06-26 18:20:03 +000043prefix = options.prefix
44if not prefix:
45 prefix = '/usr/local'
46
47libexecdir = options.libexecdir
48if not libexecdir:
49 libexecdir = os.path.join(prefix, 'lib/clc')
50
51includedir = options.includedir
52if not includedir:
53 includedir = os.path.join(prefix, 'include')
54
55pkgconfigdir = options.pkgconfigdir
56if not pkgconfigdir:
Tom Stellard93d674f2013-09-05 23:27:58 +000057 pkgconfigdir = os.path.join(prefix, 'share/pkgconfig')
Tom Stellard1de77612013-06-26 18:20:03 +000058
Peter Collingbourned5395fb2012-01-08 22:09:58 +000059def llvm_config(args):
60 try:
61 proc = Popen([llvm_config_exe] + args, stdout=PIPE)
62 return proc.communicate()[0].rstrip().replace('\n', ' ')
63 except OSError:
64 print "Error executing llvm-config."
65 print "Please ensure that llvm-config is in your $PATH, or use --with-llvm-config."
66 sys.exit(1)
67
Aaron Watryb38037f2013-12-29 16:39:53 +000068llvm_version = string.split(string.replace(llvm_config(['--version']), 'svn', ''), '.')
Jeroen Ketemad9157392015-08-07 08:31:37 +000069llvm_int_version = int(llvm_version[0]) * 100 + int(llvm_version[1]) * 10
Tom Stellardba742f52015-04-29 15:37:06 +000070llvm_string_version = 'LLVM' + llvm_version[0] + '.' + llvm_version[1]
71
Matt Arsenaulta48e15c2016-02-13 01:01:59 +000072if llvm_int_version < 390:
73 print "libclc requires LLVM >= 3.9"
Jeroen Ketemad9157392015-08-07 08:31:37 +000074 sys.exit(1)
75
Tom Stellard1d770712014-12-31 15:27:53 +000076llvm_system_libs = llvm_config(['--system-libs'])
Peter Collingbourned5395fb2012-01-08 22:09:58 +000077llvm_bindir = llvm_config(['--bindir'])
Peter Collingbournedb47eac2012-12-05 07:39:02 +000078llvm_core_libs = llvm_config(['--libs', 'core', 'bitreader', 'bitwriter']) + ' ' + \
Aaron Watryb38037f2013-12-29 16:39:53 +000079 llvm_system_libs + ' ' + \
Peter Collingbournedb47eac2012-12-05 07:39:02 +000080 llvm_config(['--ldflags'])
Peter Collingbourned5395fb2012-01-08 22:09:58 +000081llvm_cxxflags = llvm_config(['--cxxflags']) + ' -fno-exceptions -fno-rtti'
Jan Vesely62496142014-09-02 17:54:59 +000082llvm_libdir = llvm_config(['--libdir'])
Peter Collingbourned5395fb2012-01-08 22:09:58 +000083
84llvm_clang = os.path.join(llvm_bindir, 'clang')
85llvm_link = os.path.join(llvm_bindir, 'llvm-link')
86llvm_opt = os.path.join(llvm_bindir, 'opt')
87
Tom Stellard9f48bb32013-10-23 02:49:27 +000088cxx_compiler = options.with_cxx_compiler
89if not cxx_compiler:
90 cxx_compiler = os.path.join(llvm_bindir, 'clang++')
91
Tom Stellard30f554b2013-06-26 18:20:38 +000092available_targets = {
93 'r600--' : { 'devices' :
Jan Vesely4f381422016-02-09 22:17:45 +000094 [{'gpu' : 'cedar', 'aliases' : ['palm', 'sumo', 'sumo2', 'redwood', 'juniper'],
Jan Vesely46b7dd92016-02-09 22:17:46 +000095 'defines' : {}},
Jan Vesely4f381422016-02-09 22:17:45 +000096 {'gpu' : 'cypress', 'aliases' : ['hemlock'],
Jan Vesely6d870d22016-02-09 22:17:48 +000097 'defines' : {}},
Jan Vesely4f381422016-02-09 22:17:45 +000098 {'gpu' : 'barts', 'aliases' : ['turks', 'caicos'],
Jan Vesely46b7dd92016-02-09 22:17:46 +000099 'defines' : {}},
Jan Vesely4f381422016-02-09 22:17:45 +0000100 {'gpu' : 'cayman', 'aliases' : ['aruba'],
Jan Vesely6d870d22016-02-09 22:17:48 +0000101 'defines' : {}} ]},
Tom Stellard0f397212015-01-06 20:42:12 +0000102 'amdgcn--': { 'devices' :
Jan Vesely4f381422016-02-09 22:17:45 +0000103 [{'gpu' : 'tahiti', 'aliases' : ['pitcairn', 'verde', 'oland', 'hainan', 'bonaire', 'kabini', 'kaveri', 'hawaii','mullins','tonga','carrizo','iceland','fiji','stoney'],
Jan Vesely6d870d22016-02-09 22:17:48 +0000104 'defines' : {}} ]},
Konstantin Zhuravlyovf8a81f82016-04-07 19:54:19 +0000105 'amdgcn--amdhsa': { 'devices' :
106 [{'gpu' : '', 'aliases' : ['bonaire', 'hawaii', 'kabini', 'kaveri', 'mullins', 'carrizo', 'stoney', 'fiji', 'iceland', 'tonga'],
107 'defines' : {}} ]},
Jan Vesely4f381422016-02-09 22:17:45 +0000108 'nvptx--' : { 'devices' : [{'gpu' : '', 'aliases' : [],
109 'defines' : {'all' : ['cl_khr_fp64']}}]},
110 'nvptx64--' : { 'devices' : [{'gpu' : '', 'aliases' : [],
111 'defines' : {'all' : ['cl_khr_fp64']}}]},
112 'nvptx--nvidiacl' : { 'devices' : [{'gpu' : '', 'aliases' : [],
113 'defines' : {'all' : ['cl_khr_fp64']}}]},
114 'nvptx64--nvidiacl' : { 'devices' : [{'gpu' : '', 'aliases' : [],
115 'defines' : {'all' : ['cl_khr_fp64']}}]},
Tom Stellard30f554b2013-06-26 18:20:38 +0000116}
117
Konstantin Zhuravlyovf8a81f82016-04-07 19:54:19 +0000118default_targets = ['nvptx--nvidiacl', 'nvptx64--nvidiacl', 'r600--', 'amdgcn--', 'amdgcn--amdhsa']
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000119
120targets = args
121if not targets:
122 targets = default_targets
123
124b = metabuild.from_name(options.g)
125
126b.rule("LLVM_AS", "%s -o $out $in" % os.path.join(llvm_bindir, "llvm-as"),
127 'LLVM-AS $out')
128b.rule("LLVM_LINK", command = llvm_link + " -o $out $in",
129 description = 'LLVM-LINK $out')
130b.rule("OPT", command = llvm_opt + " -O3 -o $out $in",
131 description = 'OPT $out')
132
Tom Stellard9f48bb32013-10-23 02:49:27 +0000133c_compiler_rule(b, "LLVM_TOOL_CXX", 'CXX', cxx_compiler, llvm_cxxflags)
Jan Vesely62496142014-09-02 17:54:59 +0000134b.rule("LLVM_TOOL_LINK", cxx_compiler + " -o $out $in %s" % llvm_core_libs + " -Wl,-rpath %s" % llvm_libdir, 'LINK $out')
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000135
136prepare_builtins = os.path.join('utils', 'prepare-builtins')
137b.build(os.path.join('utils', 'prepare-builtins.o'), "LLVM_TOOL_CXX",
138 os.path.join(srcdir, 'utils', 'prepare-builtins.cpp'))
139b.build(prepare_builtins, "LLVM_TOOL_LINK",
140 os.path.join('utils', 'prepare-builtins.o'))
141
142b.rule("PREPARE_BUILTINS", "%s -o $out $in" % prepare_builtins,
143 'PREPARE-BUILTINS $out')
Tom Stellardf21e3ea2013-10-10 19:09:01 +0000144b.rule("PYTHON_GEN", "python < $in > $out", "PYTHON_GEN $out")
145b.build('generic/lib/convert.cl', "PYTHON_GEN", ['generic/lib/gen_convert.py'])
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000146
147manifest_deps = set([sys.argv[0], os.path.join(srcdir, 'build', 'metabuild.py'),
148 os.path.join(srcdir, 'build', 'ninja_syntax.py')])
149
Tom Stellard1de77612013-06-26 18:20:03 +0000150install_files_bc = []
Peter Collingbournebae68332012-06-01 17:29:59 +0000151install_deps = []
152
Tom Stellardd9ca1f12015-04-20 18:49:50 +0000153# Create rules for subnormal helper objects
154for src in ['subnormal_disable.ll', 'subnormal_use_default.ll']:
155 obj_name = src[:-2] + 'bc'
156 obj = os.path.join('generic--', 'lib', obj_name)
157 src_file = os.path.join('generic', 'lib', src)
158 b.build(obj, 'LLVM_AS', src_file)
159 b.default(obj)
160 install_files_bc.append((obj, obj))
161 install_deps.append(obj)
162
Tom Stellard1de77612013-06-26 18:20:03 +0000163# Create libclc.pc
164clc = open('libclc.pc', 'w')
165clc.write('includedir=%(inc)s\nlibexecdir=%(lib)s\n\nName: libclc\nDescription: Library requirements of the OpenCL C programming language\nVersion: %(maj)s.%(min)s.%(pat)s\nCflags: -I${includedir}\nLibs: -L${libexecdir}' %
166{'inc': includedir, 'lib': libexecdir, 'maj': version_major, 'min': version_minor, 'pat': version_patch})
167clc.close()
168
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000169for target in targets:
170 (t_arch, t_vendor, t_os) = target.split('-')
171 archs = [t_arch]
Peter Collingbournea3fc6452012-05-28 20:42:15 +0000172 if t_arch == 'nvptx' or t_arch == 'nvptx64':
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000173 archs.append('ptx')
174 archs.append('generic')
175
176 subdirs = []
177 for arch in archs:
178 subdirs.append("%s-%s-%s" % (arch, t_vendor, t_os))
179 subdirs.append("%s-%s" % (arch, t_os))
180 subdirs.append(arch)
Matt Arsenaulta48e15c2016-02-13 01:01:59 +0000181 if arch == 'amdgcn' or arch == 'r600':
182 subdirs.append('amdgpu')
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000183
Peter Collingbournebae68332012-06-01 17:29:59 +0000184 incdirs = filter(os.path.isdir,
185 [os.path.join(srcdir, subdir, 'include') for subdir in subdirs])
186 libdirs = filter(lambda d: os.path.isfile(os.path.join(d, 'SOURCES')),
187 [os.path.join(srcdir, subdir, 'lib') for subdir in subdirs])
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000188
Peter Collingbournebae68332012-06-01 17:29:59 +0000189 clang_cl_includes = ' '.join(["-I%s" % incdir for incdir in incdirs])
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000190
Tom Stellard30f554b2013-06-26 18:20:38 +0000191 for device in available_targets[target]['devices']:
192 # The rule for building a .bc file for the specified architecture using clang.
Jan Vesely4f381422016-02-09 22:17:45 +0000193 device_def_list = (device['defines']['all'] if 'all' in device['defines'] else []);
194 if llvm_string_version in device['defines']:
195 device_def_list += (device['defines'][llvm_string_version]);
196 device_defines = ' '.join(["-D%s" % define for define in device_def_list])
Tom Stellard30f554b2013-06-26 18:20:38 +0000197 clang_bc_flags = "-target %s -I`dirname $in` %s " \
Aaron Watry8ef48d02013-12-29 16:39:55 +0000198 "-fno-builtin " \
Tom Stellard30f554b2013-06-26 18:20:38 +0000199 "-Dcl_clang_storage_class_specifiers " \
Jan Vesely4f381422016-02-09 22:17:45 +0000200 "%s " \
Tom Stellardf21e3ea2013-10-10 19:09:01 +0000201 "-Dcles_khr_int64 " \
Tom Stellard6c7b86c2013-10-10 19:08:51 +0000202 "-D__CLC_INTERNAL " \
Jan Vesely4f381422016-02-09 22:17:45 +0000203 "-emit-llvm" % (target, clang_cl_includes, device_defines)
Tom Stellard30f554b2013-06-26 18:20:38 +0000204 if device['gpu'] != '':
205 clang_bc_flags += ' -mcpu=' + device['gpu']
Tom Stellard8a3770a2014-01-29 20:03:27 +0000206 clang_bc_rule = "CLANG_CL_BC_" + target + "_" + device['gpu']
Tom Stellard30f554b2013-06-26 18:20:38 +0000207 c_compiler_rule(b, clang_bc_rule, "LLVM-CC", llvm_clang, clang_bc_flags)
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000208
Tom Stellard30f554b2013-06-26 18:20:38 +0000209 objects = []
210 sources_seen = set()
Tom Stellardba742f52015-04-29 15:37:06 +0000211 compats_seen = set()
Tom Stellardd54f6ba2013-06-26 18:20:05 +0000212
Tom Stellard30f554b2013-06-26 18:20:38 +0000213 if device['gpu'] == '':
214 full_target_name = target
215 obj_suffix = ''
216 else:
217 full_target_name = device['gpu'] + '-' + target
218 obj_suffix = '.' + device['gpu']
Tom Stellardd54f6ba2013-06-26 18:20:05 +0000219
Tom Stellard30f554b2013-06-26 18:20:38 +0000220 for libdir in libdirs:
221 subdir_list_file = os.path.join(libdir, 'SOURCES')
222 manifest_deps.add(subdir_list_file)
223 override_list_file = os.path.join(libdir, 'OVERRIDES')
Tom Stellardba742f52015-04-29 15:37:06 +0000224 compat_list_file = os.path.join(libdir,
225 'SOURCES_' + llvm_string_version)
226
227 # Build compat list
228 if os.path.exists(compat_list_file):
229 for compat in open(compat_list_file).readlines():
230 compat = compat.rstrip()
231 compats_seen.add(compat)
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000232
Tom Stellard30f554b2013-06-26 18:20:38 +0000233 # Add target overrides
234 if os.path.exists(override_list_file):
235 for override in open(override_list_file).readlines():
236 override = override.rstrip()
237 sources_seen.add(override)
238
239 for src in open(subdir_list_file).readlines():
240 src = src.rstrip()
241 if src not in sources_seen:
242 sources_seen.add(src)
243 obj = os.path.join(target, 'lib', src + obj_suffix + '.bc')
244 objects.append(obj)
Tom Stellardba742f52015-04-29 15:37:06 +0000245 src_path = libdir
246 if src in compats_seen:
247 src_path = os.path.join(libdir, llvm_string_version)
248 src_file = os.path.join(src_path, src)
Tom Stellard30f554b2013-06-26 18:20:38 +0000249 ext = os.path.splitext(src)[1]
250 if ext == '.ll':
251 b.build(obj, 'LLVM_AS', src_file)
252 else:
253 b.build(obj, clang_bc_rule, src_file)
254
Tom Stellardd9ca1f12015-04-20 18:49:50 +0000255 obj = os.path.join('generic--', 'lib', 'subnormal_use_default.bc')
256 if not options.enable_runtime_subnormal:
257 objects.append(obj)
258
Tom Stellard30f554b2013-06-26 18:20:38 +0000259 builtins_link_bc = os.path.join(target, 'lib', 'builtins.link' + obj_suffix + '.bc')
260 builtins_opt_bc = os.path.join(target, 'lib', 'builtins.opt' + obj_suffix + '.bc')
261 builtins_bc = os.path.join('built_libs', full_target_name + '.bc')
262 b.build(builtins_link_bc, "LLVM_LINK", objects)
263 b.build(builtins_opt_bc, "OPT", builtins_link_bc)
264 b.build(builtins_bc, "PREPARE_BUILTINS", builtins_opt_bc, prepare_builtins)
265 install_files_bc.append((builtins_bc, builtins_bc))
266 install_deps.append(builtins_bc)
267 for alias in device['aliases']:
Tom Stellard8a3770a2014-01-29 20:03:27 +0000268 # Ninja cannot have multiple rules with same name so append suffix
269 ruleName = "CREATE_ALIAS_{0}_for_{1}".format(alias, device['gpu'])
270 b.rule(ruleName, "ln -fs %s $out" % os.path.basename(builtins_bc)
Tom Stellard30f554b2013-06-26 18:20:38 +0000271 ,"CREATE-ALIAS $out")
272
273 alias_file = os.path.join('built_libs', alias + '-' + target + '.bc')
Tom Stellard8a3770a2014-01-29 20:03:27 +0000274 b.build(alias_file, ruleName, builtins_bc)
Tom Stellard30f554b2013-06-26 18:20:38 +0000275 install_files_bc.append((alias_file, alias_file))
276 install_deps.append(alias_file)
277 b.default(builtins_bc)
Peter Collingbournebae68332012-06-01 17:29:59 +0000278
Tom Stellard1de77612013-06-26 18:20:03 +0000279
Tom Stellard91d51db2014-01-29 20:03:26 +0000280install_cmd = ' && '.join(['mkdir -p ${DESTDIR}/%(dst)s && cp -r %(src)s ${DESTDIR}/%(dst)s' %
Tom Stellard1de77612013-06-26 18:20:03 +0000281 {'src': file,
282 'dst': libexecdir}
283 for (file, dest) in install_files_bc])
Tom Stellard91d51db2014-01-29 20:03:26 +0000284install_cmd = ' && '.join(['%(old)s && mkdir -p ${DESTDIR}/%(dst)s && cp -r %(srcdir)s/generic/include/clc ${DESTDIR}/%(dst)s' %
Tom Stellard1de77612013-06-26 18:20:03 +0000285 {'old': install_cmd,
Tom Stellard5668ea22013-06-26 18:20:35 +0000286 'dst': includedir,
287 'srcdir': srcdir}])
Tom Stellard91d51db2014-01-29 20:03:26 +0000288install_cmd = ' && '.join(['%(old)s && mkdir -p ${DESTDIR}/%(dst)s && cp -r libclc.pc ${DESTDIR}/%(dst)s' %
Tom Stellard1de77612013-06-26 18:20:03 +0000289 {'old': install_cmd,
290 'dst': pkgconfigdir}])
291
292b.rule('install', command = install_cmd, description = 'INSTALL')
293b.build('install', 'install', install_deps)
Peter Collingbourned5395fb2012-01-08 22:09:58 +0000294
295b.rule("configure", command = ' '.join(sys.argv), description = 'CONFIGURE',
296 generator = True)
297b.build(b.output_filename(), 'configure', list(manifest_deps))
298
299b.finish()