mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 06:44:35 +00:00
bootstrap: include llvm-objcopy
in dist
This commit is contained in:
parent
27e38f8fc7
commit
d8ab230e73
@ -219,8 +219,7 @@ impl Step for Std {
|
||||
.join(compiler.host)
|
||||
.join("bin");
|
||||
if src_sysroot_bin.exists() {
|
||||
let target_sysroot_bin =
|
||||
builder.sysroot_target_libdir(compiler, target).parent().unwrap().join("bin");
|
||||
let target_sysroot_bin = builder.sysroot_target_bindir(compiler, target);
|
||||
t!(fs::create_dir_all(&target_sysroot_bin));
|
||||
builder.cp_link_r(&src_sysroot_bin, &target_sysroot_bin);
|
||||
}
|
||||
@ -1977,6 +1976,14 @@ impl Step for Assemble {
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
// `llvm-strip` is used by rustc, which is actually just a symlink to `llvm-objcopy`,
|
||||
// so copy and rename `llvm-objcopy`.
|
||||
let src_exe = exe("llvm-objcopy", target_compiler.host);
|
||||
let dst_exe = exe("rust-objcopy", target_compiler.host);
|
||||
builder.copy_link(&libdir_bin.join(src_exe), &libdir_bin.join(dst_exe));
|
||||
}
|
||||
|
||||
// In addition to `rust-lld` also install `wasm-component-ld` when
|
||||
// LLD is enabled. This is a relatively small binary that primarily
|
||||
// delegates to the `rust-lld` binary for linking and then runs
|
||||
|
@ -459,8 +459,7 @@ impl Step for Rustc {
|
||||
|
||||
// Copy over lld if it's there
|
||||
if builder.config.lld_enabled {
|
||||
let src_dir =
|
||||
builder.sysroot_target_libdir(compiler, host).parent().unwrap().join("bin");
|
||||
let src_dir = builder.sysroot_target_bindir(compiler, host);
|
||||
let rust_lld = exe("rust-lld", compiler.host);
|
||||
builder.copy_link(&src_dir.join(&rust_lld), &dst_dir.join(&rust_lld));
|
||||
let self_contained_lld_src_dir = src_dir.join("gcc-ld");
|
||||
@ -474,9 +473,16 @@ impl Step for Rustc {
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
{
|
||||
let src_dir = builder.sysroot_target_bindir(compiler, host);
|
||||
let llvm_objcopy = exe("llvm-objcopy", compiler.host);
|
||||
let rust_objcopy = exe("rust-objcopy", compiler.host);
|
||||
builder.copy_link(&src_dir.join(&llvm_objcopy), &dst_dir.join(&rust_objcopy));
|
||||
}
|
||||
|
||||
if builder.tool_enabled("wasm-component-ld") {
|
||||
let src_dir =
|
||||
builder.sysroot_target_libdir(compiler, host).parent().unwrap().join("bin");
|
||||
let src_dir = builder.sysroot_target_bindir(compiler, host);
|
||||
let ld = exe("wasm-component-ld", compiler.host);
|
||||
builder.copy_link(&src_dir.join(&ld), &dst_dir.join(&ld));
|
||||
}
|
||||
|
@ -1161,6 +1161,11 @@ impl<'a> Builder<'a> {
|
||||
self.ensure(compile::Sysroot::new(compiler))
|
||||
}
|
||||
|
||||
/// Returns the bindir for a compiler's sysroot.
|
||||
pub fn sysroot_target_bindir(&self, compiler: Compiler, target: TargetSelection) -> PathBuf {
|
||||
self.sysroot_target_libdir(compiler, target).parent().unwrap().join("bin")
|
||||
}
|
||||
|
||||
/// Returns the libdir where the standard library and other artifacts are
|
||||
/// found for a compiler's sysroot.
|
||||
pub fn sysroot_target_libdir(&self, compiler: Compiler, target: TargetSelection) -> PathBuf {
|
||||
|
Loading…
Reference in New Issue
Block a user