0ae1182489
I expect to soon give it some patches that would go in there too, but either way it's good to match the others.
196 lines
6.4 KiB
Nix
196 lines
6.4 KiB
Nix
{ lowPrio, newScope, pkgs, lib, stdenv, cmake, gccForLibs
|
||
, libxml2, python3, isl, fetchurl, overrideCC, wrapCCWith, wrapBintoolsWith
|
||
, buildPackages
|
||
, buildLlvmTools # tools, but from the previous stage, for cross
|
||
, targetLlvmLibraries # libraries, but from the next stage, for cross
|
||
}:
|
||
|
||
let
|
||
release_version = "8.0.1";
|
||
version = release_version; # differentiating these is important for rc's
|
||
targetConfig = stdenv.targetPlatform.config;
|
||
|
||
fetch = name: sha256: fetchurl {
|
||
url = "https://github.com/llvm/llvm-project/releases/download/llvmorg-${release_version}/${name}-${version}.src.tar.xz";
|
||
inherit sha256;
|
||
};
|
||
|
||
clang-tools-extra_src = fetch "clang-tools-extra" "1qf3097bc5ia8p6cpmbx985rjr3yaah5s8fc0nv7pw742yv7jw8q";
|
||
|
||
tools = lib.makeExtensible (tools: let
|
||
callPackage = newScope (tools // { inherit stdenv cmake libxml2 python3 isl release_version version fetch; });
|
||
mkExtraBuildCommands = cc: ''
|
||
rsrc="$out/resource-root"
|
||
mkdir "$rsrc"
|
||
ln -s "${cc}/lib/clang/${release_version}/include" "$rsrc"
|
||
ln -s "${targetLlvmLibraries.compiler-rt.out}/lib" "$rsrc/lib"
|
||
echo "-resource-dir=$rsrc" >> $out/nix-support/cc-cflags
|
||
'';
|
||
in {
|
||
|
||
llvm = callPackage ./llvm { };
|
||
|
||
llvm-polly = callPackage ./llvm { enablePolly = true; };
|
||
|
||
clang-unwrapped = callPackage ./clang {
|
||
inherit (tools) lld;
|
||
inherit clang-tools-extra_src;
|
||
};
|
||
clang-polly-unwrapped = callPackage ./clang {
|
||
inherit clang-tools-extra_src;
|
||
llvm = tools.llvm-polly;
|
||
enablePolly = true;
|
||
};
|
||
|
||
# disabled until recommonmark supports sphinx 3
|
||
#llvm-manpages = lowPrio (tools.llvm.override {
|
||
# enableManpages = true;
|
||
# python3 = pkgs.python3; # don't use python-boot
|
||
#});
|
||
|
||
clang-manpages = lowPrio (tools.clang-unwrapped.override {
|
||
enableManpages = true;
|
||
python3 = pkgs.python3; # don't use python-boot
|
||
});
|
||
|
||
libclang = tools.clang-unwrapped.lib;
|
||
|
||
clang = if stdenv.cc.isGNU then tools.libstdcxxClang else tools.libcxxClang;
|
||
|
||
libstdcxxClang = wrapCCWith rec {
|
||
cc = tools.clang-unwrapped;
|
||
# libstdcxx is taken from gcc in an ad-hoc way in cc-wrapper.
|
||
libcxx = null;
|
||
extraPackages = [
|
||
targetLlvmLibraries.compiler-rt
|
||
];
|
||
extraBuildCommands = mkExtraBuildCommands cc;
|
||
};
|
||
|
||
libcxxClang = wrapCCWith rec {
|
||
cc = tools.clang-unwrapped;
|
||
libcxx = targetLlvmLibraries.libcxx;
|
||
extraPackages = [
|
||
targetLlvmLibraries.libcxxabi
|
||
targetLlvmLibraries.compiler-rt
|
||
];
|
||
extraBuildCommands = mkExtraBuildCommands cc;
|
||
};
|
||
|
||
lld = callPackage ./lld {};
|
||
|
||
lldb = callPackage ./lldb {};
|
||
|
||
# Below, is the LLVM bootstrapping logic. It handles building a
|
||
# fully LLVM toolchain from scratch. No GCC toolchain should be
|
||
# pulled in. As a consequence, it is very quick to build different
|
||
# targets provided by LLVM and we can also build for what GCC
|
||
# doesn’t support like LLVM. Probably we should move to some other
|
||
# file.
|
||
|
||
bintools = callPackage ./bintools.nix {};
|
||
|
||
lldClang = wrapCCWith rec {
|
||
cc = tools.clang-unwrapped;
|
||
libcxx = targetLlvmLibraries.libcxx;
|
||
bintools = wrapBintoolsWith {
|
||
inherit (tools) bintools;
|
||
};
|
||
extraPackages = [
|
||
targetLlvmLibraries.libcxxabi
|
||
targetLlvmLibraries.compiler-rt
|
||
] ++ lib.optionals (!stdenv.targetPlatform.isWasm) [
|
||
targetLlvmLibraries.libunwind
|
||
];
|
||
extraBuildCommands = ''
|
||
echo "-rtlib=compiler-rt -Wno-unused-command-line-argument" >> $out/nix-support/cc-cflags
|
||
echo "-B${targetLlvmLibraries.compiler-rt}/lib" >> $out/nix-support/cc-cflags
|
||
'' + lib.optionalString (!stdenv.targetPlatform.isWasm) ''
|
||
echo "--unwindlib=libunwind" >> $out/nix-support/cc-cflags
|
||
'' + lib.optionalString stdenv.targetPlatform.isWasm ''
|
||
echo "-fno-exceptions" >> $out/nix-support/cc-cflags
|
||
'' + mkExtraBuildCommands cc;
|
||
};
|
||
|
||
lldClangNoLibcxx = wrapCCWith rec {
|
||
cc = tools.clang-unwrapped;
|
||
libcxx = null;
|
||
bintools = wrapBintoolsWith {
|
||
inherit (tools) bintools;
|
||
};
|
||
extraPackages = [
|
||
targetLlvmLibraries.compiler-rt
|
||
];
|
||
extraBuildCommands = ''
|
||
echo "-rtlib=compiler-rt" >> $out/nix-support/cc-cflags
|
||
echo "-B${targetLlvmLibraries.compiler-rt}/lib" >> $out/nix-support/cc-cflags
|
||
echo "-nostdlib++" >> $out/nix-support/cc-cflags
|
||
'' + mkExtraBuildCommands cc;
|
||
};
|
||
|
||
lldClangNoLibc = wrapCCWith rec {
|
||
cc = tools.clang-unwrapped;
|
||
libcxx = null;
|
||
bintools = wrapBintoolsWith {
|
||
inherit (tools) bintools;
|
||
libc = null;
|
||
};
|
||
extraPackages = [
|
||
targetLlvmLibraries.compiler-rt
|
||
];
|
||
extraBuildCommands = ''
|
||
echo "-rtlib=compiler-rt" >> $out/nix-support/cc-cflags
|
||
echo "-B${targetLlvmLibraries.compiler-rt}/lib" >> $out/nix-support/cc-cflags
|
||
'' + mkExtraBuildCommands cc;
|
||
};
|
||
|
||
lldClangNoCompilerRt = wrapCCWith {
|
||
cc = tools.clang-unwrapped;
|
||
libcxx = null;
|
||
bintools = wrapBintoolsWith {
|
||
inherit (tools) bintools;
|
||
libc = null;
|
||
};
|
||
extraPackages = [ ];
|
||
extraBuildCommands = ''
|
||
echo "-nostartfiles" >> $out/nix-support/cc-cflags
|
||
'';
|
||
};
|
||
|
||
});
|
||
|
||
libraries = lib.makeExtensible (libraries: let
|
||
callPackage = newScope (libraries // buildLlvmTools // { inherit stdenv cmake libxml2 python3 isl release_version version fetch; });
|
||
in {
|
||
|
||
compiler-rt = callPackage ./compiler-rt ({} //
|
||
(lib.optionalAttrs (stdenv.hostPlatform.useLLVM or false) {
|
||
stdenv = overrideCC stdenv buildLlvmTools.lldClangNoCompilerRt;
|
||
}));
|
||
|
||
stdenv = overrideCC stdenv buildLlvmTools.clang;
|
||
|
||
libcxxStdenv = overrideCC stdenv buildLlvmTools.libcxxClang;
|
||
|
||
libcxx = callPackage ./libc++ ({} //
|
||
(lib.optionalAttrs (stdenv.hostPlatform.useLLVM or false) {
|
||
stdenv = overrideCC stdenv buildLlvmTools.lldClangNoLibcxx;
|
||
}));
|
||
|
||
libcxxabi = callPackage ./libc++abi ({} //
|
||
(lib.optionalAttrs (stdenv.hostPlatform.useLLVM or false) {
|
||
stdenv = overrideCC stdenv buildLlvmTools.lldClangNoLibcxx;
|
||
libunwind = libraries.libunwind;
|
||
}));
|
||
|
||
openmp = callPackage ./openmp.nix {};
|
||
|
||
libunwind = callPackage ./libunwind ({} //
|
||
(lib.optionalAttrs (stdenv.hostPlatform.useLLVM or false) {
|
||
stdenv = overrideCC stdenv buildLlvmTools.lldClangNoLibcxx;
|
||
}));
|
||
|
||
});
|
||
|
||
in { inherit tools libraries; } // libraries // tools
|