1 |
commit: 50ef192da3d4805fc2d3244e9b0511eb640e05f2 |
2 |
Author: Michał Górny <mgorny <AT> gentoo <DOT> org> |
3 |
AuthorDate: Mon Jan 30 16:26:37 2023 +0000 |
4 |
Commit: Michał Górny <mgorny <AT> gentoo <DOT> org> |
5 |
CommitDate: Mon Jan 30 20:32:51 2023 +0000 |
6 |
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=50ef192d |
7 |
|
8 |
sys-devel/llvm: Add 16.0.0_rc1 |
9 |
|
10 |
Signed-off-by: Michał Górny <mgorny <AT> gentoo.org> |
11 |
|
12 |
sys-devel/llvm/Manifest | 2 + |
13 |
sys-devel/llvm/llvm-16.0.0_rc1.ebuild | 514 ++++++++++++++++++++++++++++++++++ |
14 |
2 files changed, 516 insertions(+) |
15 |
|
16 |
diff --git a/sys-devel/llvm/Manifest b/sys-devel/llvm/Manifest |
17 |
index d36dfbea9dcc..56210b031d68 100644 |
18 |
--- a/sys-devel/llvm/Manifest |
19 |
+++ b/sys-devel/llvm/Manifest |
20 |
@@ -8,6 +8,8 @@ DIST llvm-project-14.0.6.src.tar.xz 105618228 BLAKE2B ee67c5407df8cef493b9c0004f |
21 |
DIST llvm-project-14.0.6.src.tar.xz.sig 566 BLAKE2B cb658ad43d8ab6c43a5773aedadf0569c97b5ee4b1bd58eceb10e1879a30880c741c3d66bedd462c892309b688fb7b2673115a62d1f74d71ee375a578de9547f SHA512 b4a7b368532a7a4a24376cfa7db8f6d3478f6d4446474342fc00b474ecf466330cd0f16783209263c4c72d5fc7ddedfb11b95578842e700cfb7ee0bb34cc95d6 |
22 |
DIST llvm-project-15.0.7.src.tar.xz 110936452 BLAKE2B f3d277e2029157329e5be78b78af36b0826a1dfd9a337992499bf701e33149665bfc47d5e14978e38f342559629a559f8b2ce328705ba34fdf6830f5ae9721a5 SHA512 4836d3603f32e8e54434cbfa8ef33d9d473ac5dc20ebf9c67132653c73f4524931abd1084655eaee5f20bcfcb91bcc4bbc5c4a0b603ad0c9029c556e14dc4c52 |
23 |
DIST llvm-project-15.0.7.src.tar.xz.sig 566 BLAKE2B 47dc8c82d86237b80c6d85f83a6c9a6e9e174cf8e7f367b071e0cd9481d7cd408e991337c5624e07f3f370f26387c814f212808575ed1c1b58404d3e3836b7df SHA512 fc6891b440dd1175eb8df3790590af8d36bc92301660f84744ae15123475aeb900a151e6a8e7998ded27ec4d86871903ad0b89cd61164943054c2e3bc8d8beb2 |
24 |
+DIST llvm-project-16.0.0rc1.src.tar.xz 118364920 BLAKE2B 449fa321722e77d1a595d0f1f52a4e9492954d928355402f6e07e6c8a20e4ebfc03690ef8272b92eb5cdd58c97ca37fa6baf847d399e36a84e3ea7d94d1ea6ca SHA512 a24074ea8e21af49b0545f02bdec4727e8df841e59340dc189cc5a144a70fc6880e82381fba622ac62c7504f7bf394c916c773ee25904e8faf41eaedce6ae9e0 |
25 |
+DIST llvm-project-16.0.0rc1.src.tar.xz.sig 566 BLAKE2B 29a593f74b05ef6268f0b2ee5ebd810a244e7c6b27dd94f709b22bca8e6c8367f8321a6ec61f85476cd399f31519ac2a3c978014afae29490c1e70d26eb6c35f SHA512 dcca03d41ee3cc7d5b150184b03eb9f2e579603ce9cd5289360d1ca47169174afc26a85079cf096ec91e23f487f0b38bb6cd5fb7e5197530582155b16a5ce748 |
26 |
DIST llvm-project-46d5a57801bc37e5ebb1a4d6b2acc0fa99c01e8d.tar.gz 180436731 BLAKE2B 51c30c3f11dd55a225b8ebe4ded752ce9e8eb58751e7458c29901dbdd3673f94892d337d111d696e779e3f7ef0bca6c7d79709e2072a4bf3a001d8813125d571 SHA512 ebbe0f8becac39d63433dcc3de474c40f1215fc8faab94fa2ba869d28e66b27e4fe088377bd7ae64575a6d7b07017b88bf92e5488a3185a753e647d8da352bbf |
27 |
DIST llvm-project-6dc85bd3fde7df2999fda07e9e9f2e83d52c6125.tar.gz 175208511 BLAKE2B cf87cf7e9bf7c74aab8ccda0f153369cb81798047fdd48025c3c7030857b128babbaafb667385a5c8e9916e16038b14fee39f1623d329471e73c39c2f2d7bbfa SHA512 e6dc0cacd6c079be8a00364e4c244782d764d9a8d514d65f9078427cb4a0c1663ff88761bfbc1e955a1a990451439110497c2cb7af7f56b2c91f2e9db4389894 |
28 |
DIST llvmorg-13.0.1.tar.gz 147290251 BLAKE2B 2a44b012a672501761d0c27c6b3a315b69bfef0cd13b078a7e7d2fccc4a9c8c0f2bee0f164c4271c9106b0a99cb06e8b64986f66253b613336719fb86b82541b SHA512 9a8cb5d11964ba88b7624f19ec861fb28701f23956ea3c92f6ac644332d5f41fde97bd8933dd3ee70ed378058c252fa3a3887c8d1af90d219970c2b27691166f |
29 |
|
30 |
diff --git a/sys-devel/llvm/llvm-16.0.0_rc1.ebuild b/sys-devel/llvm/llvm-16.0.0_rc1.ebuild |
31 |
new file mode 100644 |
32 |
index 000000000000..d4655d4dc33f |
33 |
--- /dev/null |
34 |
+++ b/sys-devel/llvm/llvm-16.0.0_rc1.ebuild |
35 |
@@ -0,0 +1,514 @@ |
36 |
+# Copyright 1999-2023 Gentoo Authors |
37 |
+# Distributed under the terms of the GNU General Public License v2 |
38 |
+ |
39 |
+EAPI=8 |
40 |
+ |
41 |
+PYTHON_COMPAT=( python3_{9..11} ) |
42 |
+inherit cmake llvm.org multilib-minimal pax-utils python-any-r1 \ |
43 |
+ toolchain-funcs |
44 |
+ |
45 |
+DESCRIPTION="Low Level Virtual Machine" |
46 |
+HOMEPAGE="https://llvm.org/" |
47 |
+ |
48 |
+# Additional licenses: |
49 |
+# 1. OpenBSD regex: Henry Spencer's license ('rc' in Gentoo) + BSD. |
50 |
+# 2. xxhash: BSD. |
51 |
+# 3. MD5 code: public-domain. |
52 |
+# 4. ConvertUTF.h: TODO. |
53 |
+ |
54 |
+LICENSE="Apache-2.0-with-LLVM-exceptions UoI-NCSA BSD public-domain rc" |
55 |
+SLOT="${LLVM_MAJOR}/${LLVM_SOABI}" |
56 |
+KEYWORDS="" |
57 |
+IUSE=" |
58 |
+ +binutils-plugin debug doc exegesis libedit +libffi ncurses test xar |
59 |
+ xml z3 zstd |
60 |
+" |
61 |
+RESTRICT="!test? ( test )" |
62 |
+ |
63 |
+RDEPEND=" |
64 |
+ sys-libs/zlib:0=[${MULTILIB_USEDEP}] |
65 |
+ binutils-plugin? ( >=sys-devel/binutils-2.31.1-r4:*[plugins] ) |
66 |
+ exegesis? ( dev-libs/libpfm:= ) |
67 |
+ libedit? ( dev-libs/libedit:0=[${MULTILIB_USEDEP}] ) |
68 |
+ libffi? ( >=dev-libs/libffi-3.0.13-r1:0=[${MULTILIB_USEDEP}] ) |
69 |
+ ncurses? ( >=sys-libs/ncurses-5.9-r3:0=[${MULTILIB_USEDEP}] ) |
70 |
+ xar? ( app-arch/xar ) |
71 |
+ xml? ( dev-libs/libxml2:2=[${MULTILIB_USEDEP}] ) |
72 |
+ z3? ( >=sci-mathematics/z3-4.7.1:0=[${MULTILIB_USEDEP}] ) |
73 |
+ zstd? ( app-arch/zstd:=[${MULTILIB_USEDEP}] ) |
74 |
+" |
75 |
+DEPEND=" |
76 |
+ ${RDEPEND} |
77 |
+ binutils-plugin? ( sys-libs/binutils-libs ) |
78 |
+" |
79 |
+BDEPEND=" |
80 |
+ ${PYTHON_DEPS} |
81 |
+ dev-lang/perl |
82 |
+ >=dev-util/cmake-3.16 |
83 |
+ sys-devel/gnuconfig |
84 |
+ kernel_Darwin? ( |
85 |
+ <sys-libs/libcxx-${LLVM_VERSION}.9999 |
86 |
+ >=sys-devel/binutils-apple-5.1 |
87 |
+ ) |
88 |
+ doc? ( $(python_gen_any_dep ' |
89 |
+ dev-python/recommonmark[${PYTHON_USEDEP}] |
90 |
+ dev-python/sphinx[${PYTHON_USEDEP}] |
91 |
+ ') ) |
92 |
+ libffi? ( virtual/pkgconfig ) |
93 |
+" |
94 |
+# There are no file collisions between these versions but having :0 |
95 |
+# installed means llvm-config there will take precedence. |
96 |
+RDEPEND=" |
97 |
+ ${RDEPEND} |
98 |
+ !sys-devel/llvm:0 |
99 |
+" |
100 |
+PDEPEND=" |
101 |
+ sys-devel/llvm-common |
102 |
+ sys-devel/llvm-toolchain-symlinks:${LLVM_MAJOR} |
103 |
+ binutils-plugin? ( >=sys-devel/llvmgold-${LLVM_MAJOR} ) |
104 |
+" |
105 |
+ |
106 |
+LLVM_COMPONENTS=( llvm cmake ) |
107 |
+LLVM_TEST_COMPONENTS=( third-party ) |
108 |
+LLVM_MANPAGES=1 |
109 |
+LLVM_USE_TARGETS=provide |
110 |
+llvm.org_set_globals |
111 |
+ |
112 |
+python_check_deps() { |
113 |
+ use doc || return 0 |
114 |
+ |
115 |
+ python_has_version -b "dev-python/recommonmark[${PYTHON_USEDEP}]" && |
116 |
+ python_has_version -b "dev-python/sphinx[${PYTHON_USEDEP}]" |
117 |
+} |
118 |
+ |
119 |
+check_uptodate() { |
120 |
+ local prod_targets=( |
121 |
+ $(sed -n -e '/set(LLVM_ALL_TARGETS/,/)/p' CMakeLists.txt \ |
122 |
+ | tail -n +2 | head -n -1) |
123 |
+ ) |
124 |
+ local all_targets=( |
125 |
+ lib/Target/*/ |
126 |
+ ) |
127 |
+ all_targets=( "${all_targets[@]#lib/Target/}" ) |
128 |
+ all_targets=( "${all_targets[@]%/}" ) |
129 |
+ |
130 |
+ local exp_targets=() i |
131 |
+ for i in "${all_targets[@]}"; do |
132 |
+ has "${i}" "${prod_targets[@]}" || exp_targets+=( "${i}" ) |
133 |
+ done |
134 |
+ |
135 |
+ if [[ ${exp_targets[*]} != ${ALL_LLVM_EXPERIMENTAL_TARGETS[*]} ]]; then |
136 |
+ eqawarn "ALL_LLVM_EXPERIMENTAL_TARGETS is outdated!" |
137 |
+ eqawarn " Have: ${ALL_LLVM_EXPERIMENTAL_TARGETS[*]}" |
138 |
+ eqawarn "Expected: ${exp_targets[*]}" |
139 |
+ eqawarn |
140 |
+ fi |
141 |
+ |
142 |
+ if [[ ${prod_targets[*]} != ${ALL_LLVM_PRODUCTION_TARGETS[*]} ]]; then |
143 |
+ eqawarn "ALL_LLVM_PRODUCTION_TARGETS is outdated!" |
144 |
+ eqawarn " Have: ${ALL_LLVM_PRODUCTION_TARGETS[*]}" |
145 |
+ eqawarn "Expected: ${prod_targets[*]}" |
146 |
+ fi |
147 |
+} |
148 |
+ |
149 |
+check_distribution_components() { |
150 |
+ if [[ ${CMAKE_MAKEFILE_GENERATOR} == ninja ]]; then |
151 |
+ local all_targets=() my_targets=() l |
152 |
+ cd "${BUILD_DIR}" || die |
153 |
+ |
154 |
+ while read -r l; do |
155 |
+ if [[ ${l} == install-*-stripped:* ]]; then |
156 |
+ l=${l#install-} |
157 |
+ l=${l%%-stripped*} |
158 |
+ |
159 |
+ case ${l} in |
160 |
+ # shared libs |
161 |
+ LLVM|LLVMgold) |
162 |
+ ;; |
163 |
+ # TableGen lib + deps |
164 |
+ LLVMDemangle|LLVMSupport|LLVMTableGen) |
165 |
+ ;; |
166 |
+ # static libs |
167 |
+ LLVM*) |
168 |
+ continue |
169 |
+ ;; |
170 |
+ # meta-targets |
171 |
+ distribution|llvm-libraries) |
172 |
+ continue |
173 |
+ ;; |
174 |
+ # used only w/ USE=doc |
175 |
+ docs-llvm-html) |
176 |
+ use doc || continue |
177 |
+ ;; |
178 |
+ esac |
179 |
+ |
180 |
+ all_targets+=( "${l}" ) |
181 |
+ fi |
182 |
+ done < <(${NINJA} -t targets all) |
183 |
+ |
184 |
+ while read -r l; do |
185 |
+ my_targets+=( "${l}" ) |
186 |
+ done < <(get_distribution_components $"\n") |
187 |
+ |
188 |
+ local add=() remove=() |
189 |
+ for l in "${all_targets[@]}"; do |
190 |
+ if ! has "${l}" "${my_targets[@]}"; then |
191 |
+ add+=( "${l}" ) |
192 |
+ fi |
193 |
+ done |
194 |
+ for l in "${my_targets[@]}"; do |
195 |
+ if ! has "${l}" "${all_targets[@]}"; then |
196 |
+ remove+=( "${l}" ) |
197 |
+ fi |
198 |
+ done |
199 |
+ |
200 |
+ if [[ ${#add[@]} -gt 0 || ${#remove[@]} -gt 0 ]]; then |
201 |
+ eqawarn "get_distribution_components() is outdated!" |
202 |
+ eqawarn " Add: ${add[*]}" |
203 |
+ eqawarn "Remove: ${remove[*]}" |
204 |
+ fi |
205 |
+ cd - >/dev/null || die |
206 |
+ fi |
207 |
+} |
208 |
+ |
209 |
+src_prepare() { |
210 |
+ # disable use of SDK on OSX, bug #568758 |
211 |
+ sed -i -e 's/xcrun/false/' utils/lit/lit/util.py || die |
212 |
+ |
213 |
+ # Update config.guess to support more systems |
214 |
+ cp "${BROOT}/usr/share/gnuconfig/config.guess" cmake/ || die |
215 |
+ |
216 |
+ # Verify that the ebuild is up-to-date |
217 |
+ check_uptodate |
218 |
+ |
219 |
+ llvm.org_src_prepare |
220 |
+} |
221 |
+ |
222 |
+get_distribution_components() { |
223 |
+ local sep=${1-;} |
224 |
+ |
225 |
+ local out=( |
226 |
+ # shared libs |
227 |
+ LLVM |
228 |
+ LTO |
229 |
+ Remarks |
230 |
+ |
231 |
+ # tools |
232 |
+ llvm-config |
233 |
+ |
234 |
+ # common stuff |
235 |
+ cmake-exports |
236 |
+ llvm-headers |
237 |
+ |
238 |
+ # libraries needed for clang-tblgen |
239 |
+ LLVMDemangle |
240 |
+ LLVMSupport |
241 |
+ LLVMTableGen |
242 |
+ ) |
243 |
+ |
244 |
+ if multilib_is_native_abi; then |
245 |
+ out+=( |
246 |
+ # utilities |
247 |
+ llvm-tblgen |
248 |
+ FileCheck |
249 |
+ llvm-PerfectShuffle |
250 |
+ count |
251 |
+ not |
252 |
+ yaml-bench |
253 |
+ UnicodeNameMappingGenerator |
254 |
+ |
255 |
+ # tools |
256 |
+ bugpoint |
257 |
+ dsymutil |
258 |
+ llc |
259 |
+ lli |
260 |
+ lli-child-target |
261 |
+ llvm-addr2line |
262 |
+ llvm-ar |
263 |
+ llvm-as |
264 |
+ llvm-bcanalyzer |
265 |
+ llvm-bitcode-strip |
266 |
+ llvm-c-test |
267 |
+ llvm-cat |
268 |
+ llvm-cfi-verify |
269 |
+ llvm-config |
270 |
+ llvm-cov |
271 |
+ llvm-cvtres |
272 |
+ llvm-cxxdump |
273 |
+ llvm-cxxfilt |
274 |
+ llvm-cxxmap |
275 |
+ llvm-debuginfo-analyzer |
276 |
+ llvm-debuginfod |
277 |
+ llvm-debuginfod-find |
278 |
+ llvm-diff |
279 |
+ llvm-dis |
280 |
+ llvm-dlltool |
281 |
+ llvm-dwarfdump |
282 |
+ llvm-dwarfutil |
283 |
+ llvm-dwp |
284 |
+ llvm-exegesis |
285 |
+ llvm-extract |
286 |
+ llvm-gsymutil |
287 |
+ llvm-ifs |
288 |
+ llvm-install-name-tool |
289 |
+ llvm-jitlink |
290 |
+ llvm-jitlink-executor |
291 |
+ llvm-lib |
292 |
+ llvm-libtool-darwin |
293 |
+ llvm-link |
294 |
+ llvm-lipo |
295 |
+ llvm-lto |
296 |
+ llvm-lto2 |
297 |
+ llvm-mc |
298 |
+ llvm-mca |
299 |
+ llvm-ml |
300 |
+ llvm-modextract |
301 |
+ llvm-mt |
302 |
+ llvm-nm |
303 |
+ llvm-objcopy |
304 |
+ llvm-objdump |
305 |
+ llvm-opt-report |
306 |
+ llvm-otool |
307 |
+ llvm-pdbutil |
308 |
+ llvm-profdata |
309 |
+ llvm-profgen |
310 |
+ llvm-ranlib |
311 |
+ llvm-rc |
312 |
+ llvm-readelf |
313 |
+ llvm-readobj |
314 |
+ llvm-reduce |
315 |
+ llvm-remark-size-diff |
316 |
+ llvm-remarkutil |
317 |
+ llvm-rtdyld |
318 |
+ llvm-sim |
319 |
+ llvm-size |
320 |
+ llvm-split |
321 |
+ llvm-stress |
322 |
+ llvm-strings |
323 |
+ llvm-strip |
324 |
+ llvm-symbolizer |
325 |
+ llvm-tapi-diff |
326 |
+ llvm-tli-checker |
327 |
+ llvm-undname |
328 |
+ llvm-windres |
329 |
+ llvm-xray |
330 |
+ obj2yaml |
331 |
+ opt |
332 |
+ sancov |
333 |
+ sanstats |
334 |
+ split-file |
335 |
+ verify-uselistorder |
336 |
+ yaml2obj |
337 |
+ |
338 |
+ # python modules |
339 |
+ opt-viewer |
340 |
+ ) |
341 |
+ |
342 |
+ if llvm_are_manpages_built; then |
343 |
+ out+=( |
344 |
+ # manpages |
345 |
+ docs-dsymutil-man |
346 |
+ docs-llvm-dwarfdump-man |
347 |
+ docs-llvm-man |
348 |
+ ) |
349 |
+ fi |
350 |
+ use doc && out+=( |
351 |
+ docs-llvm-html |
352 |
+ ) |
353 |
+ |
354 |
+ use binutils-plugin && out+=( |
355 |
+ LLVMgold |
356 |
+ ) |
357 |
+ fi |
358 |
+ |
359 |
+ printf "%s${sep}" "${out[@]}" |
360 |
+} |
361 |
+ |
362 |
+multilib_src_configure() { |
363 |
+ local ffi_cflags ffi_ldflags |
364 |
+ if use libffi; then |
365 |
+ ffi_cflags=$($(tc-getPKG_CONFIG) --cflags-only-I libffi) |
366 |
+ ffi_ldflags=$($(tc-getPKG_CONFIG) --libs-only-L libffi) |
367 |
+ fi |
368 |
+ |
369 |
+ local libdir=$(get_libdir) |
370 |
+ local mycmakeargs=( |
371 |
+ # disable appending VCS revision to the version to improve |
372 |
+ # direct cache hit ratio |
373 |
+ -DLLVM_APPEND_VC_REV=OFF |
374 |
+ -DCMAKE_INSTALL_PREFIX="${EPREFIX}/usr/lib/llvm/${LLVM_MAJOR}" |
375 |
+ -DLLVM_LIBDIR_SUFFIX=${libdir#lib} |
376 |
+ |
377 |
+ -DBUILD_SHARED_LIBS=OFF |
378 |
+ -DLLVM_BUILD_LLVM_DYLIB=ON |
379 |
+ -DLLVM_LINK_LLVM_DYLIB=ON |
380 |
+ -DLLVM_DISTRIBUTION_COMPONENTS=$(get_distribution_components) |
381 |
+ |
382 |
+ # cheap hack: LLVM combines both anyway, and the only difference |
383 |
+ # is that the former list is explicitly verified at cmake time |
384 |
+ -DLLVM_TARGETS_TO_BUILD="" |
385 |
+ -DLLVM_EXPERIMENTAL_TARGETS_TO_BUILD="${LLVM_TARGETS// /;}" |
386 |
+ -DLLVM_INCLUDE_BENCHMARKS=OFF |
387 |
+ -DLLVM_INCLUDE_TESTS=$(usex test) |
388 |
+ -DLLVM_BUILD_TESTS=$(usex test) |
389 |
+ |
390 |
+ -DLLVM_ENABLE_FFI=$(usex libffi) |
391 |
+ -DLLVM_ENABLE_LIBEDIT=$(usex libedit) |
392 |
+ -DLLVM_ENABLE_TERMINFO=$(usex ncurses) |
393 |
+ -DLLVM_ENABLE_LIBXML2=$(usex xml) |
394 |
+ -DLLVM_ENABLE_ASSERTIONS=$(usex debug) |
395 |
+ -DLLVM_ENABLE_LIBPFM=$(usex exegesis) |
396 |
+ -DLLVM_ENABLE_Z3_SOLVER=$(usex z3) |
397 |
+ -DLLVM_ENABLE_ZSTD=$(usex zstd) |
398 |
+ |
399 |
+ -DLLVM_HOST_TRIPLE="${CHOST}" |
400 |
+ |
401 |
+ -DFFI_INCLUDE_DIR="${ffi_cflags#-I}" |
402 |
+ -DFFI_LIBRARY_DIR="${ffi_ldflags#-L}" |
403 |
+ # used only for llvm-objdump tool |
404 |
+ -DLLVM_HAVE_LIBXAR=$(multilib_native_usex xar 1 0) |
405 |
+ |
406 |
+ -DPython3_EXECUTABLE="${PYTHON}" |
407 |
+ |
408 |
+ # disable OCaml bindings (now in dev-ml/llvm-ocaml) |
409 |
+ -DOCAMLFIND=NO |
410 |
+ ) |
411 |
+ |
412 |
+ local suffix= |
413 |
+ if [[ -n ${EGIT_VERSION} && ${EGIT_BRANCH} != release/* ]]; then |
414 |
+ # the ABI of the main branch is not stable, so let's include |
415 |
+ # the commit id in the SOVERSION to contain the breakage |
416 |
+ suffix+="git${EGIT_VERSION::8}" |
417 |
+ fi |
418 |
+ if [[ $(tc-get-cxx-stdlib) == libc++ ]]; then |
419 |
+ # Smart hack: alter version suffix -> SOVERSION when linking |
420 |
+ # against libc++. This way we won't end up mixing LLVM libc++ |
421 |
+ # libraries with libstdc++ clang, and the other way around. |
422 |
+ suffix+="+libcxx" |
423 |
+ mycmakeargs+=( |
424 |
+ -DLLVM_ENABLE_LIBCXX=ON |
425 |
+ ) |
426 |
+ fi |
427 |
+ mycmakeargs+=( |
428 |
+ -DLLVM_VERSION_SUFFIX="${suffix}" |
429 |
+ ) |
430 |
+ |
431 |
+ use test && mycmakeargs+=( |
432 |
+ -DLLVM_LIT_ARGS="$(get_lit_flags)" |
433 |
+ ) |
434 |
+ |
435 |
+ if multilib_is_native_abi; then |
436 |
+ local build_docs=OFF |
437 |
+ if llvm_are_manpages_built; then |
438 |
+ build_docs=ON |
439 |
+ mycmakeargs+=( |
440 |
+ -DCMAKE_INSTALL_MANDIR="${EPREFIX}/usr/lib/llvm/${LLVM_MAJOR}/share/man" |
441 |
+ -DLLVM_INSTALL_SPHINX_HTML_DIR="${EPREFIX}/usr/share/doc/${PF}/html" |
442 |
+ -DSPHINX_WARNINGS_AS_ERRORS=OFF |
443 |
+ ) |
444 |
+ fi |
445 |
+ |
446 |
+ mycmakeargs+=( |
447 |
+ -DLLVM_BUILD_DOCS=${build_docs} |
448 |
+ -DLLVM_ENABLE_OCAMLDOC=OFF |
449 |
+ -DLLVM_ENABLE_SPHINX=${build_docs} |
450 |
+ -DLLVM_ENABLE_DOXYGEN=OFF |
451 |
+ -DLLVM_INSTALL_UTILS=ON |
452 |
+ ) |
453 |
+ use binutils-plugin && mycmakeargs+=( |
454 |
+ -DLLVM_BINUTILS_INCDIR="${EPREFIX}"/usr/include |
455 |
+ ) |
456 |
+ fi |
457 |
+ |
458 |
+ # workaround BMI bug in gcc-7 (fixed in 7.4) |
459 |
+ # https://bugs.gentoo.org/649880 |
460 |
+ # apply only to x86, https://bugs.gentoo.org/650506 |
461 |
+ if tc-is-gcc && [[ ${MULTILIB_ABI_FLAG} == abi_x86* ]] && |
462 |
+ [[ $(gcc-major-version) -eq 7 && $(gcc-minor-version) -lt 4 ]] |
463 |
+ then |
464 |
+ local CFLAGS="${CFLAGS} -mno-bmi" |
465 |
+ local CXXFLAGS="${CXXFLAGS} -mno-bmi" |
466 |
+ fi |
467 |
+ |
468 |
+ # LLVM can have very high memory consumption while linking, |
469 |
+ # exhausting the limit on 32-bit linker executable |
470 |
+ use x86 && local -x LDFLAGS="${LDFLAGS} -Wl,--no-keep-memory" |
471 |
+ |
472 |
+ # LLVM_ENABLE_ASSERTIONS=NO does not guarantee this for us, #614844 |
473 |
+ use debug || local -x CPPFLAGS="${CPPFLAGS} -DNDEBUG" |
474 |
+ cmake_src_configure |
475 |
+ |
476 |
+ grep -q -E "^CMAKE_PROJECT_VERSION_MAJOR(:.*)?=${LLVM_MAJOR}$" \ |
477 |
+ CMakeCache.txt || |
478 |
+ die "Incorrect version, did you update _LLVM_MASTER_MAJOR?" |
479 |
+ multilib_is_native_abi && check_distribution_components |
480 |
+} |
481 |
+ |
482 |
+multilib_src_compile() { |
483 |
+ tc-env_build cmake_build distribution |
484 |
+ |
485 |
+ pax-mark m "${BUILD_DIR}"/bin/llvm-rtdyld |
486 |
+ pax-mark m "${BUILD_DIR}"/bin/lli |
487 |
+ pax-mark m "${BUILD_DIR}"/bin/lli-child-target |
488 |
+ |
489 |
+ if use test; then |
490 |
+ pax-mark m "${BUILD_DIR}"/unittests/ExecutionEngine/Orc/OrcJITTests |
491 |
+ pax-mark m "${BUILD_DIR}"/unittests/ExecutionEngine/MCJIT/MCJITTests |
492 |
+ pax-mark m "${BUILD_DIR}"/unittests/Support/SupportTests |
493 |
+ fi |
494 |
+} |
495 |
+ |
496 |
+multilib_src_test() { |
497 |
+ # respect TMPDIR! |
498 |
+ local -x LIT_PRESERVES_TMP=1 |
499 |
+ cmake_build check |
500 |
+} |
501 |
+ |
502 |
+src_install() { |
503 |
+ local MULTILIB_CHOST_TOOLS=( |
504 |
+ /usr/lib/llvm/${LLVM_MAJOR}/bin/llvm-config |
505 |
+ ) |
506 |
+ |
507 |
+ local MULTILIB_WRAPPED_HEADERS=( |
508 |
+ /usr/include/llvm/Config/llvm-config.h |
509 |
+ ) |
510 |
+ |
511 |
+ local LLVM_LDPATHS=() |
512 |
+ multilib-minimal_src_install |
513 |
+ |
514 |
+ # move wrapped headers back |
515 |
+ mv "${ED}"/usr/include "${ED}"/usr/lib/llvm/${LLVM_MAJOR}/include || die |
516 |
+} |
517 |
+ |
518 |
+multilib_src_install() { |
519 |
+ DESTDIR=${D} cmake_build install-distribution |
520 |
+ |
521 |
+ # move headers to /usr/include for wrapping |
522 |
+ rm -rf "${ED}"/usr/include || die |
523 |
+ mv "${ED}"/usr/lib/llvm/${LLVM_MAJOR}/include "${ED}"/usr/include || die |
524 |
+ |
525 |
+ LLVM_LDPATHS+=( "${EPREFIX}/usr/lib/llvm/${LLVM_MAJOR}/$(get_libdir)" ) |
526 |
+} |
527 |
+ |
528 |
+multilib_src_install_all() { |
529 |
+ local revord=$(( 9999 - ${LLVM_MAJOR} )) |
530 |
+ newenvd - "60llvm-${revord}" <<-_EOF_ |
531 |
+ PATH="${EPREFIX}/usr/lib/llvm/${LLVM_MAJOR}/bin" |
532 |
+ # we need to duplicate it in ROOTPATH for Portage to respect... |
533 |
+ ROOTPATH="${EPREFIX}/usr/lib/llvm/${LLVM_MAJOR}/bin" |
534 |
+ MANPATH="${EPREFIX}/usr/lib/llvm/${LLVM_MAJOR}/share/man" |
535 |
+ LDPATH="$( IFS=:; echo "${LLVM_LDPATHS[*]}" )" |
536 |
+ _EOF_ |
537 |
+ |
538 |
+ docompress "/usr/lib/llvm/${LLVM_MAJOR}/share/man" |
539 |
+ llvm_install_manpages |
540 |
+} |
541 |
+ |
542 |
+pkg_postinst() { |
543 |
+ elog "You can find additional opt-viewer utility scripts in:" |
544 |
+ elog " ${EROOT}/usr/lib/llvm/${LLVM_MAJOR}/share/opt-viewer" |
545 |
+ elog "To use these scripts, you will need Python along with the following" |
546 |
+ elog "packages:" |
547 |
+ elog " dev-python/pygments (for opt-viewer)" |
548 |
+ elog " dev-python/pyyaml (for all of them)" |
549 |
+} |