- 
                Notifications
    You must be signed in to change notification settings 
- Fork 13.9k
Generalize configuring LLD as the default linker in bootstrap #147626
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
| These commits modify compiler targets. This PR modifies  If appropriate, please update  This PR modifies  If appropriate, please update  | 
| @bors r=jieyouxu | 
Generalize configuring LLD as the default linker in bootstrap Reopen of rust-lang#147157, because apparently bors can't deal with it for some reason. r? `@ghost`
| I copy-pasted the description from the old PR, because that sort of thing tends to be handy when looking through history. | 
| The old PR was rollup=never; should this one be too? | 
| Bors still haven't updated the mergeability status even of this PR.. let's just try to roll it up and see what happens. It might be the only way to merge this, lol. | 
| Do we need to attempt a resync? | 
| It caught up to this PR now, so I don't think so. #147569 is the only approved one right now that doesn't have the mergeability status. | 
Rollup of 6 pull requests Successful merges: - #147514 (repr_transparent_external_private_fields: normalize types during traversal) - #147605 (Add doc links between `{integer}::from_str_radix` and `from_str`) - #147608 (cg_llvm: Use `LLVMDIBuilderCreateGlobalVariableExpression`) - #147623 (Clear `ChunkedBitSet` without reallocating) - #147625 (Add a warning when running tests with the GCC backend and debug assertions are enabled) - #147626 (Generalize configuring LLD as the default linker in bootstrap) r? `@ghost` `@rustbot` modify labels: rollup
| You're asking questions no one knows the answer to 😆 If it gets stuck at the top of the queue, I'd consider closing that PR and reopening it again. | 
| bors is working on it 😆 | 
| FYI, we started to see failures with our internal Arm64EC validation pipeline after this PR was merged: 
 For context, this is how we are configuring and running the build (via an Arm64 VS PowerShell):       &python .\src\bootstrap\configure.py `
        --set 'build.build-dir=build.stage0' `
        --set 'build.submodules=false' `
        --set 'llvm.download-ci-llvm=false' `
        --set 'llvm.targets=AArch64' `
        --set 'llvm.experimental-targets=' `
        --set 'llvm.link-jobs=8'
      if (!$?) { exit $LASTEXITCODE }
      &python .\x.py build `
        --stage 2 `
        --build aarch64-pc-windows-msvc `
        --host arm64ec-pc-windows-msvc `
        --target arm64ec-pc-windows-msvc `
        compiler cargo library/std rustfmt clippy rustdoc
      if (!$?) { exit $LASTEXITCODE } | 
| Could you please share your whole  | 
| We don't have a checked-in bootstrap.toml, we just run configure and use that. | 
| Ah, crap, I see the problem. LLD is enabled globally, but the override is configured per target. So if at least a single target opts into LLD, then  | 
| Opened #147698. | 
Do not enable LLD if we don't build host code for targets that opt into it Should fix the problem mentioned in #147626 (comment). r? `@jieyouxu`
Do not enable LLD if we don't build host code for targets that opt into it Should fix the problem mentioned in #147626 (comment). r? `@jieyouxu`
Do not enable LLD if we don't build host code for targets that opt into it Should fix the problem mentioned in rust-lang/rust#147626 (comment). r? `@jieyouxu`
Reopen of #147157, because apparently bors can't deal with it for some reason.
This PR generalizes the previous hardcoded logic for setting self-contained LLD to be used as the default Linker on Linux GNU targets. The changes made:
rust.lldnow only controls whether LLD is built and included in the sysroot. Ifrust.lldis set tofalse, it will disable the default opt into LLD on x64 Linux.rust-lldthroughcccan now be applied to all Linux targets. It is configured throughtarget.<target>.default-linker-linux-override = "self-contained-lld-cc"/"off"Here is how it behaves:
default-linker-linux-override = "self-contained-lld-cc"and alsorust.lld = true.rust.lld = false, you disable this overridetarget.x86_64-unknown-linux-gnu.default-linux-linker-override = "off", you disable this overridetarget.x86_64-unknown-linux-gnu.llvm-config = ..., you disable this overrideNote that in contrast to what I described in #146640, I didn't bother moving
rust.lldtollvm.lld. We can do that separately later, but I don't think it's worth the churn. I realized thatrustis perhaps a better place for this, because it not only controls whether LLD is built, but also if it is included in the compiler sysroot. So to truly distinguish these two, we'd need bothllvm.lldandrust.lld, which doesn't seem worth it. Note thatrust.codegen-backends = ["llvm"]works in the same way, it tells bootstrap to build LLVM and include it in the sysroot. So it is consistent withrust.lldRelated to: #146640
r? @ghost