Merge pull request #173034 from Mic92/nix-ld

nix-ld: 1.0.0 -> 1.0.2
main
Thiago Kenji Okada 2 years ago committed by GitHub
commit 1dc9931937
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 4
      nixos/modules/programs/nix-ld.nix
  2. 2
      nixos/tests/nix-ld.nix
  3. 101
      pkgs/os-specific/linux/nix-ld/default.nix

@ -5,8 +5,6 @@
programs.nix-ld.enable = lib.mkEnableOption ''nix-ld, Documentation: <link xlink:href="https://github.com/Mic92/nix-ld"/>''; programs.nix-ld.enable = lib.mkEnableOption ''nix-ld, Documentation: <link xlink:href="https://github.com/Mic92/nix-ld"/>'';
}; };
config = lib.mkIf config.programs.nix-ld.enable { config = lib.mkIf config.programs.nix-ld.enable {
systemd.tmpfiles.rules = [ systemd.tmpfiles.packages = [ pkgs.nix-ld ];
"L+ ${pkgs.nix-ld.ldPath} - - - - ${pkgs.nix-ld}/libexec/nix-ld"
];
}; };
} }

@ -6,7 +6,7 @@ import ./make-test-python.nix ({ lib, pkgs, ...} :
environment.systemPackages = [ environment.systemPackages = [
(pkgs.runCommand "patched-hello" {} '' (pkgs.runCommand "patched-hello" {} ''
install -D -m755 ${pkgs.hello}/bin/hello $out/bin/hello install -D -m755 ${pkgs.hello}/bin/hello $out/bin/hello
patchelf $out/bin/hello --set-interpreter ${pkgs.nix-ld.ldPath} patchelf $out/bin/hello --set-interpreter $(cat ${pkgs.nix-ld}/nix-support/ldpath)
'') '')
]; ];
}; };

@ -1,49 +1,56 @@
{ stdenv, meson, ninja, lib, nixosTests, fetchFromGitHub }: { lib
, stdenv
, fetchFromGitHub
, meson
, ninja
, nixosTests
}:
let let
self = stdenv.mkDerivation { libDir = if builtins.elem stdenv.system [ "x86_64-linux" "mips64-linux" "powerpc64le-linux" ]
name = "nix-ld"; then "/lib64"
src = fetchFromGitHub { else "/lib";
owner = "Mic92"; in
repo = "nix-ld"; stdenv.mkDerivation rec {
rev = "1.0.0"; pname = "nix-ld";
sha256 = "sha256-QYPg8wPpq7q5Xd1jW17Lh36iKFSsVkN/gWYoQRv2XoU="; version = "1.0.2";
};
src = fetchFromGitHub {
doCheck = true; owner = "mic92";
repo = "nix-ld";
nativeBuildInputs = [ meson ninja ]; rev = version;
sha256 = "sha256-DlWU5i/MykqWgB9vstYbECy3e+XagXWCxi+XDJNey0s=";
mesonFlags = [ };
"-Dnix-system=${stdenv.system}"
]; doCheck = true;
hardeningDisable = [ nativeBuildInputs = [ meson ninja ];
"stackprotector"
]; mesonFlags = [
"-Dnix-system=${stdenv.system}"
postInstall = '' ];
mkdir -p $out/nix-support
basename $(< ${stdenv.cc}/nix-support/dynamic-linker) > $out/nix-support/ld-name hardeningDisable = [
''; "stackprotector"
];
passthru.tests.nix-ld = nixosTests.nix-ld;
passthru.ldPath = let postInstall = ''
libDir = if stdenv.system == "x86_64-linux" || mkdir -p $out/nix-support
stdenv.system == "mips64-linux" ||
stdenv.system == "powerpc64le-linux" ldpath=${libDir}/$(basename $(< ${stdenv.cc}/nix-support/dynamic-linker))
then echo "$ldpath" > $out/nix-support/ldpath
"/lib64" mkdir -p $out/lib/tmpfiles.d/
else cat > $out/lib/tmpfiles.d/nix-ld.conf <<EOF
"/lib"; L+ $ldpath - - - - $out/libexec/nix-ld
ldName = lib.fileContents "${self}/nix-support/ld-name"; EOF
in "${libDir}/${ldName}"; '';
meta = with lib; { passthru.tests.nix-ld = nixosTests.nix-ld;
description = "Run unpatched dynamic binaries on NixOS";
homepage = "https://github.com/Mic92/nix-ld"; meta = with lib; {
license = licenses.mit; description = "Run unpatched dynamic binaries on NixOS";
maintainers = with maintainers; [ mic92 ]; homepage = "https://github.com/Mic92/nix-ld";
platforms = platforms.linux; license = licenses.mit;
}; maintainers = with maintainers; [ mic92 ];
platforms = platforms.unix;
}; };
in self }

Loading…
Cancel
Save