new package: llvm11-11.0.0
Additional fixes by q66.
This commit is contained in:
parent
d5ff5d89d9
commit
f8b6ce4acc
27 changed files with 750 additions and 12 deletions
|
@ -1027,10 +1027,11 @@ libuchardet.so.0 uchardet-0.0.6_1
|
||||||
libgtksourceviewmm-3.0.so.0 gtksourceviewmm-3.2.0_1
|
libgtksourceviewmm-3.0.so.0 gtksourceviewmm-3.2.0_1
|
||||||
libyajl.so.2 yajl-2.0.1_1
|
libyajl.so.2 yajl-2.0.1_1
|
||||||
libconfuse.so.2 confuse-3.2.1_1
|
libconfuse.so.2 confuse-3.2.1_1
|
||||||
liblldb.so.10 lldb-10.0.0_1
|
|
||||||
libclang.so.10 libclang-10.0.0_3
|
|
||||||
libclang-cpp.so.10 libclang-cpp-10.0.0_3
|
|
||||||
libLLVM-10.so libllvm10-10.0.0_1
|
libLLVM-10.so libllvm10-10.0.0_1
|
||||||
|
liblldb.so.11 lldb-11.0.0_1
|
||||||
|
libclang.so.11 libclang-11.0.0_1
|
||||||
|
libclang-cpp.so.11 libclang-cpp-11.0.0_1
|
||||||
|
libLLVM-11.so libllvm11-11.0.0_1
|
||||||
libisofs.so.6 libisofs-0.6.24_1
|
libisofs.so.6 libisofs-0.6.24_1
|
||||||
libmpack.so.0 libmpack-1.0.5_1
|
libmpack.so.0 libmpack-1.0.5_1
|
||||||
libGeoIP.so.1 libgeoip-1.4.8_1
|
libGeoIP.so.1 libgeoip-1.4.8_1
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
1
srcpkgs/libllvm11
Symbolic link
1
srcpkgs/libllvm11
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
|
@ -1 +1 @@
|
||||||
llvm10
|
llvm11
|
9
srcpkgs/llvm11/files/llvm-Config-llvm-config.h
Normal file
9
srcpkgs/llvm11/files/llvm-Config-llvm-config.h
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
#include <bits/wordsize.h>
|
||||||
|
|
||||||
|
#if __WORDSIZE == 32
|
||||||
|
#include "llvm-config-32.h"
|
||||||
|
#elif __WORDSIZE == 64
|
||||||
|
#include "llvm-config-64.h"
|
||||||
|
#else
|
||||||
|
#error "Unknown word size"
|
||||||
|
#endif
|
|
@ -0,0 +1,44 @@
|
||||||
|
From 352974169f0d2b5da3d5321f588f5e3b5941330e Mon Sep 17 00:00:00 2001
|
||||||
|
From: Andrea Brancaleoni <miwaxe@gmail.com>
|
||||||
|
Date: Tue, 8 Sep 2015 22:14:57 +0200
|
||||||
|
Subject: [PATCH 2/7] fix unwind chain inclusion
|
||||||
|
|
||||||
|
---
|
||||||
|
lib/Headers/unwind.h | 9 +++++----
|
||||||
|
1 file changed, 5 insertions(+), 4 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/lib/Headers/unwind.h b/lib/Headers/unwind.h
|
||||||
|
index 303d792..44e10cc 100644
|
||||||
|
--- a/lib/Headers/unwind.h
|
||||||
|
+++ b/lib/Headers/unwind.h
|
||||||
|
@@ -9,9 +9,6 @@
|
||||||
|
|
||||||
|
/* See "Data Definitions for libgcc_s" in the Linux Standard Base.*/
|
||||||
|
|
||||||
|
-#ifndef __CLANG_UNWIND_H
|
||||||
|
-#define __CLANG_UNWIND_H
|
||||||
|
-
|
||||||
|
#if defined(__APPLE__) && __has_include_next(<unwind.h>)
|
||||||
|
/* Darwin (from 11.x on) provide an unwind.h. If that's available,
|
||||||
|
* use it. libunwind wraps some of its definitions in #ifdef _GNU_SOURCE,
|
||||||
|
@@ -39,6 +36,9 @@
|
||||||
|
# endif
|
||||||
|
#else
|
||||||
|
|
||||||
|
+#ifndef __CLANG_UNWIND_H
|
||||||
|
+#define __CLANG_UNWIND_H
|
||||||
|
+
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
@@ -322,6 +322,7 @@ _Unwind_Ptr _Unwind_GetTextRelBase(struct _Unwind_Context *);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
+#endif /* __CLANG_UNWIND_H */
|
||||||
|
+
|
||||||
|
#endif
|
||||||
|
|
||||||
|
-#endif /* __CLANG_UNWIND_H */
|
||||||
|
--
|
||||||
|
2.5.1
|
|
@ -0,0 +1,91 @@
|
||||||
|
--- a/lib/Driver/ToolChains/Gnu.cpp
|
||||||
|
+++ b/lib/Driver/ToolChains/Gnu.cpp
|
||||||
|
@@ -1938,7 +1938,8 @@ void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes(
|
||||||
|
static const char *const ARMHFTriples[] = {"arm-linux-gnueabihf",
|
||||||
|
"armv7hl-redhat-linux-gnueabi",
|
||||||
|
"armv6hl-suse-linux-gnueabi",
|
||||||
|
- "armv7hl-suse-linux-gnueabi"};
|
||||||
|
+ "armv7hl-suse-linux-gnueabi",
|
||||||
|
+ "armv7l-linux-gnueabihf"};
|
||||||
|
static const char *const ARMebLibDirs[] = {"/lib"};
|
||||||
|
static const char *const ARMebTriples[] = {"armeb-linux-gnueabi",
|
||||||
|
"armeb-linux-androideabi"};
|
||||||
|
@@ -2077,6 +2078,78 @@ void Generic_GCC::GCCInstallationDetector::AddDefaultGCCPrefixes(
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (TargetTriple.isMusl()) {
|
||||||
|
+ static const char *const AArch64MuslTriples[] = {"aarch64-linux-musl"};
|
||||||
|
+ static const char *const ARMHFMuslTriples[] = {
|
||||||
|
+ "arm-linux-musleabihf", "armv7l-linux-musleabihf"
|
||||||
|
+ };
|
||||||
|
+ static const char *const ARMMuslTriples[] = {"arm-linux-musleabi"};
|
||||||
|
+ static const char *const X86_64MuslTriples[] = {"x86_64-linux-musl"};
|
||||||
|
+ static const char *const X86MuslTriples[] = {"i686-linux-musl"};
|
||||||
|
+ static const char *const MIPSMuslTriples[] = {
|
||||||
|
+ "mips-linux-musl", "mipsel-linux-musl",
|
||||||
|
+ "mipsel-linux-muslhf", "mips-linux-muslhf"
|
||||||
|
+ };
|
||||||
|
+ static const char *const PPCMuslTriples[] = {"powerpc-linux-musl"};
|
||||||
|
+ static const char *const PPC64MuslTriples[] = {"powerpc64-linux-musl"};
|
||||||
|
+ static const char *const PPC64LEMuslTriples[] = {"powerpc64le-linux-musl"};
|
||||||
|
+
|
||||||
|
+ switch (TargetTriple.getArch()) {
|
||||||
|
+ case llvm::Triple::aarch64:
|
||||||
|
+ LibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs));
|
||||||
|
+ TripleAliases.append(begin(AArch64MuslTriples), end(AArch64MuslTriples));
|
||||||
|
+ BiarchLibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs));
|
||||||
|
+ BiarchTripleAliases.append(begin(AArch64MuslTriples), end(AArch64MuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::arm:
|
||||||
|
+ LibDirs.append(begin(ARMLibDirs), end(ARMLibDirs));
|
||||||
|
+ if (TargetTriple.getEnvironment() == llvm::Triple::MuslEABIHF) {
|
||||||
|
+ TripleAliases.append(begin(ARMHFMuslTriples), end(ARMHFMuslTriples));
|
||||||
|
+ } else {
|
||||||
|
+ TripleAliases.append(begin(ARMMuslTriples), end(ARMMuslTriples));
|
||||||
|
+ }
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::x86_64:
|
||||||
|
+ LibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs));
|
||||||
|
+ TripleAliases.append(begin(X86_64MuslTriples), end(X86_64MuslTriples));
|
||||||
|
+ BiarchLibDirs.append(begin(X86LibDirs), end(X86LibDirs));
|
||||||
|
+ BiarchTripleAliases.append(begin(X86MuslTriples), end(X86MuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::x86:
|
||||||
|
+ LibDirs.append(begin(X86LibDirs), end(X86LibDirs));
|
||||||
|
+ TripleAliases.append(begin(X86MuslTriples), end(X86MuslTriples));
|
||||||
|
+ BiarchLibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs));
|
||||||
|
+ BiarchTripleAliases.append(begin(X86_64MuslTriples), end(X86_64MuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::mips:
|
||||||
|
+ LibDirs.append(begin(MIPSLibDirs), end(MIPSLibDirs));
|
||||||
|
+ TripleAliases.append(begin(MIPSMuslTriples), end(MIPSMuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::ppc:
|
||||||
|
+ LibDirs.append(begin(PPCLibDirs), end(PPCLibDirs));
|
||||||
|
+ TripleAliases.append(begin(PPCMuslTriples), end(PPCMuslTriples));
|
||||||
|
+ BiarchLibDirs.append(begin(PPC64LibDirs), end(PPC64LibDirs));
|
||||||
|
+ BiarchTripleAliases.append(begin(PPC64MuslTriples), end(PPC64MuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::ppc64:
|
||||||
|
+ LibDirs.append(begin(PPC64LibDirs), end(PPC64LibDirs));
|
||||||
|
+ TripleAliases.append(begin(PPC64MuslTriples), end(PPC64MuslTriples));
|
||||||
|
+ BiarchLibDirs.append(begin(PPCLibDirs), end(PPCLibDirs));
|
||||||
|
+ BiarchTripleAliases.append(begin(PPCMuslTriples), end(PPCMuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ case llvm::Triple::ppc64le:
|
||||||
|
+ LibDirs.append(begin(PPC64LELibDirs), end(PPC64LELibDirs));
|
||||||
|
+ TripleAliases.append(begin(PPC64LEMuslTriples), end(PPC64LEMuslTriples));
|
||||||
|
+ break;
|
||||||
|
+ default:
|
||||||
|
+ break;
|
||||||
|
+ }
|
||||||
|
+ TripleAliases.push_back(TargetTriple.str());
|
||||||
|
+ if (TargetTriple.str() != BiarchTriple.str())
|
||||||
|
+ BiarchTripleAliases.push_back(BiarchTriple.str());
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
// Android targets should not use GNU/Linux tools or libraries.
|
||||||
|
if (TargetTriple.isAndroid()) {
|
||||||
|
static const char *const AArch64AndroidTriples[] = {
|
|
@ -0,0 +1,18 @@
|
||||||
|
--- a/lib/Driver/ToolChains/Linux.cpp
|
||||||
|
+++ b/lib/Driver/ToolChains/Linux.cpp
|
||||||
|
@@ -593,12 +593,12 @@ std::string Linux::getDynamicLinker(const ArgList &Args) const {
|
||||||
|
Loader = "ld.so.1";
|
||||||
|
break;
|
||||||
|
case llvm::Triple::ppc64:
|
||||||
|
- LibDir = "lib64";
|
||||||
|
+ LibDir = "lib";
|
||||||
|
Loader =
|
||||||
|
- (tools::ppc::hasPPCAbiArg(Args, "elfv2")) ? "ld64.so.2" : "ld64.so.1";
|
||||||
|
+ (tools::ppc::hasPPCAbiArg(Args, "elfv1")) ? "ld64.so.1" : "ld64.so.2";
|
||||||
|
break;
|
||||||
|
case llvm::Triple::ppc64le:
|
||||||
|
- LibDir = "lib64";
|
||||||
|
+ LibDir = "lib";
|
||||||
|
Loader =
|
||||||
|
(tools::ppc::hasPPCAbiArg(Args, "elfv1")) ? "ld64.so.1" : "ld64.so.2";
|
||||||
|
break;
|
|
@ -0,0 +1,30 @@
|
||||||
|
--- a/lib/Basic/Targets/PPC.h
|
||||||
|
+++ b/lib/Basic/Targets/PPC.h
|
||||||
|
@@ -408,11 +408,10 @@
|
||||||
|
SuitableAlign = 64;
|
||||||
|
} else if ((Triple.getArch() == llvm::Triple::ppc64le)) {
|
||||||
|
resetDataLayout("e-m:e-i64:64-n32:64");
|
||||||
|
- ABI = "elfv2";
|
||||||
|
} else {
|
||||||
|
resetDataLayout("E-m:e-i64:64-n32:64");
|
||||||
|
- ABI = "elfv1";
|
||||||
|
}
|
||||||
|
+ ABI = "elfv2";
|
||||||
|
|
||||||
|
if (Triple.isOSFreeBSD() || Triple.isOSOpenBSD() ||
|
||||||
|
Triple.getOS() == llvm::Triple::AIX || Triple.isMusl()) {
|
||||||
|
--- a/lib/Driver/ToolChains/Clang.cpp
|
||||||
|
+++ b/lib/Driver/ToolChains/Clang.cpp
|
||||||
|
@@ -1883,11 +1883,7 @@
|
||||||
|
ABIName = "elfv1-qpx";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
- if ((T.isOSFreeBSD() && T.getOSMajorVersion() >= 13) ||
|
||||||
|
- T.isOSOpenBSD() || T.isMusl())
|
||||||
|
- ABIName = "elfv2";
|
||||||
|
- else
|
||||||
|
- ABIName = "elfv1";
|
||||||
|
+ ABIName = "elfv2";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case llvm::Triple::ppc64le:
|
|
@ -0,0 +1,11 @@
|
||||||
|
--- compiler-rt-10.0.0.src/lib/builtins/CMakeLists.txt
|
||||||
|
+++ compiler-rt-10.0.0.src/lib/builtins/CMakeLists.txt
|
||||||
|
@@ -428,8 +428,6 @@
|
||||||
|
)
|
||||||
|
set(arm_Thumb1_SOURCES
|
||||||
|
${arm_Thumb1_JT_SOURCES}
|
||||||
|
- ${arm_Thumb1_SjLj_EH_SOURCES}
|
||||||
|
- ${arm_Thumb1_VFPv2_SOURCES}
|
||||||
|
${arm_Thumb1_icache_SOURCES}
|
||||||
|
)
|
||||||
|
|
31
srcpkgs/llvm11/files/patches/lldb/musl.patch
Normal file
31
srcpkgs/llvm11/files/patches/lldb/musl.patch
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
--- a/source/Plugins/Process/Linux/Procfs.h
|
||||||
|
+++ b/source/Plugins/Process/Linux/Procfs.h
|
||||||
|
@@ -10,21 +10,12 @@
|
||||||
|
// sys/procfs.h on Android/Linux for all supported architectures.
|
||||||
|
|
||||||
|
#include <sys/ptrace.h>
|
||||||
|
+#include <asm/ptrace.h>
|
||||||
|
|
||||||
|
-#ifdef __ANDROID__
|
||||||
|
-#if defined(__arm64__) || defined(__aarch64__)
|
||||||
|
-typedef unsigned long elf_greg_t;
|
||||||
|
-typedef elf_greg_t
|
||||||
|
- elf_gregset_t[(sizeof(struct user_pt_regs) / sizeof(elf_greg_t))];
|
||||||
|
-typedef struct user_fpsimd_state elf_fpregset_t;
|
||||||
|
-#ifndef NT_FPREGSET
|
||||||
|
-#define NT_FPREGSET NT_PRFPREG
|
||||||
|
-#endif // NT_FPREGSET
|
||||||
|
-#elif defined(__mips__)
|
||||||
|
-#ifndef NT_FPREGSET
|
||||||
|
-#define NT_FPREGSET NT_PRFPREG
|
||||||
|
-#endif // NT_FPREGSET
|
||||||
|
-#endif
|
||||||
|
-#else // __ANDROID__
|
||||||
|
+#if !defined(__GLIBC__) && defined(__powerpc__)
|
||||||
|
+#define pt_regs musl_pt_regs
|
||||||
|
+#include <sys/procfs.h>
|
||||||
|
+#undef pt_regs
|
||||||
|
+#else
|
||||||
|
#include <sys/procfs.h>
|
||||||
|
-#endif // __ANDROID__
|
||||||
|
+#endif
|
58
srcpkgs/llvm11/files/patches/llvm/llvm-001-musl.patch
Normal file
58
srcpkgs/llvm11/files/patches/llvm/llvm-001-musl.patch
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
From faca3fbd15d0c3108493c3c54cd93138e049ac43 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Andrea Brancaleoni <miwaxe@gmail.com>
|
||||||
|
Date: Tue, 8 Sep 2015 22:03:02 +0200
|
||||||
|
Subject: [PATCH 3/3] musl
|
||||||
|
|
||||||
|
---
|
||||||
|
include/llvm/Analysis/TargetLibraryInfo.h | 9 +++++++++
|
||||||
|
lib/Support/DynamicLibrary.cpp | 2 +-
|
||||||
|
lib/Support/Unix/Signals.inc | 6 +++---
|
||||||
|
utils/unittest/googletest/src/gtest.cc | 1 +
|
||||||
|
5 files changed, 17 insertions(+), 6 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/include/llvm/Analysis/TargetLibraryInfo.h b/include/llvm/Analysis/TargetLibraryInfo.h
|
||||||
|
index e0a1ee3..465b65a 100644
|
||||||
|
--- a/include/llvm/Analysis/TargetLibraryInfo.h
|
||||||
|
+++ b/include/llvm/Analysis/TargetLibraryInfo.h
|
||||||
|
@@ -18,6 +18,15 @@
|
||||||
|
#include "llvm/IR/PassManager.h"
|
||||||
|
#include "llvm/Pass.h"
|
||||||
|
|
||||||
|
+#undef fopen64
|
||||||
|
+#undef fseeko64
|
||||||
|
+#undef fstat64
|
||||||
|
+#undef fstatvfs64
|
||||||
|
+#undef ftello64
|
||||||
|
+#undef lstat64
|
||||||
|
+#undef stat64
|
||||||
|
+#undef tmpfile64
|
||||||
|
+
|
||||||
|
namespace llvm {
|
||||||
|
template <typename T> class ArrayRef;
|
||||||
|
|
||||||
|
diff --git a/utils/unittest/googletest/src/gtest.cc b/utils/unittest/googletest/src/gtest.cc
|
||||||
|
index 5780764..1d548c1 100644
|
||||||
|
--- a/utils/unittest/googletest/src/gtest.cc
|
||||||
|
+++ b/utils/unittest/googletest/src/gtest.cc
|
||||||
|
@@ -128,6 +128,7 @@
|
||||||
|
|
||||||
|
#if GTEST_CAN_STREAM_RESULTS_
|
||||||
|
# include <arpa/inet.h> // NOLINT
|
||||||
|
+# include <sys/socket.h> // NOLINT
|
||||||
|
# include <netdb.h> // NOLINT
|
||||||
|
# include <sys/socket.h> // NOLINT
|
||||||
|
# include <sys/types.h> // NOLINT
|
||||||
|
--
|
||||||
|
2.5.1
|
||||||
|
|
||||||
|
--- a/lib/Support/Unix/DynamicLibrary.inc
|
||||||
|
+++ b/lib/Support/Unix/DynamicLibrary.inc
|
||||||
|
@@ -102,7 +102,7 @@ static void *DoSearch(const char* SymbolName) {
|
||||||
|
|
||||||
|
// This macro returns the address of a well-known, explicit symbol
|
||||||
|
#define EXPLICIT_SYMBOL(SYM) \
|
||||||
|
- if (!strcmp(SymbolName, #SYM)) return &SYM
|
||||||
|
+ if (!strcmp(SymbolName, #SYM)) return (void *)&SYM
|
||||||
|
|
||||||
|
// Under glibc we have a weird situation. The stderr/out/in symbols are both
|
||||||
|
// macros and global variables because of standards requirements. So, we
|
|
@ -0,0 +1,26 @@
|
||||||
|
This patches LLVM to use ELFv2 on ppc64 unconditionally unless overridden. We
|
||||||
|
need this because unlike most distros we use ELFv2 for both glibc and musl
|
||||||
|
on big endian ppc64.
|
||||||
|
|
||||||
|
--- a/lib/Target/PowerPC/PPCTargetMachine.cpp
|
||||||
|
+++ b/lib/Target/PowerPC/PPCTargetMachine.cpp
|
||||||
|
@@ -214,9 +214,8 @@
|
||||||
|
|
||||||
|
switch (TT.getArch()) {
|
||||||
|
case Triple::ppc64le:
|
||||||
|
- return PPCTargetMachine::PPC_ABI_ELFv2;
|
||||||
|
case Triple::ppc64:
|
||||||
|
- return PPCTargetMachine::PPC_ABI_ELFv1;
|
||||||
|
+ return PPCTargetMachine::PPC_ABI_ELFv2;
|
||||||
|
default:
|
||||||
|
return PPCTargetMachine::PPC_ABI_UNKNOWN;
|
||||||
|
}
|
||||||
|
--- a/test/CodeGen/PowerPC/ppc64-elf-abi.ll
|
||||||
|
+++ b/test/CodeGen/PowerPC/ppc64-elf-abi.ll
|
||||||
|
@@ -1,4 +1,5 @@
|
||||||
|
-; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu < %s | FileCheck %s -check-prefix=CHECK-ELFv1
|
||||||
|
+; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu < %s | FileCheck %s -check-prefix=CHECK-ELFv2
|
||||||
|
+; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-musl < %s | FileCheck %s -check-prefix=CHECK-ELFv2
|
||||||
|
; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu -target-abi elfv1 < %s | FileCheck %s -check-prefix=CHECK-ELFv1
|
||||||
|
; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux-gnu -target-abi elfv2 < %s | FileCheck %s -check-prefix=CHECK-ELFv2
|
||||||
|
; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux-gnu < %s | FileCheck %s -check-prefix=CHECK-ELFv2
|
|
@ -0,0 +1,11 @@
|
||||||
|
--- llvm/lib/Target/PowerPC/PPCSubtarget.cpp
|
||||||
|
+++ llvm/lib/Target/PowerPC/PPCSubtarget.cpp
|
||||||
|
@@ -150,7 +150,7 @@ void PPCSubtarget::initSubtargetFeatures(StringRef CPU, StringRef FS) {
|
||||||
|
|
||||||
|
if ((TargetTriple.isOSFreeBSD() && TargetTriple.getOSMajorVersion() >= 13) ||
|
||||||
|
TargetTriple.isOSNetBSD() || TargetTriple.isOSOpenBSD() ||
|
||||||
|
- TargetTriple.isMusl())
|
||||||
|
+ isTargetLinux())
|
||||||
|
SecurePlt = true;
|
||||||
|
|
||||||
|
if (HasSPE && IsPPC64)
|
|
@ -0,0 +1,11 @@
|
||||||
|
--- llvm/lib/Target/PowerPC/PPCSubtarget.cpp
|
||||||
|
+++ llvm/lib/Target/PowerPC/PPCSubtarget.cpp
|
||||||
|
@@ -153,7 +153,7 @@
|
||||||
|
|
||||||
|
if ((TargetTriple.isOSFreeBSD() && TargetTriple.getOSMajorVersion() >= 13) ||
|
||||||
|
TargetTriple.isOSNetBSD() || TargetTriple.isOSOpenBSD() ||
|
||||||
|
- TargetTriple.isMusl())
|
||||||
|
+ isTargetLinux())
|
||||||
|
SecurePlt = true;
|
||||||
|
|
||||||
|
if (HasSPE && IsPPC64)
|
|
@ -0,0 +1,18 @@
|
||||||
|
This allows us to override the optimization level as not all platforms can
|
||||||
|
deal with -O3.
|
||||||
|
|
||||||
|
--- a/CMakeLists.txt
|
||||||
|
+++ b/CMakeLists.txt
|
||||||
|
@@ -999,6 +999,12 @@
|
||||||
|
${CMAKE_ARCHIVE_OUTPUT_DIRECTORY}/tf_runtime)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
+set(VOID_CXX_OPT_FLAGS "" CACHE STRING "Optimization level to use")
|
||||||
|
+
|
||||||
|
+if (NOT VOID_CXX_OPT_FLAGS STREQUAL "")
|
||||||
|
+ llvm_replace_compiler_option(CMAKE_CXX_FLAGS_RELEASE "-O3" "${VOID_CXX_OPT_FLAGS}")
|
||||||
|
+endif()
|
||||||
|
+
|
||||||
|
# Put this before tblgen. Else we have a circular dependence.
|
||||||
|
add_subdirectory(lib/Demangle)
|
||||||
|
add_subdirectory(lib/Support)
|
38
srcpkgs/llvm11/files/patches/llvm/llvm-005-ppc-bigpic.patch
Normal file
38
srcpkgs/llvm11/files/patches/llvm/llvm-005-ppc-bigpic.patch
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
From f3dbdd49c06bfafc1d6138094cf42889c14d38b6 Mon Sep 17 00:00:00 2001
|
||||||
|
From: Samuel Holland <samuel@sholland.org>
|
||||||
|
Date: Sun, 3 Nov 2019 10:57:27 -0600
|
||||||
|
Subject: [PATCH] [LLVM][PowerPC] Assume BigPIC if no PIC level is specified
|
||||||
|
|
||||||
|
---
|
||||||
|
llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp | 2 +-
|
||||||
|
llvm/lib/Target/PowerPC/PPCMCInstLower.cpp | 2 +-
|
||||||
|
2 files changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp b/llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
|
||||||
|
index 269b84b4e8d..03246a5242c 100644
|
||||||
|
--- llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
|
||||||
|
+++ llvm/lib/Target/PowerPC/PPCAsmPrinter.cpp
|
||||||
|
@@ -488,7 +488,7 @@ void PPCAsmPrinter::EmitTlsCall(const MachineInstr *MI,
|
||||||
|
|
||||||
|
// Add 32768 offset to the symbol so we follow up the latest GOT/PLT ABI.
|
||||||
|
if (Kind == MCSymbolRefExpr::VK_PLT && Subtarget->isSecurePlt() &&
|
||||||
|
- M->getPICLevel() == PICLevel::BigPIC)
|
||||||
|
+ M->getPICLevel() != PICLevel::SmallPIC)
|
||||||
|
TlsRef = MCBinaryExpr::createAdd(
|
||||||
|
TlsRef, MCConstantExpr::create(32768, OutContext), OutContext);
|
||||||
|
const MachineOperand &MO = MI->getOperand(2);
|
||||||
|
diff --git a/llvm/lib/Target/PowerPC/PPCMCInstLower.cpp b/llvm/lib/Target/PowerPC/PPCMCInstLower.cpp
|
||||||
|
index 027e6bd1ba0..ae461f4eea9 100644
|
||||||
|
--- llvm/lib/Target/PowerPC/PPCMCInstLower.cpp
|
||||||
|
+++ llvm/lib/Target/PowerPC/PPCMCInstLower.cpp
|
||||||
|
@@ -116,7 +116,7 @@ static MCOperand GetSymbolRef(const MachineOperand &MO, const MCSymbol *Symbol,
|
||||||
|
const MCExpr *Expr = MCSymbolRefExpr::create(Symbol, RefKind, Ctx);
|
||||||
|
// If -msecure-plt -fPIC, add 32768 to symbol.
|
||||||
|
if (Subtarget->isSecurePlt() && TM.isPositionIndependent() &&
|
||||||
|
- M->getPICLevel() == PICLevel::BigPIC &&
|
||||||
|
+ M->getPICLevel() != PICLevel::SmallPIC &&
|
||||||
|
MO.getTargetFlags() == PPCII::MO_PLT)
|
||||||
|
Expr =
|
||||||
|
MCBinaryExpr::createAdd(Expr, MCConstantExpr::create(32768, Ctx), Ctx);
|
||||||
|
--
|
||||||
|
2.23.0
|
|
@ -0,0 +1,25 @@
|
||||||
|
Fix failures in AllocationTests/MappedMemoryTest.* on aarch64:
|
||||||
|
|
||||||
|
Failing Tests (8):
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.AllocAndRelease/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.DuplicateNear/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.EnabledWrite/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.MultipleAllocAndRelease/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.SuccessiveNear/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.UnalignedNear/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.ZeroNear/3
|
||||||
|
LLVM-Unit :: Support/./SupportTests/AllocationTests/MappedMemoryTest.ZeroSizeNear/3
|
||||||
|
|
||||||
|
Upstream-Issue: https://bugs.llvm.org/show_bug.cgi?id=14278#c10
|
||||||
|
|
||||||
|
--- a/lib/Support/Unix/Memory.inc
|
||||||
|
+++ b/lib/Support/Unix/Memory.inc
|
||||||
|
@@ -59,7 +59,7 @@
|
||||||
|
return PROT_READ | PROT_WRITE | PROT_EXEC;
|
||||||
|
case llvm::sys::Memory::MF_EXEC:
|
||||||
|
#if (defined(__FreeBSD__) || defined(__POWERPC__) || defined (__ppc__) || \
|
||||||
|
- defined(_POWER) || defined(_ARCH_PPC))
|
||||||
|
+ defined(_POWER) || defined(_ARCH_PPC) || (defined(__linux__) && defined(__aarch64__)))
|
||||||
|
// On PowerPC, having an executable page that has no read permission
|
||||||
|
// can have unintended consequences. The function InvalidateInstruction-
|
||||||
|
// Cache uses instructions dcbf and icbi, both of which are treated by
|
313
srcpkgs/llvm11/template
Normal file
313
srcpkgs/llvm11/template
Normal file
|
@ -0,0 +1,313 @@
|
||||||
|
# Template file for 'llvm11'
|
||||||
|
pkgname=llvm11
|
||||||
|
version=11.0.0
|
||||||
|
revision=1
|
||||||
|
wrksrc="llvm-${version}.src"
|
||||||
|
build_style=cmake
|
||||||
|
configure_args="
|
||||||
|
-DCMAKE_BUILD_TYPE=Release
|
||||||
|
-DLLVM_INSTALL_UTILS=ON
|
||||||
|
-DLLVM_BUILD_LLVM_DYLIB=ON
|
||||||
|
-DLLVM_LINK_LLVM_DYLIB=ON
|
||||||
|
-DLLVM_ENABLE_RTTI=ON
|
||||||
|
-DLLVM_ENABLE_FFI=ON
|
||||||
|
-DLLVM_BINUTILS_INCDIR=/usr/include"
|
||||||
|
hostmakedepends="groff perl python3 zlib-devel libffi-devel swig"
|
||||||
|
makedepends="python3-devel zlib-devel libffi-devel libedit-devel
|
||||||
|
libxml2-devel binutils-devel libatomic-devel"
|
||||||
|
depends="libllvm11"
|
||||||
|
short_desc="Low Level Virtual Machine"
|
||||||
|
maintainer="q66 <daniel@octaforce.org>"
|
||||||
|
license="NCSA"
|
||||||
|
homepage="https://www.llvm.org"
|
||||||
|
distfiles="
|
||||||
|
https://github.com/llvm/llvm-project/releases/download/llvmorg-${version}/llvm-${version}.src.tar.xz
|
||||||
|
https://github.com/llvm/llvm-project/releases/download/llvmorg-${version}/lldb-${version}.src.tar.xz
|
||||||
|
https://github.com/llvm/llvm-project/releases/download/llvmorg-${version}/lld-${version}.src.tar.xz
|
||||||
|
https://github.com/llvm/llvm-project/releases/download/llvmorg-${version}/clang-${version}.src.tar.xz
|
||||||
|
https://github.com/llvm/llvm-project/releases/download/llvmorg-${version}/clang-tools-extra-${version}.src.tar.xz
|
||||||
|
https://github.com/llvm/llvm-project/releases/download/llvmorg-${version}/compiler-rt-${version}.src.tar.xz"
|
||||||
|
checksum="
|
||||||
|
913f68c898dfb4a03b397c5e11c6a2f39d0f22ed7665c9cefa87a34423a72469
|
||||||
|
8570c09f57399e21e0eea0dcd66ae0231d47eafc7a04d6fe5c4951b13c4d2c72
|
||||||
|
efe7be4a7b7cdc6f3bcf222827c6f837439e6e656d12d6c885d5c8a80ff4fd1c
|
||||||
|
0f96acace1e8326b39f220ba19e055ba99b0ab21c2475042dbc6a482649c5209
|
||||||
|
fed318f75d560d0e0ae728e2fb8abce71e9d0c60dd120c9baac118522ce76c09
|
||||||
|
374aff82ff573a449f9aabbd330a5d0a441181c535a3599996127378112db234"
|
||||||
|
lib32disabled=yes
|
||||||
|
python_version=3
|
||||||
|
|
||||||
|
_lldb_enable=yes
|
||||||
|
|
||||||
|
if [ "$CROSS_BUILD" ]; then
|
||||||
|
_lldb_enable=no
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
ppc64le*) ;;
|
||||||
|
ppc*) _lldb_enable=no ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
subpackages="clang-tools-extra clang clang-analyzer libclang libclang-cpp libllvm11"
|
||||||
|
if [ "$_lldb_enable" = "yes" ]; then
|
||||||
|
# XXX fails to cross compile due to python
|
||||||
|
subpackages+=" lldb lldb-devel"
|
||||||
|
fi
|
||||||
|
subpackages+=" lld lld-devel"
|
||||||
|
|
||||||
|
post_patch() {
|
||||||
|
# patches
|
||||||
|
cd ${XBPS_BUILDDIR}/llvm-${version}.src
|
||||||
|
for i in ${FILESDIR}/patches/llvm/llvm-*.patch; do
|
||||||
|
msg_normal "Applying $i to llvm\n"
|
||||||
|
patch -sNp1 -i ${i}
|
||||||
|
done
|
||||||
|
|
||||||
|
cd ${XBPS_BUILDDIR}/clang-${version}.src
|
||||||
|
for i in ${FILESDIR}/patches/clang/clang-*.patch; do
|
||||||
|
msg_normal "Applying $i to clang\n"
|
||||||
|
patch -sNp1 -i ${i}
|
||||||
|
done
|
||||||
|
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
armv5*)
|
||||||
|
cd ${XBPS_BUILDDIR}/compiler-rt-${version}.src
|
||||||
|
for i in ${FILESDIR}/patches/compiler-rt/compiler-rt-*.patch; do
|
||||||
|
msg_normal "Applying $i to compiler-rt\n"
|
||||||
|
patch -sNp1 -i ${i}
|
||||||
|
done
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ "$_lldb_enable" = "yes" ]; then
|
||||||
|
cd ${XBPS_BUILDDIR}/lldb-${version}.src
|
||||||
|
for i in ${FILESDIR}/patches/lldb/*.patch; do
|
||||||
|
msg_normal "Applying $i to lldb\n"
|
||||||
|
patch -sNp1 -i ${i}
|
||||||
|
done
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
*-musl) sed -i 's|__ptrace_request|int|g' source/Plugins/Process/Linux/NativeProcessLinux.cpp ;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Move clang files into the llvm source.
|
||||||
|
if [ -d ${XBPS_BUILDDIR}/clang-${version}.src ]; then
|
||||||
|
mv ${XBPS_BUILDDIR}/clang-${version}.src ${wrksrc}/tools/clang
|
||||||
|
fi
|
||||||
|
# Move clang-tools-extra files into llvm source.
|
||||||
|
if [ -d ${XBPS_BUILDDIR}/clang-tools-extra-${version}.src ]; then
|
||||||
|
mv ${XBPS_BUILDDIR}/clang-tools-extra-${version}.src ${wrksrc}/tools/clang/tools/extra
|
||||||
|
fi
|
||||||
|
# Move lld files into the llvm source.
|
||||||
|
if [ -d ${XBPS_BUILDDIR}/lld-${version}.src ]; then
|
||||||
|
mv ${XBPS_BUILDDIR}/lld-${version}.src ${wrksrc}/tools/lld
|
||||||
|
fi
|
||||||
|
# Move lldb files into the llvm source.
|
||||||
|
if [ -d ${XBPS_BUILDDIR}/lldb-${version}.src ]; then
|
||||||
|
if [ "$_lldb_enable" = "yes" ]; then
|
||||||
|
mv ${XBPS_BUILDDIR}/lldb-${version}.src ${wrksrc}/tools/lldb
|
||||||
|
else
|
||||||
|
rm -rf ${XBPS_BUILDDIR}/lldb-${version}.src
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
# Move compiler-rt files into the llvm source.
|
||||||
|
if [ -d ${XBPS_BUILDDIR}/compiler-rt-${version}.src ]; then
|
||||||
|
mv ${XBPS_BUILDDIR}/compiler-rt-${version}.src ${wrksrc}/projects/compiler-rt
|
||||||
|
fi
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
*-musl)
|
||||||
|
# Disable sanitizers
|
||||||
|
sed -i 's/set(COMPILER_RT_HAS_SANITIZER_COMMON TRUE)/set(COMPILER_RT_HAS_SANITIZER_COMMON FALSE)/' ${wrksrc}/projects/compiler-rt/cmake/config-ix.cmake
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
pre_configure() {
|
||||||
|
# Vastly reduce size of debugging symbols:
|
||||||
|
CFLAGS=${CFLAGS/ -g/ -g1}
|
||||||
|
CXXFLAGS=${CXXFLAGS/ -g/ -g1}
|
||||||
|
|
||||||
|
# since gcc9, the build likes to blow up for ppc32 apparently because
|
||||||
|
# of clang being too large for a 24-bit relative call to the PLT, so
|
||||||
|
# optimize for size instead
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
mips*-musl|ppc|ppc-musl) configure_args+=" -DVOID_CXX_OPT_FLAGS=-Os" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ "$CROSS_BUILD" ]; then
|
||||||
|
msg_normal "Building host tblgen\n"
|
||||||
|
mkdir -p build/HOST
|
||||||
|
cd build/HOST
|
||||||
|
CC="$BUILD_CC" CXX="$BUILD_CXX" CFLAGS="$BUILD_CFLAGS" \
|
||||||
|
CXXFLAGS="$BUILD_CXXFLAGS" LDFLAGS="$BUILD_LDFLAGS" \
|
||||||
|
cmake ../.. -DCMAKE_BUILD_TYPE=Release
|
||||||
|
make ${makejobs} -C utils/TableGen
|
||||||
|
make ${makejobs} -C tools/clang/utils/TableGen
|
||||||
|
configure_args+=" -DLLVM_TABLEGEN=${wrksrc}/build/HOST/bin/llvm-tblgen"
|
||||||
|
configure_args+=" -DCLANG_TABLEGEN=${wrksrc}/build/HOST/bin/clang-tblgen"
|
||||||
|
cd ../..
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$XBPS_TARGET_MACHINE" in
|
||||||
|
i686*) _arch="X86";;
|
||||||
|
x86_64*) _arch="X86";;
|
||||||
|
armv5*) _arch="Armv5te";;
|
||||||
|
armv6*) _arch="Armv6";;
|
||||||
|
armv7*) _arch="Armv7";;
|
||||||
|
aarch64*) _arch="AArch64";;
|
||||||
|
mips*) _arch="Mips";;
|
||||||
|
ppc*) _arch="PowerPC";;
|
||||||
|
esac
|
||||||
|
configure_args+=" -DLLVM_TARGET_ARCH=${_arch}"
|
||||||
|
configure_args+=" -DLLVM_HOST_TRIPLE=${XBPS_CROSS_TRIPLET:-$XBPS_TRIPLET}"
|
||||||
|
configure_args+=" -DLLVM_DEFAULT_TARGET_TRIPLE=${XBPS_CROSS_TRIPLET:-$XBPS_TRIPLET}"
|
||||||
|
}
|
||||||
|
|
||||||
|
do_install() {
|
||||||
|
vlicense LICENSE.TXT
|
||||||
|
|
||||||
|
cd build
|
||||||
|
cmake -DCMAKE_INSTALL_PREFIX=${DESTDIR}/usr -P cmake_install.cmake
|
||||||
|
|
||||||
|
# Fix permissions of static libs
|
||||||
|
chmod -x ${DESTDIR}/usr/lib/*.a
|
||||||
|
|
||||||
|
# Required for multilib.
|
||||||
|
if [ "$XBPS_TARGET_MACHINE" = "x86_64" ]; then
|
||||||
|
for _header in llvm-config; do
|
||||||
|
mv ${DESTDIR}/usr/include/llvm/Config/${_header}{,-64}.h
|
||||||
|
vinstall ${FILESDIR}/llvm-Config-${_header}.h 644 \
|
||||||
|
usr/include/llvm/Config ${_header}.h
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Remove llvm-config-host in cross builds.
|
||||||
|
if [ "$CROSS_BUILD" ]; then
|
||||||
|
rm -f ${DESTDIR}/usr/bin/llvm-config-host
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
clang-analyzer_package() {
|
||||||
|
pycompile_dirs="usr/share/scan-view"
|
||||||
|
depends="clang-${version}_${revision} python3"
|
||||||
|
short_desc+=" - A source code analysis framework"
|
||||||
|
homepage="https://clang-analyzer.llvm.org/"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/share/man/man1/scan-build.1
|
||||||
|
vmove "/usr/bin/scan-*"
|
||||||
|
vmove "/usr/share/scan-*"
|
||||||
|
vmove "/usr/libexec/*analyzer"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
clang-tools-extra_package() {
|
||||||
|
lib32disabled=yes
|
||||||
|
depends="clang-${version}_${revision} python3"
|
||||||
|
short_desc+=" - Extra Clang tools"
|
||||||
|
homepage="https://clang.llvm.org/extra/"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/include/clang-tidy
|
||||||
|
vmove usr/bin/clang-apply-replacements
|
||||||
|
vmove usr/bin/clang-query
|
||||||
|
vmove usr/bin/clang-rename
|
||||||
|
vmove usr/bin/clang-tidy
|
||||||
|
vmove usr/bin/diagtool
|
||||||
|
vmove usr/bin/find-all-symbols
|
||||||
|
vmove usr/bin/hmaptool
|
||||||
|
vmove usr/bin/modularize
|
||||||
|
vmove usr/bin/pp-trace
|
||||||
|
vmove usr/bin/sancov
|
||||||
|
vmove "usr/lib/libclangApplyReplacements*"
|
||||||
|
vmove "usr/lib/libclangQuery*"
|
||||||
|
vmove "usr/lib/libclangTidy*"
|
||||||
|
vmove "usr/share/clang/*tidy*"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
clang_package() {
|
||||||
|
lib32disabled=yes
|
||||||
|
depends="libstdc++-devel libgcc-devel binutils ${XBPS_TARGET_LIBC}-devel
|
||||||
|
libclang-${version}_${revision}"
|
||||||
|
short_desc+=" - C language family frontend"
|
||||||
|
homepage="https://clang.llvm.org/"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/include/clang
|
||||||
|
vmove usr/include/clang-c
|
||||||
|
vmove "usr/bin/*clang*"
|
||||||
|
vmove usr/bin/c-index-test
|
||||||
|
vmove usr/lib/clang
|
||||||
|
vmove usr/lib/cmake/clang
|
||||||
|
vmove "usr/lib/libclang*.a"
|
||||||
|
vmove "usr/lib/libclang*.so"
|
||||||
|
vmove "usr/share/clang"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
libclang_package() {
|
||||||
|
short_desc+=" - C frontend runtime library"
|
||||||
|
pkg_install() {
|
||||||
|
vmove "usr/lib/libclang.so.*"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
libclang-cpp_package() {
|
||||||
|
short_desc+=" - C frontend runtime library (C++ interface)"
|
||||||
|
pkg_install() {
|
||||||
|
vmove "usr/lib/libclang-cpp.so.*"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lld_package() {
|
||||||
|
lib32disabled=yes
|
||||||
|
short_desc+=" - linker"
|
||||||
|
homepage="https://lld.llvm.org"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/bin/lld*
|
||||||
|
vmove usr/bin/wasm-ld
|
||||||
|
vmove usr/bin/ld.lld*
|
||||||
|
vmove usr/bin/ld64.lld*
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lld-devel_package() {
|
||||||
|
lib32disabled=yes
|
||||||
|
short_desc+=" - linker - development files"
|
||||||
|
homepage="https://lld.llvm.org"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/include/lld
|
||||||
|
vmove usr/lib/cmake/lld
|
||||||
|
vmove "usr/lib/liblld*a"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lldb_package() {
|
||||||
|
lib32disabled=yes
|
||||||
|
depends+=" python3-six"
|
||||||
|
short_desc+=" - LLDB debugger"
|
||||||
|
homepage="https://lldb.llvm.org/"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/bin/*lldb*
|
||||||
|
vmove usr/lib/liblldb*so.*
|
||||||
|
vmove /usr/lib/python*
|
||||||
|
# Depend on python3-six instead of conflicting
|
||||||
|
rm ${PKGDESTDIR}/usr/lib/python3*/site-packages/six.py
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
lldb-devel_package() {
|
||||||
|
lib32disabled=yes
|
||||||
|
depends="lldb>=${version}_${revision}"
|
||||||
|
short_desc+=" - LLDB debugger - development files"
|
||||||
|
pkg_install() {
|
||||||
|
vmove usr/include/lldb
|
||||||
|
vmove "usr/lib/liblldb*.so"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
libllvm11_package() {
|
||||||
|
short_desc+=" - runtime library"
|
||||||
|
pkg_install() {
|
||||||
|
vmove "usr/lib/libLLVM-*.so*"
|
||||||
|
}
|
||||||
|
}
|
2
srcpkgs/llvm11/update
Normal file
2
srcpkgs/llvm11/update
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
site=https://releases.llvm.org/
|
||||||
|
pattern="'\K[\d\.]*(?=')"
|
Loading…
Add table
Add a link
Reference in a new issue