Skip to content
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

cctools-llvm: init at 11.1.0-973.0.1 #234859

Merged
merged 1 commit into from
Jun 8, 2023
Merged

Commits on Jun 6, 2023

  1. cctools-llvm: init at 11.1.0-973.0.1

    cctools-llvm is a replacement for cctools that replaces as much of cctools with equivalents from LLVM that it can reasonably do. This was motivated by wanting to reduce dependencies on cctools, which are updated infrequently by upstream.
    
    To provide a motivating example, the version of `strip` included in cctools cannot properly strip the archives in compiler-rt in LLVM 15. Paths are left to bootstrap tools, resulting in failed requisites checks in the final stdenv build. Since `strip` needs replaced, the opportunity was taken to replace other provided they are functional replacements.
    
    Note: This has to be done in cctools (or some equivalent) because some derivations (noteably LLVM) use the bintools of the stdenv directly instead of going through the wrapper.
    
    The following tools from LLVM are not used in this derivation:
    
    * LLD - not fully compatible with ld64 yet and potentially too big of a change;
    * libtool - not a drop-in replacement yet because it does not support linker passthrough, which is needed by xcbuild;
    * lipo - crashes when running the LLVM test suite;
    * install_name_tool - fails when trying to build swift-corefoundation; and.
    * randlib - not completely a drop-in replacement, so leaving it out for now.
    
    If other incompatabilities are found, the tools can be reverted or made conditional. For example, cctools `strip` is preferred on older versions of LLVM (which lack the compiler-rt issue) or when cctools itself is a new enough version because `llvm-strip` on LLVM 11 produces files that older verions of `codesign_allocate` cannot process correctly.
    
    One final caveat/note: Some tools are not duplicated or linked from cctools-port. The names of the tools and which ones were linked was determined based on what is provided upstream in Xcode and is installed on macOS system.
    reckenrode committed Jun 6, 2023
    Configuration menu
    Copy the full SHA
    df7487f View commit details
    Browse the repository at this point in the history