From 945dbcd227ef8f43ffc287fc2ff651e0381af11b Mon Sep 17 00:00:00 2001 From: Nicholas Bishop Date: Sat, 2 Nov 2024 22:42:46 -0400 Subject: [PATCH] Use -windows-gnu for all UEFI targets This restores the behavior prior to https://github.com/rust-lang/cc-rs/pull/1252, when the UEFI targets were hardcoded in src/lib.rs. --- dev-tools/gen-target-info/src/main.rs | 40 +++++++++++++++++++++++---- src/target/generated.rs | 4 +-- 2 files changed, 37 insertions(+), 7 deletions(-) diff --git a/dev-tools/gen-target-info/src/main.rs b/dev-tools/gen-target-info/src/main.rs index 95f85637..c0c17f28 100644 --- a/dev-tools/gen-target-info/src/main.rs +++ b/dev-tools/gen-target-info/src/main.rs @@ -26,17 +26,47 @@ fn generate_target_mapping(f: &mut File, target_specs: &RustcTargetSpecs) -> std let env = spec.env.as_deref().unwrap_or(""); let abi = spec.abi.as_deref().unwrap_or(""); - // Remove deployment target information from LLVM target triples (we - // will add this in another part of CC). - // - // FIXME(madsmtm): Should become unnecessary after - // https://github.com/rust-lang/rust/pull/131037 let unversioned_llvm_target = if spec.llvm_target.contains("apple") { + // Remove deployment target information from LLVM target triples (we + // will add this in another part of CC). + // + // FIXME(madsmtm): Should become unnecessary after + // https://github.com/rust-lang/rust/pull/131037 let mut components = spec.llvm_target.split("-").collect::>(); components[2] = components[2].trim_end_matches(|c: char| c.is_numeric() || c == '.'); components.join("-") + } else if os == "uefi" { + // Override the UEFI LLVM targets. + // + // The rustc mappings (as of 1.82) for the UEFI targets are: + // * i686-unknown-uefi -> i686-unknown-windows-gnu + // * x86_64-unknown-uefi -> x86_64-unknown-windows + // * aarch64-unknown-uefi -> aarch64-unknown-windows + // + // However, in cc-rs all the UEFI targets use + // -windows-gnu. This has been the case since 2021 [1]. + // * i686-unknown-uefi -> i686-unknown-windows-gnu + // * x86_64-unknown-uefi -> x86_64-unknown-windows-gnu + // * aarch64-unknown-uefi -> aarch64-unknown-windows-gnu + // + // For now, override the UEFI mapping to keep the behavior + // of cc-rs unchanged. + // + // TODO: as discussed in [2], it may be possible to switch + // to new UEFI targets added to clang, and regardless it + // would be good to have consistency between rustc and + // cc-rs. + // + // [1]: https://github.com/rust-lang/cc-rs/pull/623 + // [2]: https://github.com/rust-lang/cc-rs/pull/1264 + let arch = if spec.arch == "x86" { + "i686" + } else { + &spec.arch + }; + format!("{}-unknown-windows-gnu", arch) } else { spec.llvm_target.clone() }; diff --git a/src/target/generated.rs b/src/target/generated.rs index ce3a4b07..973c10f2 100644 --- a/src/target/generated.rs +++ b/src/target/generated.rs @@ -409,7 +409,7 @@ pub(crate) const LIST: &[(&str, TargetInfo<'static>)] = &[ os: "uefi", env: "", abi: "", - unversioned_llvm_target: "aarch64-unknown-windows", + unversioned_llvm_target: "aarch64-unknown-windows-gnu", }, ), ( @@ -3205,7 +3205,7 @@ pub(crate) const LIST: &[(&str, TargetInfo<'static>)] = &[ os: "uefi", env: "", abi: "", - unversioned_llvm_target: "x86_64-unknown-windows", + unversioned_llvm_target: "x86_64-unknown-windows-gnu", }, ), (