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

Remove wrapper scripts from musl causing a glibc dependency #106940

Closed
wants to merge 1 commit into from

Conversation

teburd
Copy link
Contributor

@teburd teburd commented Dec 15, 2020

Requiring bash here meant requiring glibc

No one wants glibc with their musl

@ofborg ofborg bot requested review from dtzWill and thoughtpolice December 15, 2020 03:24
@ofborg ofborg bot added 10.rebuild-darwin: 0 This PR does not cause any packages to rebuild on Darwin 10.rebuild-linux: 11-100 labels Dec 15, 2020
Requiring bash here meant requiring glibc

No one wants glibc with their musl
@r-burns
Copy link
Contributor

r-burns commented Dec 15, 2020

How about moving them to a separate output, such as bin? Then they'll still be available if needed but will typically be excluded from dependers' closures.

@symphorien
Copy link
Member

I don't think musl-gcc and the like are spurious junk we can just get rid of.
If you want pure musl packages, use pkgsMusl instead.

@teburd
Copy link
Contributor Author

teburd commented Dec 15, 2020

Fixes #75476 for me

@teburd
Copy link
Contributor Author

teburd commented Dec 15, 2020

@symphorien can you show how you'd get a pure musl package without glibc given the sample project in #75476 without this change?

@teburd
Copy link
Contributor Author

teburd commented Dec 15, 2020

@r-burns possibly a decent solution, I'll see if I can't split it off. Ideally though the musl scripts would use a bash built against musl, but that seems impossible without moving the scripts to their own derivation? I'm still new-ish to writing nix but hard to see how it'd be possible otherwise.

@symphorien
Copy link
Member

@symphorien can you show how you'd get a pure musl package without glibc given the sample project in #75476 without this change?

let
  musl = (import <nixpkgs/lib>).systems.examples.musl64;
  musl-pkgs = (import <nixpkgs> {}).pkgsMusl;

  host-pkgs = import <nixpkgs> {};

  build = pkgs:
    let
      inherit (pkgs) stdenv;
    in
    stdenv.mkDerivation {
      name = "hello";
      src = ./.;

      buildPhase = ''
        $CXX hello.cc
      '';

      installPhase = ''
        mkdir -p $out/bin
        cp a.out $out/bin
      '';
    };
in
  {
    host = build host-pkgs;
    musl = build musl-pkgs;
  }
$  nix-build -A musl
these derivations will be built:
  /nix/store/3jkmx2gz2ps8q7hf2y1svxfy3jvn0ms9-hello.drv
building '/nix/store/3jkmx2gz2ps8q7hf2y1svxfy3jvn0ms9-hello.drv'...
unpacking sources
unpacking source archive /nix/store/6wqpdbiyk98q0s8ipgmdv286515d7v97-foo
source root is foo
patching sources
updateAutotoolsGnuConfigScriptsPhase
configuring
no configure script, doing nothing
building
installing
post-installation fixup
shrinking RPATHs of ELF executables and libraries in /nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello
shrinking /nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello/bin/a.out
strip is /nix/store/cdbsfljc8m900axs37fab7gnp2y1dksn-binutils-2.31.1/bin/strip
stripping (with command strip and flags -S) in /nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello/bin
patching script interpreter paths in /nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello
checking for references to /build/ in /nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello...
/nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello
                                                                                                                                                                                              

$  nix-store -qR result
/nix/store/dl4gwchzfl6gxaf8xgvrva29k9m2zk77-musl-1.2.0
/nix/store/78iyhz8ci6vdqzybf1bl9kbs45w2bv94-gcc-9.3.0-lib
/nix/store/bnd7srs7x7h81574q5drnsvnmqrf5yxb-hello

As I said, if you want a pure musl artifact, the most direct solution is to use a pure musl toolchain, that is pkgsMusl.

Anyway, I think removing musl-gcc is a regression and thus not an acceptable solution.

@teburd
Copy link
Contributor Author

teburd commented Dec 15, 2020

@symphorien fair enough, I didn't like it either to be quite honest, but was confused entirely by the musl -> bash -> glibc dep chain going on, which seems... wrong. Even if you do depend on the musl-dev shouldn't that avoid relying on glibc as it may inherently blow up closure size in some cases where the -dev related stuff is needed still?

My ultimate goal with this work is to be able to cross compile, with musl, to multiple target archs as well so I'm not sure if that changes the outcome here

@symphorien
Copy link
Member

If you insist on cross compiling and not having glibc in the build-platform compiler, then you should cross compile from a musl build platform. Untested, but pkgsMusl.pkgsCross might do that.

@teburd
Copy link
Contributor Author

teburd commented Dec 16, 2020

I do think -dev shouldn't depend on bash and glibc by default, but I agree with comments that removing the scripts isn't the right path. Closing

@teburd teburd closed this Dec 16, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
10.rebuild-darwin: 0 This PR does not cause any packages to rebuild on Darwin 10.rebuild-linux: 11-100
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants