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