From 4f71ff0c7cfd4c68d9a0fdd415201bbaaade55e8 Mon Sep 17 00:00:00 2001 From: Levi Zim Date: Sun, 20 Oct 2024 16:51:44 +0800 Subject: [PATCH] updpatch: rust 1:1.82.0-1 Musl Patch ========== riscv64gc-unknown-linux-musl gets promoted to tier 2 and `crt_static_default` is updated to false in /~https://github.com/rust-lang/rust/pull/122049, which triggers /~https://github.com/rust-lang/rust/issues/82521#issuecomment-786093169 when building stage2 library artifacts (riscv64gc-unknown-linux-gnu -> riscv64gc-unknown-linux-musl). I patched it to re-enable `crt_static_default` for `riscv64gc-unknown-linux-musl` to fix the build and align with the behavior on x86 Arch Linux, where `rust-musl` defaults to statically link musl. Wasm compiler_builtins bug ========================== Wasm compiler_builtins rlib from built `rust-wasm` package includes objects for host architecture(riscv64 in our case, and x86_64 for x86 Arch Linux). This is not reproducible for toolchains installed via rustup so I have reported it to Arch Linux: https://gitlab.archlinux.org/archlinux/packaging/packages/rust/-/issues/3 Complications when building 1.82.0 ================================== /~https://github.com/rust-lang/rust/pull/125016 landed in 1.82.0, which breaks building rust 1.82.0 using our packaged rust 1.81.0. Compiling the new compiler_builtins component requires a rustc compiler that includes /~https://github.com/rust-lang/rust/pull/125016/commits/99e6a28804eac57faa37134d61a2bb17069996a2 but unfortunately 1.81.0 does not, leading to the following ICE: https://archriscv.felixc.at/.status/log.htm?url=logs/rust/rust-1:1.82.0-1.log internal compiler error: compiler/rustc_codegen_llvm/src/abi.rs:126:22: unsupported float: Reg { kind: Float, size: Size(2 bytes) } This is mitigated upstream by bumping stage0 to 1.82: /~https://github.com/rust-lang/rust/issues/129268#issuecomment-2408697698 So we need to first build 1.82.0 rustc once without the f16/f128 handling part in compiler_builtins, to get a compiler that is capable of handling f16/f128. And then we can use this compiler to compile compiler_builtins with f16/f128 handling. It's not easy to do so in one patch. The most easy way is to build and package rust 1.82.0 twice. This PR covers the first part and disable-f16-f128.diff will be removed in the second part. --- rust/disable-f16-f128.diff | 13 ++++++++ rust/riscv-musl-crt-default-static.diff | 12 +++++++ rust/riscv64.patch | 44 ++++++++++++++++++++++--- 3 files changed, 65 insertions(+), 4 deletions(-) create mode 100644 rust/disable-f16-f128.diff create mode 100644 rust/riscv-musl-crt-default-static.diff diff --git a/rust/disable-f16-f128.diff b/rust/disable-f16-f128.diff new file mode 100644 index 000000000..5741a3ca5 --- /dev/null +++ b/rust/disable-f16-f128.diff @@ -0,0 +1,13 @@ +diff --git a/library/alloc/Cargo.toml b/library/alloc/Cargo.toml +index 4365bcc4ad0..7849d463b6d 100644 +--- a/library/alloc/Cargo.toml ++++ b/library/alloc/Cargo.toml +@@ -10,7 +10,7 @@ edition = "2021" + + [dependencies] + core = { path = "../core" } +-compiler_builtins = { version = "0.1.123", features = ['rustc-dep-of-std'] } ++compiler_builtins = { version = "0.1.123", features = ['rustc-dep-of-std', 'no-f16-f128'] } + + [dev-dependencies] + rand = { version = "0.8.5", default-features = false, features = ["alloc"] } diff --git a/rust/riscv-musl-crt-default-static.diff b/rust/riscv-musl-crt-default-static.diff new file mode 100644 index 000000000..ab0efb655 --- /dev/null +++ b/rust/riscv-musl-crt-default-static.diff @@ -0,0 +1,12 @@ +diff --git a/compiler/rustc_target/src/spec/targets/riscv64gc_unknown_linux_musl.rs b/compiler/rustc_target/src/spec/targets/riscv64gc_unknown_linux_musl.rs +index 8b401329868..3e575fdd528 100644 +--- a/compiler/rustc_target/src/spec/targets/riscv64gc_unknown_linux_musl.rs ++++ b/compiler/rustc_target/src/spec/targets/riscv64gc_unknown_linux_musl.rs +@@ -21,7 +21,6 @@ pub fn target() -> Target { + llvm_abiname: "lp64d".into(), + max_atomic_width: Some(64), + supported_split_debuginfo: Cow::Borrowed(&[SplitDebuginfo::Off]), +- crt_static_default: false, + ..base::linux_musl::opts() + }, + } diff --git a/rust/riscv64.patch b/rust/riscv64.patch index 8de9a878c..82fefc91f 100644 --- a/rust/riscv64.patch +++ b/rust/riscv64.patch @@ -17,7 +17,43 @@ libffi lld llvm -@@ -99,9 +96,8 @@ link-shared = true +@@ -61,6 +58,8 @@ source=( + 0003-compiler-Change-LLVM-targets.patch + 0004-compiler-Use-wasm-ld-for-wasm-targets.patch + 0005-Fix-enabling-wasm-component-ld-to-match-other-tools.patch ++ disable-f16-f128.diff ++ riscv-musl-crt-default-static.diff + ) + b2sums=('c95ee180622a7984d03d43bcb3dd2ae16c41f95dde88426f972f32cac6ece904ced00d90967a32829db64d8790ee042192d1102426e7a2c4f6b2ff9d14c7cf70' + 'SKIP' +@@ -68,7 +67,9 @@ b2sums=('c95ee180622a7984d03d43bcb3dd2ae16c41f95dde88426f972f32cac6ece904ced00d9 + '365d53955a5ccf4b603ed39dd06384db063441477ed76fbbb31d7a0d46c6a297d86a0b306fcb616485c229ec8965eaa36a5b91b2398991b51f37ff58bd461054' + 'b0e5c8054f5364fbbc5619674923931e5d896bf56dc1cb1b09e906b7b451d44b7af78dca848e9f8e2de4f15d014187dd25301d6e704005a1efafffe586e120de' + '963aa64d27763f063b9fac483a870563f5a71a49ec02d17b7ca0c14dbf67064ba56028bbc45f2ee50b16eada725cb55c2aa2ab17ceadff65ba9e40cb220f7a0c' +- 'b99ff1689f92ac50b2f64e00150ae6959cf5350dab28e773d9256ec33457684289cef37297c66943a4aa15e0128d043676fa3e498a63bd264bdff34e165e1bcc') ++ 'b99ff1689f92ac50b2f64e00150ae6959cf5350dab28e773d9256ec33457684289cef37297c66943a4aa15e0128d043676fa3e498a63bd264bdff34e165e1bcc' ++ 'cc08fcde954217dd00d64f8554fa676730192209d96c8bad6444f283560c40589eeecdea4c93a596ba678ad470d49304208f1218595a900ab35588ff21f2bbe9' ++ 'a49b3a586b6ed62ec19a4f84f3ef297d926ce584faa640697c71e806f74012908a84d6a87a31bc8b3e70a6ce3049c1075ab13de3581374decf19cd9ee719cc65') + validpgpkeys=( + 108F66205EAEB0AAA8DD5E1C85AB96E6FA1BE5FE # Rust Language (Tag and Release Signing Key) + ) +@@ -93,6 +94,15 @@ prepare() { + # /~https://github.com/rust-lang/rust/pull/130034 + patch -Np1 -i ../0005-Fix-enabling-wasm-component-ld-to-match-other-tools.patch + ++ # Disable f16 f128 once ++ patch -Np1 -i ../disable-f16-f128.diff ++ ++ # Some musl targets(like x86_64) by default crt-static, while others are not. ++ # riscv musl target gets changed to not crt-static by default and triggers ++ # /~https://github.com/rust-lang/rust/issues/82521 ++ # Re-enable default crt-static to align with x86_64 Arch Linux and fix build. ++ patch -Np1 -i ../riscv-musl-crt-default-static.diff ++ + cat >config.toml <