Auto merge of #107129 - wesleywiser:musl_1.2_upgrade, r=petrochenkov
Update the version of musl used on `*-linux-musl` targets to 1.2.3 Update the version of musl used on our Linux musl targets from 1.1.24 to 1.2.3 as proposed in rust-lang/compiler-team#572. musl 1.2.3 is the latest version of musl and supports the same range of Linux kernels as the 1.1 series. As such, it does not affect the minimum supported version of Linux for any of the musl targets. One of the major musl 1.2 features is support for [time64](https://musl.libc.org/time64.html). This support is both source and ABI compatible with programs built against musl 1.1 and so updating the musl version for these targets should not cause Rust programs to fail to run or compile (a [crater run](https://github.com/rust-lang/rust/pull/107129#issuecomment-1407196104) has been completed which demonstrates this for the `i686-unknown-linux-musl` target). Once this change reaches stable, the `libc` crate will then be able to [update their definitions to support 64-bit time](https://github.com/rust-lang/libc/pull/3068), matching the default musl 1.2 APIs exactly. Fixes #91178
This commit is contained in:
commit
6e96802bf5
5 changed files with 7 additions and 16 deletions
|
@ -8,7 +8,6 @@ RUN sh /scripts/crosstool-ng.sh
|
|||
|
||||
WORKDIR /build
|
||||
|
||||
COPY scripts/musl-patch-configure.diff /build/
|
||||
COPY scripts/musl-toolchain.sh /build/
|
||||
# We need to mitigate rust-lang/rust#34978 when compiling musl itself as well
|
||||
RUN CFLAGS="-Wa,--compress-debug-sections=none -Wl,--compress-debug-sections=none" \
|
||||
|
|
|
@ -25,7 +25,6 @@ WORKDIR /build/
|
|||
COPY scripts/cmake.sh /scripts/
|
||||
RUN /scripts/cmake.sh
|
||||
|
||||
COPY scripts/musl-patch-configure.diff /build/
|
||||
COPY scripts/musl-toolchain.sh /build/
|
||||
# We need to mitigate rust-lang/rust#34978 when compiling musl itself as well
|
||||
RUN CFLAGS="-Wa,-mrelax-relocations=no -Wa,--compress-debug-sections=none -Wl,--compress-debug-sections=none" \
|
||||
|
|
|
@ -33,7 +33,6 @@ RUN curl -sL --output ovmf-ia32.deb http://mirrors.kernel.org/ubuntu/pool/univer
|
|||
RUN dpkg -i ovmf-ia32.deb && rm ovmf-ia32.deb
|
||||
|
||||
WORKDIR /build/
|
||||
COPY scripts/musl-patch-configure.diff /build/
|
||||
COPY scripts/musl-toolchain.sh /build/
|
||||
RUN bash musl-toolchain.sh x86_64 && rm -rf build
|
||||
WORKDIR /
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
#
|
||||
# Versions of the toolchain components are configurable in `musl-cross-make/Makefile` and
|
||||
# musl unlike GLIBC is forward compatible so upgrading it shouldn't break old distributions.
|
||||
# Right now we have: Binutils 2.31.1, GCC 9.2.0, musl 1.1.24.
|
||||
# Right now we have: Binutils 2.31.1, GCC 9.2.0, musl 1.2.3.
|
||||
|
||||
# ignore-tidy-linelength
|
||||
|
||||
|
@ -32,6 +32,7 @@ TARGET=$ARCH-linux-musl
|
|||
|
||||
# Don't depend on the mirrors of sabotage linux that musl-cross-make uses.
|
||||
LINUX_HEADERS_SITE=https://ci-mirrors.rust-lang.org/rustc/sabotage-linux-tarballs
|
||||
LINUX_VER=headers-4.19.88
|
||||
|
||||
OUTPUT=/usr/local
|
||||
shift
|
||||
|
@ -44,18 +45,11 @@ export CFLAGS="-fPIC -g1 $CFLAGS"
|
|||
|
||||
git clone https://github.com/richfelker/musl-cross-make # -b v0.9.9
|
||||
cd musl-cross-make
|
||||
# A few commits ahead of v0.9.9 to include the cowpatch fix:
|
||||
git checkout a54eb56f33f255dfca60be045f12a5cfaf5a72a9
|
||||
# A version that includes support for building musl 1.2.3
|
||||
git checkout fe915821b652a7fa37b34a596f47d8e20bc72338
|
||||
|
||||
# Fix the cfi detection script in musl's configure so cfi is generated
|
||||
# when debug info is asked for. This patch is derived from
|
||||
# https://git.musl-libc.org/cgit/musl/commit/?id=c4d4028dde90562f631edf559fbc42d8ec1b29de.
|
||||
# When we upgrade to a version that includes this commit, we can remove the patch.
|
||||
mkdir patches/musl-1.1.24
|
||||
cp ../musl-patch-configure.diff patches/musl-1.1.24/0001-fix-cfi-detection.diff
|
||||
|
||||
hide_output make -j$(nproc) TARGET=$TARGET MUSL_VER=1.1.24 LINUX_HEADERS_SITE=$LINUX_HEADERS_SITE
|
||||
hide_output make install TARGET=$TARGET MUSL_VER=1.1.24 LINUX_HEADERS_SITE=$LINUX_HEADERS_SITE OUTPUT=$OUTPUT
|
||||
hide_output make -j$(nproc) TARGET=$TARGET MUSL_VER=1.2.3 LINUX_HEADERS_SITE=$LINUX_HEADERS_SITE LINUX_VER=$LINUX_VER
|
||||
hide_output make install TARGET=$TARGET MUSL_VER=1.2.3 LINUX_HEADERS_SITE=$LINUX_HEADERS_SITE LINUX_VER=$LINUX_VER OUTPUT=$OUTPUT
|
||||
|
||||
cd -
|
||||
|
||||
|
|
|
@ -25,7 +25,7 @@ shift
|
|||
# Apparently applying `-fPIC` everywhere allows them to link successfully.
|
||||
export CFLAGS="-fPIC $CFLAGS"
|
||||
|
||||
MUSL=musl-1.1.24
|
||||
MUSL=musl-1.2.3
|
||||
|
||||
# may have been downloaded in a previous run
|
||||
if [ ! -d $MUSL ]; then
|
||||
|
|
Loading…
Add table
Reference in a new issue