2021-05-11 23:12:04 +02:00
|
|
|
{ lib, stdenv, llvm_meta, version, fetch, cmake, python3, llvm, libcxxabi }:
|
2020-03-18 17:10:09 +01:00
|
|
|
|
|
|
|
let
|
|
|
|
|
|
|
|
useLLVM = stdenv.hostPlatform.useLLVM or false;
|
|
|
|
bareMetal = stdenv.hostPlatform.parsed.kernel.name == "none";
|
2021-05-11 21:20:15 +02:00
|
|
|
haveLibc = stdenv.cc.libc != null;
|
2020-03-18 17:10:09 +01:00
|
|
|
inherit (stdenv.hostPlatform) isMusl;
|
|
|
|
|
|
|
|
in
|
|
|
|
|
2021-05-11 21:20:15 +02:00
|
|
|
stdenv.mkDerivation {
|
|
|
|
pname = "compiler-rt" + lib.optionalString (haveLibc) "-libc";
|
2019-09-19 20:19:41 +02:00
|
|
|
inherit version;
|
2021-05-11 21:20:15 +02:00
|
|
|
src = fetch "compiler-rt" "0xwh79g3zggdabxgnd0bphry75asm1qz7mv3hcqihqwqr6aspgy2";
|
2019-09-19 20:19:41 +02:00
|
|
|
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 10:23:57 +02:00
|
|
|
nativeBuildInputs = [ cmake python3 llvm.dev ];
|
2021-01-22 12:25:31 +01:00
|
|
|
buildInputs = lib.optional stdenv.hostPlatform.isDarwin libcxxabi;
|
2019-09-19 20:19:41 +02:00
|
|
|
|
2019-11-19 15:48:42 +01:00
|
|
|
NIX_CFLAGS_COMPILE = [
|
|
|
|
"-DSCUDO_DEFAULT_OPTIONS=DeleteSizeMismatch=0:DeallocationTypeMismatch=0"
|
|
|
|
];
|
|
|
|
|
2020-04-07 02:46:15 +02:00
|
|
|
cmakeFlags = [
|
2019-09-19 20:19:41 +02:00
|
|
|
"-DCOMPILER_RT_DEFAULT_TARGET_ONLY=ON"
|
|
|
|
"-DCMAKE_C_COMPILER_TARGET=${stdenv.hostPlatform.config}"
|
|
|
|
"-DCMAKE_ASM_COMPILER_TARGET=${stdenv.hostPlatform.config}"
|
2021-01-22 12:25:31 +01:00
|
|
|
] ++ lib.optionals (useLLVM || bareMetal || isMusl) [
|
2019-09-19 20:19:41 +02:00
|
|
|
"-DCOMPILER_RT_BUILD_SANITIZERS=OFF"
|
|
|
|
"-DCOMPILER_RT_BUILD_XRAY=OFF"
|
|
|
|
"-DCOMPILER_RT_BUILD_LIBFUZZER=OFF"
|
|
|
|
"-DCOMPILER_RT_BUILD_PROFILE=OFF"
|
2021-05-11 21:20:15 +02:00
|
|
|
] ++ lib.optionals ((useLLVM || bareMetal) && !haveLibc) [
|
2020-03-18 17:10:09 +01:00
|
|
|
"-DCMAKE_C_COMPILER_WORKS=ON"
|
|
|
|
"-DCMAKE_CXX_COMPILER_WORKS=ON"
|
2019-09-19 20:19:41 +02:00
|
|
|
"-DCOMPILER_RT_BAREMETAL_BUILD=ON"
|
2020-03-18 17:10:09 +01:00
|
|
|
"-DCMAKE_SIZEOF_VOID_P=${toString (stdenv.hostPlatform.parsed.cpu.bits / 8)}"
|
2021-05-11 21:20:15 +02:00
|
|
|
] ++ lib.optionals (useLLVM && !haveLibc) [
|
|
|
|
"-DCMAKE_C_FLAGS=-nodefaultlibs"
|
2021-01-22 12:25:31 +01:00
|
|
|
] ++ lib.optionals (useLLVM) [
|
2020-03-18 17:10:09 +01:00
|
|
|
"-DCOMPILER_RT_BUILD_BUILTINS=ON"
|
2019-09-19 20:19:41 +02:00
|
|
|
#https://stackoverflow.com/questions/53633705/cmake-the-c-compiler-is-not-able-to-compile-a-simple-test-program
|
|
|
|
"-DCMAKE_TRY_COMPILE_TARGET_TYPE=STATIC_LIBRARY"
|
2021-01-22 12:25:31 +01:00
|
|
|
] ++ lib.optionals (bareMetal) [
|
2019-09-19 20:19:41 +02:00
|
|
|
"-DCOMPILER_RT_OS_DIR=baremetal"
|
2021-01-22 12:25:31 +01:00
|
|
|
] ++ lib.optionals (stdenv.hostPlatform.isDarwin) [
|
2020-07-29 17:32:34 +02:00
|
|
|
# The compiler-rt build infrastructure sniffs supported platforms on Darwin
|
|
|
|
# and finds i386;x86_64;x86_64h. We only build for x86_64, so linking fails
|
|
|
|
# when it tries to use libc++ and libc++api for i386.
|
2021-03-19 12:40:13 +01:00
|
|
|
"-DDARWIN_osx_ARCHS=${stdenv.hostPlatform.darwinArch}"
|
2019-09-19 20:19:41 +02:00
|
|
|
];
|
|
|
|
|
|
|
|
outputs = [ "out" "dev" ];
|
|
|
|
|
|
|
|
patches = [
|
2021-03-24 02:40:33 +01:00
|
|
|
# https://github.com/llvm/llvm-project/commit/947f9692440836dcb8d88b74b69dd379d85974ce
|
|
|
|
../../common/compiler-rt/glibc.patch
|
|
|
|
./codesign.patch # Revert compiler-rt commit that makes codesign mandatory
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 10:23:57 +02:00
|
|
|
./gnu-install-dirs.patch
|
2021-01-22 12:25:31 +01:00
|
|
|
]# ++ lib.optional stdenv.hostPlatform.isMusl ./sanitizers-nongnu.patch
|
2021-03-24 02:40:33 +01:00
|
|
|
++ lib.optional stdenv.hostPlatform.isAarch32 ./armv7l.patch;
|
2019-09-19 20:19:41 +02:00
|
|
|
|
|
|
|
# TSAN requires XPC on Darwin, which we have no public/free source files for. We can depend on the Apple frameworks
|
|
|
|
# to get it, but they're unfree. Since LLVM is rather central to the stdenv, we patch out TSAN support so that Hydra
|
|
|
|
# can build this. If we didn't do it, basically the entire nixpkgs on Darwin would have an unfree dependency and we'd
|
|
|
|
# get no binary cache for the entire platform. If you really find yourself wanting the TSAN, make this controllable by
|
|
|
|
# a flag and turn the flag off during the stdenv build.
|
2021-01-22 12:25:31 +01:00
|
|
|
postPatch = lib.optionalString (!stdenv.isDarwin) ''
|
2020-04-24 17:22:21 +02:00
|
|
|
substituteInPlace cmake/builtin-config-ix.cmake \
|
|
|
|
--replace 'set(X86 i386)' 'set(X86 i386 i486 i586 i686)'
|
2021-01-22 12:25:31 +01:00
|
|
|
'' + lib.optionalString stdenv.isDarwin ''
|
2019-09-19 20:19:41 +02:00
|
|
|
substituteInPlace cmake/config-ix.cmake \
|
|
|
|
--replace 'set(COMPILER_RT_HAS_TSAN TRUE)' 'set(COMPILER_RT_HAS_TSAN FALSE)'
|
2021-01-22 12:25:31 +01:00
|
|
|
'' + lib.optionalString (useLLVM) ''
|
2019-09-19 20:19:41 +02:00
|
|
|
substituteInPlace lib/builtins/int_util.c \
|
|
|
|
--replace "#include <stdlib.h>" ""
|
|
|
|
substituteInPlace lib/builtins/clear_cache.c \
|
|
|
|
--replace "#include <assert.h>" ""
|
|
|
|
substituteInPlace lib/builtins/cpu_model.c \
|
|
|
|
--replace "#include <assert.h>" ""
|
|
|
|
'';
|
|
|
|
|
|
|
|
# Hack around weird upsream RPATH bug
|
2021-05-10 00:51:20 +02:00
|
|
|
postInstall = lib.optionalString (stdenv.hostPlatform.isDarwin || stdenv.hostPlatform.isWasm) ''
|
|
|
|
ln -s "$out/lib"/*/* "$out/lib"
|
|
|
|
'' + lib.optionalString (useLLVM) ''
|
2019-09-19 20:19:41 +02:00
|
|
|
ln -s $out/lib/*/clang_rt.crtbegin-*.o $out/lib/crtbegin.o
|
|
|
|
ln -s $out/lib/*/clang_rt.crtend-*.o $out/lib/crtend.o
|
|
|
|
ln -s $out/lib/*/clang_rt.crtbegin_shared-*.o $out/lib/crtbeginS.o
|
|
|
|
ln -s $out/lib/*/clang_rt.crtend_shared-*.o $out/lib/crtendS.o
|
|
|
|
'';
|
2021-05-11 23:12:04 +02:00
|
|
|
|
|
|
|
meta = llvm_meta // {
|
|
|
|
homepage = "https://compiler-rt.llvm.org/";
|
|
|
|
description = "Compiler runtime libraries";
|
|
|
|
longDescription = ''
|
|
|
|
The compiler-rt project provides highly tuned implementations of the
|
|
|
|
low-level code generator support routines like "__fixunsdfdi" and other
|
|
|
|
calls generated when a target doesn't have a short sequence of native
|
|
|
|
instructions to implement a core IR operation. It also provides
|
|
|
|
implementations of run-time libraries for dynamic testing tools such as
|
|
|
|
AddressSanitizer, ThreadSanitizer, MemorySanitizer, and DataFlowSanitizer.
|
|
|
|
'';
|
|
|
|
# "All of the code in the compiler-rt project is dual licensed under the MIT
|
|
|
|
# license and the UIUC License (a BSD-like license)":
|
|
|
|
license = with lib.licenses; [ mit ncsa ];
|
|
|
|
};
|
2019-09-19 20:19:41 +02:00
|
|
|
}
|