From 8e72ae8a1d4b59d0131f3373e5161b3f405861b0 Mon Sep 17 00:00:00 2001 From: its-pointless Date: Mon, 21 Oct 2019 12:52:24 +1100 Subject: [PATCH] update to llvm9 and fix tools in rust --- packages/libllvm/ORCv2.rst.patch | 68 ++++++++++++++++++++++++++++++++ packages/libllvm/build.sh | 30 +++++++------- packages/rust/build.sh | 22 ++++++----- packages/rust/config.toml | 4 +- 4 files changed, 99 insertions(+), 25 deletions(-) create mode 100644 packages/libllvm/ORCv2.rst.patch diff --git a/packages/libllvm/ORCv2.rst.patch b/packages/libllvm/ORCv2.rst.patch new file mode 100644 index 000000000..db0bad6a2 --- /dev/null +++ b/packages/libllvm/ORCv2.rst.patch @@ -0,0 +1,68 @@ +From fe4cc4507a5f23efd105194b017d28311d1620e4 Mon Sep 17 00:00:00 2001 +From: Lang Hames +Date: Wed, 31 Jul 2019 18:07:37 +0000 +Subject: [PATCH] [docs] Add references to unreferenced footnotes. + +Thanks to Stefan Granitz for catching the issue. + +git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@367458 91177308-0d34-0410-b5e6-96231b3b80d8 +--- + docs/ORCv2.rst | 26 +++++++++++++------------- + 1 file changed, 13 insertions(+), 13 deletions(-) + +diff --git a/docs/ORCv2.rst b/docs/ORCv2.rst +index 7423c041d40a..4f9e08b9a154 100644 +--- a/docs/ORCv2.rst ++++ b/docs/ORCv2.rst +@@ -153,8 +153,8 @@ Design Overview + ORC's JIT'd program model aims to emulate the linking and symbol resolution + rules used by the static and dynamic linkers. This allows ORC to JIT + arbitrary LLVM IR, including IR produced by an ordinary static compiler (e.g. +-clang) that uses constructs like symbol linkage and visibility, and weak and +-common symbol definitions. ++clang) that uses constructs like symbol linkage and visibility, and weak [4]_ ++and common symbol definitions. + + To see how this works, imagine a program ``foo`` which links against a pair + of dynamic libraries: ``libA`` and ``libB``. On the command line, building this +@@ -326,7 +326,7 @@ prefix in LLVM 8.0, and have deprecation warnings attached in LLVM 9.0. In LLVM + 10.0 ORCv1 will be removed entirely. + + Transitioning from ORCv1 to ORCv2 should be easy for most clients. Most of the +-ORCv1 layers and utilities have ORCv2 counterparts[2]_ that can be directly ++ORCv1 layers and utilities have ORCv2 counterparts [2]_ that can be directly + substituted. However there are some design differences between ORCv1 and ORCv2 + to be aware of: + +@@ -497,8 +497,8 @@ locking must be done explicitly: + } + + Clients wishing to maximize possibilities for concurrent compilation will want +-to create every new ThreadSafeModule on a new ThreadSafeContext. For this reason +-a convenience constructor for ThreadSafeModule is provided that implicitly ++to create every new ThreadSafeModule on a new ThreadSafeContext [3]_. For this ++reason a convenience constructor for ThreadSafeModule is provided that implicitly + constructs a new ThreadSafeContext value from a std::unique_ptr: + + .. code-block:: c++ +@@ -622,11 +622,11 @@ TBD: Speculative compilation. Object Caches. + + .. [3] Sharing ThreadSafeModules in a concurrent compilation can be dangerous: + if interdependent modules are loaded on the same context, but compiled +- on different threads a deadlock may occur (with each compile waiting for +- the other(s) to complete, and the other(s) unable to proceed because the +- context is locked). +- +-.. [4] Mostly. Weak definitions are handled correctly within dylibs, but if +- multiple dylibs provide a weak definition of a symbol each will end up +- with its own definition (similar to how weak symbols in Windows DLLs +- behave). This will be fixed in the future. +\ No newline at end of file ++ on different threads a deadlock may occur, with each compile waiting for ++ the other to complete, and the other unable to proceed because the ++ context is locked. ++ ++.. [4] Weak definitions are currently handled correctly within dylibs, but if ++ multiple dylibs provide a weak definition of a symbol then each will end ++ up with its own definition (similar to how weak definitions are handled ++ in Windows DLLs). This will be fixed in the future. diff --git a/packages/libllvm/build.sh b/packages/libllvm/build.sh index 3feed53a3..dd23a6397 100644 --- a/packages/libllvm/build.sh +++ b/packages/libllvm/build.sh @@ -1,16 +1,16 @@ TERMUX_PKG_HOMEPAGE=https://clang.llvm.org/ TERMUX_PKG_DESCRIPTION="Modular compiler and toolchain technologies library" TERMUX_PKG_LICENSE="NCSA" -TERMUX_PKG_VERSION=8.0.1 -TERMUX_PKG_REVISION=4 -TERMUX_PKG_SHA256=(44787a6d02f7140f145e2250d56c9f849334e11f9ae379827510ed72f12b75e7 - 70effd69f7a8ab249f66b0a68aba8b08af52aa2ab710dfb8a0fba102685b1646 - 9fba1e94249bd7913e8a6c3aadcb308b76c8c3d83c5ce36c99c3f34d73873d88 - 3e85dd3cad41117b7c89a41de72f2e6aa756ea7b4ef63bb10dcddf8561a7722c) -TERMUX_PKG_SRCURL=(https://github.com/llvm/llvm-project/releases/download/llvmorg-$TERMUX_PKG_VERSION/llvm-$TERMUX_PKG_VERSION.src.tar.xz - https://github.com/llvm/llvm-project/releases/download/llvmorg-$TERMUX_PKG_VERSION/cfe-$TERMUX_PKG_VERSION.src.tar.xz - https://github.com/llvm/llvm-project/releases/download/llvmorg-$TERMUX_PKG_VERSION/lld-$TERMUX_PKG_VERSION.src.tar.xz - https://github.com/llvm/llvm-project/releases/download/llvmorg-$TERMUX_PKG_VERSION/openmp-$TERMUX_PKG_VERSION.src.tar.xz) +TERMUX_PKG_VERSION=9.0.0 +TERMUX_PKG_SHA256=(d6a0565cf21f22e9b4353b2eb92622e8365000a9e90a16b09b56f8157eabfe84 + 7ba81eef7c22ca5da688fdf9d88c20934d2d6b40bfe150ffd338900890aa4610 + 31c6748b235d09723fb73fea0c816ed5a3fab0f96b66f8fbc546a0fcc8688f91 + 9979eb1133066376cc0be29d1682bc0b0e7fb541075b391061679111ae4d3b5b) +TERMUX_PKG_SRCURL=(https://releases.llvm.org/$TERMUX_PKG_VERSION/llvm-$TERMUX_PKG_VERSION.src.tar.xz + https://releases.llvm.org/$TERMUX_PKG_VERSION/cfe-$TERMUX_PKG_VERSION.src.tar.xz + https://releases.llvm.org/$TERMUX_PKG_VERSION/lld-$TERMUX_PKG_VERSION.src.tar.xz + https://releases.llvm.org/$TERMUX_PKG_VERSION/openmp-$TERMUX_PKG_VERSION.src.tar.xz + ) TERMUX_PKG_HOSTBUILD=true TERMUX_PKG_RM_AFTER_INSTALL=" bin/clang-check @@ -95,13 +95,15 @@ termux_step_pre_configure() { TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" -DLLVM_TARGET_ARCH=$LLVM_TARGET_ARCH -DLLVM_TARGETS_TO_BUILD=all" TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" -DLLVM_HOST_TRIPLE=$LLVM_DEFAULT_TARGET_TRIPLE" } +termux_step_make() { + ninja || zsh +} termux_step_post_make_install() { if [ $TERMUX_ARCH = "arm" ]; then - cp ../src/projects/openmp/runtime/exports/common.min.50/include/omp.h $TERMUX_PREFIX/include + cp ../src/projects/openmp/runtime/exports/common.min/include/omp.h $TERMUX_PREFIX/include else - cp ../src/projects/openmp/runtime/exports/common.min.50.ompt.optional/include/omp.h $TERMUX_PREFIX/include - fi - + cp ../src/projects/openmp/runtime/exports/common.min.ompt.optional/include/omp.h $TERMUX_PREFIX/include + fi if [ "$TERMUX_CMAKE_BUILD" = Ninja ]; then ninja docs-llvm-man else diff --git a/packages/rust/build.sh b/packages/rust/build.sh index a464a82e3..4e2c308d3 100644 --- a/packages/rust/build.sh +++ b/packages/rust/build.sh @@ -6,8 +6,7 @@ TERMUX_PKG_VERSION=1.38.0 TERMUX_PKG_SRCURL=https://static.rust-lang.org/dist/rustc-$TERMUX_PKG_VERSION-src.tar.xz TERMUX_PKG_SHA256=3a7991aa4cb44ef941d71636e45a95468b520dc6fc7cf725364925bd3e3d3a34 TERMUX_PKG_DEPENDS="libc++, clang, openssl, lld, zlib" -TERMUX_PKG_BLACKLISTED_ARCHES="x86_64" - +TERMUX_PKG_REVISION=1 termux_step_configure() { termux_setup_cmake termux_setup_rust @@ -18,9 +17,9 @@ termux_step_configure() { # configuration is used otherwise it fails a long time into the build... # like 30 to 40 + minutes ... so lets get it right - # 1.36 needs 1.35 to build revert to using $TERMUX_PKG_VERSION next time.. + # upstream only tests build ver one version behind $TERMUX_PKG_VERSION rustup install 1.37.0 - export PATH=$HOME/.rustup/toolchains/1.37.0-x86_64-unknown-linux-gnu/bin:$PATH + export PATH=$TERMUX_COMMON_CACHEDIR/toolchains/1.37.0-x86_64-unknown-linux-gnu/bin:$PATH local RUSTC=$(which rustc) local CARGO=$(which cargo) @@ -42,16 +41,21 @@ termux_step_configure() { export CC_x86_64_unknown_linux_gnu=gcc export CFLAGS_x86_64_unknown_linux_gnu="-O2" unset CC CXX CPP LD CFLAGS CXXFLAGS CPPFLAGS LDFLAGS PKG_CONFIG AR RANLIB + # rust checks libs in PREFIX/lib because both host and target are x86_64. It then can't libc.so and libdl.so because rust program doesn't know + # where those are. Putting them temporarly in $PREFIX/lib prevents that failure + if [ $TERMUX_ARCH = "x86_64" ]; then + cp $TERMUX_STANDALONE_TOOLCHAIN/sysroot/usr/lib/x86_64-linux-android/$TERMUX_PKG_API_LEVEL/libc.so $TERMUX_PREFIX/lib/ + cp $TERMUX_STANDALONE_TOOLCHAIN/sysroot/usr/lib/x86_64-linux-android/$TERMUX_PKG_API_LEVEL/libdl.so $TERMUX_PREFIX/lib/ + fi } -termux_step_make() { - $TERMUX_PKG_SRCDIR/x.py dist -} termux_step_make_install() { - $TERMUX_PKG_SRCDIR/x.py install - + # ugly fix to get extended tools working + $TERMUX_PKG_SRCDIR/x.py install --host $CARGO_TARGET_NAME --target $CARGO_TARGET_NAME --target wasm32-unknown-unknown || cp ./build/x86_64-unknown-linux-gnu/stage2/lib/rustlib/x86_64-unknown-linux-gnu/lib/librustc_macros-*.so ./build/x86_64-unknown-linux-gnu/stage2-tools/release/deps/librustc_macros-*.so + $TERMUX_PKG_SRCDIR/x.py install --host $CARGO_TARGET_NAME --target $CARGO_TARGET_NAME --target wasm32-unknown-unknown || true cd "$TERMUX_PREFIX/lib" + rm -f libc.so libdl.so ln -sf rustlib/$CARGO_TARGET_NAME/lib/*.so . ln -sf $TERMUX_PREFIX/bin/lld $TERMUX_PREFIX/bin/rust-lld diff --git a/packages/rust/config.toml b/packages/rust/config.toml index 060b5e965..73b3fa19e 100644 --- a/packages/rust/config.toml +++ b/packages/rust/config.toml @@ -14,7 +14,7 @@ python = "python2.7" extended = true sanitizers = false -tools = ["cargo", "analysis"] +#tools = ["cargo", "analysis", "rls", "rustfmt", "clippy-driver" ] [install] prefix = "@TERMUX_PREFIX@" @@ -37,4 +37,4 @@ llvm-config = "@TERMUX_PREFIX@/bin/llvm-config" [dist] src-tarball = false -missing-tools = true +#missing-tools = true