From 25511edc2ee048f6a4c5aabdc8a0ce9847049560 Mon Sep 17 00:00:00 2001 From: onur-ozkan Date: Mon, 9 Sep 2024 10:40:40 +0300 Subject: [PATCH] Revert "bypass linker configuration and cross target check for specific commands #128871" Signed-off-by: onur-ozkan --- src/bootstrap/src/core/builder.rs | 10 +-------- src/bootstrap/src/utils/cc_detect.rs | 32 ++++++++-------------------- 2 files changed, 10 insertions(+), 32 deletions(-) diff --git a/src/bootstrap/src/core/builder.rs b/src/bootstrap/src/core/builder.rs index 8f7ade7940342..a28b19d33a632 100644 --- a/src/bootstrap/src/core/builder.rs +++ b/src/bootstrap/src/core/builder.rs @@ -2463,15 +2463,7 @@ impl Cargo { cmd_kind: Kind, ) -> Cargo { let mut cargo = builder.cargo(compiler, mode, source_type, target, cmd_kind); - - match cmd_kind { - // No need to configure the target linker for these command types. - Kind::Clean | Kind::Check | Kind::Suggest | Kind::Format | Kind::Setup => {} - _ => { - cargo.configure_linker(builder); - } - } - + cargo.configure_linker(builder); cargo } diff --git a/src/bootstrap/src/utils/cc_detect.rs b/src/bootstrap/src/utils/cc_detect.rs index a2c7ab31df8a5..29e6b74aaceb8 100644 --- a/src/bootstrap/src/utils/cc_detect.rs +++ b/src/bootstrap/src/utils/cc_detect.rs @@ -87,29 +87,15 @@ fn new_cc_build(build: &Build, target: TargetSelection) -> cc::Build { } pub fn find(build: &Build) { - let targets: HashSet<_> = match build.config.cmd { - // We don't need to check cross targets for these commands. - crate::Subcommand::Clean { .. } - | crate::Subcommand::Check { .. } - | crate::Subcommand::Suggest { .. } - | crate::Subcommand::Format { .. } - | crate::Subcommand::Setup { .. } => { - build.hosts.iter().cloned().chain(iter::once(build.build)).collect() - } - - _ => { - // For all targets we're going to need a C compiler for building some shims - // and such as well as for being a linker for Rust code. - build - .targets - .iter() - .chain(&build.hosts) - .cloned() - .chain(iter::once(build.build)) - .collect() - } - }; - + // For all targets we're going to need a C compiler for building some shims + // and such as well as for being a linker for Rust code. + let targets = build + .targets + .iter() + .chain(&build.hosts) + .cloned() + .chain(iter::once(build.build)) + .collect::>(); for target in targets.into_iter() { find_target(build, target); }