llvmPackages_{12,13,14,15,16,17,18,git}: use common lld

Changed files
+113 -462
pkgs
+5 -1
pkgs/development/compilers/llvm/12/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
src = fetch "lld" "0qg3fgc7wj34hdkqn21y03zcmsdd01szhhm1hfki63iifrm3y2v9";
+
patches = [
+
./lld/gnu-install-dirs.patch
+
];
inherit llvm_meta;
inherit (libraries) libunwind;
};
-54
pkgs/development/compilers/llvm/12/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, fetch
-
, libunwind
-
, cmake
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
src = fetch pname "0qg3fgc7wj34hdkqn21y03zcmsdd01szhhm1hfki63iifrm3y2v9";
-
-
patches = [
-
./gnu-install-dirs.patch
-
];
-
-
postPatch = ''
-
substituteInPlace MachO/CMakeLists.txt --replace \
-
'(''${LLVM_MAIN_SRC_DIR}/' '('
-
mkdir -p libunwind/include
-
tar -xf "${libunwind.src}" --wildcards -C libunwind/include --strip-components=2 "libunwind-*/include/"
-
'';
-
-
nativeBuildInputs = [ cmake ];
-
buildInputs = [ libllvm libxml2 ];
-
-
cmakeFlags = [
-
"-DLLVM_CONFIG_PATH=${libllvm.dev}/bin/llvm-config${lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) "-native"}"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+4 -1
pkgs/development/compilers/llvm/13/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
];
inherit llvm_meta;
};
-55
pkgs/development/compilers/llvm/13/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, src
-
, cmake
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
inherit src;
-
sourceRoot = "${src.name}/${pname}";
-
-
patches = [
-
./gnu-install-dirs.patch
-
];
-
-
# On Darwin the llvm-config is perhaps not working fine as the
-
# LLVM_MAIN_SRC_DIR is not getting set correctly, and the build fails as the
-
# include path is not correct.
-
postPatch = lib.optionalString stdenv.isDarwin ''
-
substituteInPlace MachO/CMakeLists.txt --replace \
-
'(''${LLVM_MAIN_SRC_DIR}/' '(../'
-
'';
-
-
nativeBuildInputs = [ cmake ];
-
buildInputs = [ libllvm libxml2 ];
-
-
cmakeFlags = [
-
"-DLLVM_CONFIG_PATH=${libllvm.dev}/bin/llvm-config${lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) "-native"}"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+5 -1
pkgs/development/compilers/llvm/14/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
./lld/fix-root-src-dir.patch
+
];
inherit llvm_meta;
};
-58
pkgs/development/compilers/llvm/14/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, monorepoSrc, runCommand
-
, cmake
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
# Blank llvm dir just so relative path works
-
src = runCommand "${pname}-src-${version}" {} ''
-
mkdir -p "$out"
-
cp -r ${monorepoSrc}/cmake "$out"
-
cp -r ${monorepoSrc}/${pname} "$out"
-
mkdir -p "$out/libunwind"
-
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
-
mkdir -p "$out/llvm"
-
'';
-
-
sourceRoot = "${src.name}/${pname}";
-
-
patches = [
-
./gnu-install-dirs.patch
-
# On Darwin the llvm-config is perhaps not working fine as the
-
# LLVM_MAIN_SRC_DIR is not getting set correctly, and the build fails as
-
# the include path is not correct.
-
./fix-root-src-dir.patch
-
];
-
-
nativeBuildInputs = [ cmake ];
-
buildInputs = [ libllvm libxml2 ];
-
-
cmakeFlags = lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+4 -1
pkgs/development/compilers/llvm/15/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
];
inherit llvm_meta;
};
-57
pkgs/development/compilers/llvm/15/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, monorepoSrc, runCommand
-
, cmake
-
, ninja
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
# Blank llvm dir just so relative path works
-
src = runCommand "${pname}-src-${version}" {} ''
-
mkdir -p "$out"
-
cp -r ${monorepoSrc}/cmake "$out"
-
cp -r ${monorepoSrc}/${pname} "$out"
-
mkdir -p "$out/libunwind"
-
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
-
mkdir -p "$out/llvm"
-
'';
-
-
sourceRoot = "${src.name}/${pname}";
-
-
patches = [
-
./gnu-install-dirs.patch
-
];
-
-
nativeBuildInputs = [ cmake ninja ];
-
buildInputs = [ libllvm libxml2 ];
-
-
cmakeFlags = [
-
"-DLLD_INSTALL_PACKAGE_DIR=${placeholder "dev"}/lib/cmake/lld"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+5 -1
pkgs/development/compilers/llvm/16/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
./lld/add-table-base.patch
+
];
inherit llvm_meta;
};
-58
pkgs/development/compilers/llvm/16/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, monorepoSrc, runCommand
-
, cmake
-
, ninja
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
# Blank llvm dir just so relative path works
-
src = runCommand "${pname}-src-${version}" {} ''
-
mkdir -p "$out"
-
cp -r ${monorepoSrc}/cmake "$out"
-
cp -r ${monorepoSrc}/${pname} "$out"
-
mkdir -p "$out/libunwind"
-
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
-
mkdir -p "$out/llvm"
-
'';
-
-
sourceRoot = "${src.name}/${pname}";
-
-
patches = [
-
./gnu-install-dirs.patch
-
./add-table-base.patch
-
];
-
-
nativeBuildInputs = [ cmake ninja ];
-
buildInputs = [ libllvm libxml2 ];
-
-
cmakeFlags = [
-
"-DLLD_INSTALL_PACKAGE_DIR=${placeholder "dev"}/lib/cmake/lld"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+5 -1
pkgs/development/compilers/llvm/17/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
./lld/add-table-base.patch
+
];
inherit llvm_meta;
};
-58
pkgs/development/compilers/llvm/17/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, monorepoSrc, runCommand
-
, cmake
-
, ninja
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
# Blank llvm dir just so relative path works
-
src = runCommand "${pname}-src-${version}" {} ''
-
mkdir -p "$out"
-
cp -r ${monorepoSrc}/cmake "$out"
-
cp -r ${monorepoSrc}/${pname} "$out"
-
mkdir -p "$out/libunwind"
-
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
-
mkdir -p "$out/llvm"
-
'';
-
-
sourceRoot = "${src.name}/${pname}";
-
-
patches = [
-
./gnu-install-dirs.patch
-
./add-table-base.patch
-
];
-
-
nativeBuildInputs = [ cmake ninja ];
-
buildInputs = [ libllvm libxml2 ];
-
-
cmakeFlags = [
-
"-DLLD_INSTALL_PACKAGE_DIR=${placeholder "dev"}/lib/cmake/lld"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+4 -1
pkgs/development/compilers/llvm/18/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
];
inherit llvm_meta;
};
-57
pkgs/development/compilers/llvm/18/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, monorepoSrc, runCommand
-
, cmake
-
, ninja
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
# Blank llvm dir just so relative path works
-
src = runCommand "${pname}-src-${version}" {} ''
-
mkdir -p "$out"
-
cp -r ${monorepoSrc}/cmake "$out"
-
cp -r ${monorepoSrc}/${pname} "$out"
-
mkdir -p "$out/libunwind"
-
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
-
mkdir -p "$out/llvm"
-
'';
-
-
sourceRoot = "${src.name}/${pname}";
-
-
nativeBuildInputs = [ cmake ninja ];
-
buildInputs = [ libllvm libxml2 ];
-
-
patches = [
-
./gnu-install-dirs.patch
-
];
-
-
cmakeFlags = [
-
"-DLLD_INSTALL_PACKAGE_DIR=${placeholder "dev"}/lib/cmake/lld"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}
+77
pkgs/development/compilers/llvm/common/lld/default.nix
···
+
{ lib
+
, stdenv
+
, llvm_meta
+
, release_version
+
, patches ? []
+
, buildLlvmTools
+
, monorepoSrc ? null
+
, src ? null
+
, libunwind ? null
+
, runCommand
+
, cmake
+
, ninja
+
, libxml2
+
, libllvm
+
, version
+
}:
+
let
+
pname = "lld";
+
src' =
+
if monorepoSrc != null then
+
runCommand "lld-src-${version}" {} ''
+
mkdir -p "$out"
+
cp -r ${monorepoSrc}/cmake "$out"
+
cp -r ${monorepoSrc}/${pname} "$out"
+
mkdir -p "$out/libunwind"
+
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
+
mkdir -p "$out/llvm"
+
'' else src;
+
+
postPatch = lib.optionalString (lib.versions.major release_version == "12") ''
+
substituteInPlace MachO/CMakeLists.txt --replace \
+
'(''${LLVM_MAIN_SRC_DIR}/' '('
+
mkdir -p libunwind/include
+
tar -xf "${libunwind.src}" --wildcards -C libunwind/include --strip-components=2 "libunwind-*/include/"
+
'' + lib.optionalString (lib.versions.major release_version == "13" && stdenv.isDarwin) ''
+
substituteInPlace MachO/CMakeLists.txt --replace \
+
'(''${LLVM_MAIN_SRC_DIR}/' '(../'
+
'';
+
in
+
stdenv.mkDerivation (rec {
+
inherit pname version patches;
+
+
src = src';
+
+
sourceRoot =
+
if lib.versionOlder release_version "13" then null
+
else "${src.name}/${pname}";
+
+
nativeBuildInputs = [ cmake ] ++ lib.optional (lib.versionAtLeast release_version "15") ninja;
+
buildInputs = [ libllvm libxml2 ];
+
+
cmakeFlags = lib.optionals (lib.versionOlder release_version "14") [
+
"-DLLVM_CONFIG_PATH=${libllvm.dev}/bin/llvm-config${lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) "-native"}"
+
] ++ lib.optionals (lib.versionAtLeast release_version "15") [
+
"-DLLD_INSTALL_PACKAGE_DIR=${placeholder "dev"}/lib/cmake/lld"
+
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
+
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
+
];
+
+
# Musl's default stack size is too small for lld to be able to link Firefox.
+
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
+
+
outputs = [ "out" "lib" "dev" ];
+
+
meta = llvm_meta // {
+
homepage = "https://lld.llvm.org/";
+
description = "The LLVM linker (unwrapped)";
+
longDescription = ''
+
LLD is a linker from the LLVM project that is a drop-in replacement for
+
system linkers and runs much faster than them. It also provides features
+
that are useful for toolchain developers.
+
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
+
WebAssembly in descending order of completeness. Internally, LLD consists
+
of several different linkers.
+
'';
+
};
+
} // (if (postPatch == "" && lib.versions.major release_version != "13") then {} else { inherit postPatch; }))
+4 -1
pkgs/development/compilers/llvm/git/default.nix
···
extraBuildCommands = mkExtraBuildCommands cc;
};
-
lld = callPackage ./lld {
+
lld = callPackage ../common/lld {
+
patches = [
+
./lld/gnu-install-dirs.patch
+
];
inherit llvm_meta;
};
-57
pkgs/development/compilers/llvm/git/lld/default.nix
···
-
{ lib, stdenv, llvm_meta
-
, buildLlvmTools
-
, monorepoSrc, runCommand
-
, cmake
-
, ninja
-
, libxml2
-
, libllvm
-
, version
-
}:
-
-
stdenv.mkDerivation rec {
-
pname = "lld";
-
inherit version;
-
-
# Blank llvm dir just so relative path works
-
src = runCommand "${pname}-src-${version}" {} ''
-
mkdir -p "$out"
-
cp -r ${monorepoSrc}/cmake "$out"
-
cp -r ${monorepoSrc}/${pname} "$out"
-
mkdir -p "$out/libunwind"
-
cp -r ${monorepoSrc}/libunwind/include "$out/libunwind"
-
mkdir -p "$out/llvm"
-
'';
-
-
sourceRoot = "${src.name}/${pname}";
-
-
nativeBuildInputs = [ cmake ninja ];
-
buildInputs = [ libllvm libxml2 ];
-
-
patches = [
-
./gnu-install-dirs.patch
-
];
-
-
cmakeFlags = [
-
"-DLLD_INSTALL_PACKAGE_DIR=${placeholder "dev"}/lib/cmake/lld"
-
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
-
"-DLLVM_TABLEGEN_EXE=${buildLlvmTools.llvm}/bin/llvm-tblgen"
-
];
-
-
# Musl's default stack size is too small for lld to be able to link Firefox.
-
LDFLAGS = lib.optionalString stdenv.hostPlatform.isMusl "-Wl,-z,stack-size=2097152";
-
-
outputs = [ "out" "lib" "dev" ];
-
-
meta = llvm_meta // {
-
homepage = "https://lld.llvm.org/";
-
description = "The LLVM linker (unwrapped)";
-
longDescription = ''
-
LLD is a linker from the LLVM project that is a drop-in replacement for
-
system linkers and runs much faster than them. It also provides features
-
that are useful for toolchain developers.
-
The linker supports ELF (Unix), PE/COFF (Windows), Mach-O (macOS), and
-
WebAssembly in descending order of completeness. Internally, LLD consists
-
of several different linkers.
-
'';
-
};
-
}