diff options
author | Jakub Jirutka <jakub@jirutka.cz> | 2017-04-16 18:31:09 +0200 |
---|---|---|
committer | Jakub Jirutka <jakub@jirutka.cz> | 2017-04-22 02:45:58 +0200 |
commit | 6b867ce28451cdb2b794961e42ed775741fe0b31 (patch) | |
tree | 7bbb44354474eadb629c2d71992978b90dbd08b5 /main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch | |
parent | e18b37127697426aa02c3e947a7c67ec92dafa88 (diff) | |
download | aports-6b867ce28451cdb2b794961e42ed775741fe0b31.tar.bz2 aports-6b867ce28451cdb2b794961e42ed775741fe0b31.tar.xz |
main/llvm4: move from testing
Diffstat (limited to 'main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch')
-rw-r--r-- | main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch b/main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch new file mode 100644 index 0000000000..d5d7f07b5e --- /dev/null +++ b/main/llvm4/llvm-fix-DynamicLibrary-to-build-with-musl-libc.patch @@ -0,0 +1,33 @@ +From d12ecb83d01dcb580dd94f4d57828f33d3eb4c35 Mon Sep 17 00:00:00 2001 +From: Natanael Copa <ncopa@alpinelinux.org> +Date: Thu, 18 Feb 2016 15:33:21 +0100 +Subject: [PATCH 3/3] Fix DynamicLibrary to build with musl libc + +stdin/out/err is part of the libc and not the kernel so we check for the +specific libc that does the unexpected instead of linux. + +This is needed for making it build with musl libc. +--- + lib/Support/DynamicLibrary.cpp | 4 ++-- + 1 file changed, 2 insertions(+), 2 deletions(-) + +diff --git a/lib/Support/DynamicLibrary.cpp b/lib/Support/DynamicLibrary.cpp +index 9a7aeb5..0c1c8f8 100644 +--- a/lib/Support/DynamicLibrary.cpp ++++ b/lib/Support/DynamicLibrary.cpp +@@ -140,10 +140,10 @@ void* DynamicLibrary::SearchForAddressOfSymbol(const char *symbolName) { + #define EXPLICIT_SYMBOL(SYM) \ + if (!strcmp(symbolName, #SYM)) return &SYM + +-// On linux we have a weird situation. The stderr/out/in symbols are both ++// On GNU libc we have a weird situation. The stderr/out/in symbols are both + // macros and global variables because of standards requirements. So, we + // boldly use the EXPLICIT_SYMBOL macro without checking for a #define first. +-#if defined(__linux__) and !defined(__ANDROID__) ++#if defined(__GLIBC__) + { + EXPLICIT_SYMBOL(stderr); + EXPLICIT_SYMBOL(stdout); +-- +2.7.3 + |