-
-
Notifications
You must be signed in to change notification settings - Fork 14.7k
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
linux: allow building with ld.lld (for LTO) #344665
Conversation
Full build failure log is here: I'm not quite sure what is failing. Will continue looking into it. |
a1800a7
to
4a1ff2b
Compare
|
Looks like that should be using the binutils wrapper and not the clang wrapper. |
Ah, |
There should be a strip in bintools:
(I'm assuming llvm-objcopy must be multi-call or something for it to be the target of the link.) |
Only
There is also a |
Want to fix it then? |
Yes, will open a different PR for this given that it's not a requirement for this one. The build goes further now:
We're getting closer. |
I've opened #345691 for the strip issue. |
So I've narrowed down the build issue to the compiler/bintools wrappers. If I use the unwrapped toolchain for building (the last XXX commit), the build succeeds. I'm currently debugging what the wrappers do that causes this problem. I wish there were a flag to turn the wrapper magic off for cases like these... |
You have ran into #321667 if you're on x86_64-linux. |
Thanks for the pointer! But why would the kernel need patching, if it builds fine with the unwrapped toolchain? It seems like we do something weird in our wrapping logic. |
Our wrapper does invoke a behavior of LLVM which GNU ld doesn't have. GNU ld has some logic to not link with dynamic libraries when necessary. LLVM ld doesn't have this behavior. I did start some work in the wrapper to implement the same GNU ld behavior but I just haven't allocated enough time into this problem. I did however open an issue in LLVM itself to see about getting this behavior implemented. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Everything LGTM
I'm testing this locally now, but I don't understand why we need absolute paths for anything apart from the linker on x86_64. A comment mentions PATH clobbering issues, but what path clobbering issues? Have we ever seen any? |
I'm also wondering whether LD etc would be better set as environment variables in stdenv. Would you be interested in exploring that as followup? It would likely fix other packages with similar problems. |
The problem it refers to seems to be that |
I can look into this. I see a couple of packages that use |
But they're not going to be autodetected if we're explicitly setting them to the prefixed versions? |
For CC this is already done by stdenv. I was just talking about e.g. LD, for consistency. |
I looked into this and we don't have to set them at all! We only need to set I'm currently compiling some kernels, but so far it looks good. Testing is welcome! @alyssais If this approach works out, I'll squash the commits. |
@RossComputerGuy Can you also check how this version looks for you? If this works, it would remove quite a bit of clutter from the derivations. |
@alyssais @RossComputerGuy Do you have any input how to move this forward? |
Do you think it's ready? It looks fine to me with a squash. |
I think it's fine. |
I've rebased this and squashed the ld wrapper fixup. The other commits are reasonably self-sufficient. In case there are issues with 7ccb461, it could also be reverted individually without breaking functionality. I'm going to give this another nixpkgs-review round. |
Result of 430 packages marked as broken and skipped:
175 packages failed to build:
2551 packages built:
|
The failed kernel modules seem unrelated. But maybe has a better overview of what's supposed to fail? What's our policy here? Does it make sense to mark them broken in another PR? |
Yeah. It's just that it needs investigation of what conditions cause them to fail to build, so having them marked broken properly requires somebody to put in the time to do that investigation. |
Even when building with pkgsLLVM.stdenv where ld is ld.lld and not binutils ld, the build picks up binutils ld for linking. This prevents features from working that require ld.lld. The reason is that when the LD environment variable is not set, Linux defaults to `ld` as a linker and ld is: /nix/store/zznja5f8v3jafffyah1rk46vpfcn38dv-gcc-wrapper-13.3.0/bin/ld GNU ld (GNU Binutils) 2.42 This ld comes from pkgsLLVM.buildPackages.stdenv.cc. Fix by being more specific about which tools we want to build with. This just extends what manual-config.nix has already done for quite a while to avoid similar problems for other tools. It's important to pass LD and other toolchain environment variables to `make config` in generate-config.pl, because otherwise `make config` will also make decisions based on the wrong toolchain.
When we set CROSS_COMPILE to set the toolchain prefix, everything works out of the box without using absolute paths everywhere. This removes a lot of duplication from the kernel derivations.
Result of 474 packages marked as broken and skipped:
228 packages failed to build:
2616 packages built:
|
Even when building the Linux kernel with a
stdenv
where the linker isld.lld
instead of binutilsld
, the build picks up binutilsld
for linking. This prevents features that requireld.lld
from working, such as LTO.Fix by being more specific about which tools we want to build with. This extends what manual-config.nix has already done for quite a while.
I've used the following to get
ld.ldd
as linker:Things left to be done
make config
recognizes the right linkernix-build clang-kernel.nix -A linux_llvm
currently fails:Things done
nix.conf
? (See Nix manual)sandbox = relaxed
sandbox = true
nix-shell -p nixpkgs-review --run "nixpkgs-review rev HEAD"
. Note: all changes have to be committed, also see nixpkgs-review usage./result/bin/
)Add a 👍 reaction to pull requests you find important.