diff options
| author | Jakub Beránek <berykubik@gmail.com> | 2025-08-22 21:00:35 +0200 | 
|---|---|---|
| committer | Josh Stone <jistone@redhat.com> | 2025-09-09 09:00:12 -0700 | 
| commit | e52d88dcea305a297136e5fd7b0bb5ee2973d0ef (patch) | |
| tree | 2a5a88b4f09139a50ec83cccb348c1d8674df061 | |
| parent | 5a4a250ffecc8bbe9ec513398e6866ac020dd2a6 (diff) | |
| download | rust-e52d88dcea305a297136e5fd7b0bb5ee2973d0ef.tar.gz rust-e52d88dcea305a297136e5fd7b0bb5ee2973d0ef.zip | |
Ship LLVM tools for the correct target when cross-compiling
(cherry picked from commit c064521cc7fd4d2548bcf30aca2424556c9cf82c)
| -rw-r--r-- | src/bootstrap/src/core/build_steps/compile.rs | 48 | 
1 files changed, 43 insertions, 5 deletions
| diff --git a/src/bootstrap/src/core/build_steps/compile.rs b/src/bootstrap/src/core/build_steps/compile.rs index 48cb4818cd4..30cbcc05c42 100644 --- a/src/bootstrap/src/core/build_steps/compile.rs +++ b/src/bootstrap/src/core/build_steps/compile.rs @@ -2012,14 +2012,52 @@ impl Step for Assemble { if builder.config.llvm_enabled(target_compiler.host) { trace!("target_compiler.host" = ?target_compiler.host, "LLVM enabled"); - let llvm::LlvmResult { host_llvm_config, .. } = - builder.ensure(llvm::Llvm { target: target_compiler.host }); + let target = target_compiler.host; + let llvm::LlvmResult { host_llvm_config, .. } = builder.ensure(llvm::Llvm { target }); if !builder.config.dry_run() && builder.config.llvm_tools_enabled { trace!("LLVM tools enabled"); - let llvm_bin_dir = - command(host_llvm_config).arg("--bindir").run_capture_stdout(builder).stdout(); - let llvm_bin_dir = Path::new(llvm_bin_dir.trim()); + let host_llvm_bin_dir = command(&host_llvm_config) + .arg("--bindir") + .run_capture_stdout(builder) + .stdout() + .trim() + .to_string(); + + let llvm_bin_dir = if target == builder.host_target { + PathBuf::from(host_llvm_bin_dir) + } else { + // If we're cross-compiling, we cannot run the target llvm-config in order to + // figure out where binaries are located. We thus have to guess. + let external_llvm_config = builder + .config + .target_config + .get(&target) + .and_then(|t| t.llvm_config.clone()); + if let Some(external_llvm_config) = external_llvm_config { + // If we have an external LLVM, just hope that the bindir is the directory + // where the LLVM config is located + external_llvm_config.parent().unwrap().to_path_buf() + } else { + // If we have built LLVM locally, then take the path of the host bindir + // relative to its output build directory, and then apply it to the target + // LLVM output build directory. + let host_llvm_out = builder.llvm_out(builder.host_target); + let target_llvm_out = builder.llvm_out(target); + if let Ok(relative_path) = + Path::new(&host_llvm_bin_dir).strip_prefix(host_llvm_out) + { + target_llvm_out.join(relative_path) + } else { + // This is the most desperate option, just replace the host target with + // the actual target in the directory path... + PathBuf::from( + host_llvm_bin_dir + .replace(&*builder.host_target.triple, &target.triple), + ) + } + } + }; // Since we've already built the LLVM tools, install them to the sysroot. // This is the equivalent of installing the `llvm-tools-preview` component via | 
