mirror of
git://git.openembedded.org/meta-openembedded
synced 2026-05-22 01:26:58 +00:00
llvm: drop 2.8 and 2.9 versions
* mesa is now using 3.3 by default and I don't know about any llvm2* users Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
This commit is contained in:
parent
896aab8ca1
commit
d241efeef8
@ -25,13 +25,90 @@ HOMEPAGE = "http://llvm.org"
|
||||
LICENSE = "NCSA"
|
||||
LIC_FILES_CHKSUM = "file://LICENSE.TXT;md5=d0a3ef0d3e0e8f5cf59e5ffc273ab1f8"
|
||||
|
||||
# 2.* inherits also cmake
|
||||
# 3.* inherits also automake
|
||||
inherit perlnative pythonnative
|
||||
DEPENDS = "libffi libxml2-native llvm-common"
|
||||
|
||||
inherit perlnative pythonnative autotools
|
||||
|
||||
LLVM_RELEASE = "${PV}"
|
||||
LLVM_DIR = "llvm${LLVM_RELEASE}"
|
||||
|
||||
SRC_URI = "http://llvm.org/releases/${PV}/llvm-${PV}.src.tar.gz"
|
||||
S = "${WORKDIR}/llvm-${PV}.src"
|
||||
|
||||
LLVM_BUILD_DIR = "${WORKDIR}/llvm-${PV}.build"
|
||||
LLVM_INSTALL_DIR = "${WORKDIR}/llvm-install"
|
||||
|
||||
EXTRA_OECONF += "--disable-assertions \
|
||||
--enable-debug-runtime \
|
||||
--disable-expensive-checks \
|
||||
--enable-bindings=none \
|
||||
--enable-keep-symbols \
|
||||
--enable-libffi \
|
||||
--enable-optimized \
|
||||
--enable-shared \
|
||||
--enable-targets=host-only"
|
||||
EXTRA_OEMAKE += "REQUIRES_RTTI=1 VERBOSE=1"
|
||||
|
||||
do_configure_prepend() {
|
||||
# Remove RPATHs
|
||||
sed -i 's:$(RPATH) -Wl,$(\(ToolDir\|LibDir\|ExmplDir\))::g' ${S}/Makefile.rules
|
||||
|
||||
# Drop "svn" suffix from version string
|
||||
sed -i 's/${PV}svn/${PV}/g' ${S}/configure
|
||||
|
||||
# Fix paths in llvm-config
|
||||
sed -i "s|sys::path::parent_path(CurrentPath))\.str()|sys::path::parent_path(sys::path::parent_path(CurrentPath))).str()|g" ${S}/tools/llvm-config/llvm-config.cpp
|
||||
sed -ri "s#/(bin|include|lib)(/?\")#/\1/${LLVM_DIR}\2#g" ${S}/tools/llvm-config/llvm-config.cpp
|
||||
|
||||
# Fails to build unless using separate directory from source
|
||||
mkdir -p ${LLVM_BUILD_DIR}
|
||||
cd ${LLVM_BUILD_DIR}
|
||||
}
|
||||
|
||||
do_compile() {
|
||||
cd ${LLVM_BUILD_DIR}
|
||||
oe_runmake \
|
||||
AR="${BUILD_AR}" \
|
||||
CC="${BUILD_CC}" \
|
||||
CFLAGS="${BUILD_CFLAGS}" \
|
||||
CXX="${BUILD_CXX}" \
|
||||
CXXFLAGS="${BUILD_CXXFLAGS}" \
|
||||
CPP="${BUILD_CPP}" \
|
||||
CPPFLAGS="${BUILD_CPPFLAGS}" \
|
||||
NM="${BUILD_NM}" \
|
||||
RANLIB="${BUILD_RANLIB}" \
|
||||
PATH="${STAGING_BINDIR_NATIVE}:$PATH" \
|
||||
cross-compile-build-tools
|
||||
oe_runmake
|
||||
}
|
||||
|
||||
do_install() {
|
||||
cd ${LLVM_BUILD_DIR}
|
||||
oe_runmake DESTDIR=${LLVM_INSTALL_DIR} install
|
||||
|
||||
mv ${LLVM_INSTALL_DIR}${bindir}/${HOST_SYS}-llvm-config-host ${LLVM_INSTALL_DIR}/llvm-config-host
|
||||
|
||||
install -d ${D}${bindir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${bindir}/* ${D}${bindir}/${LLVM_DIR}/
|
||||
|
||||
install -d ${D}${includedir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${includedir}/* ${D}${includedir}/${LLVM_DIR}/
|
||||
|
||||
install -d ${D}${libdir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${libdir}/* ${D}${libdir}/${LLVM_DIR}/
|
||||
ln -s ${LLVM_DIR}/libLLVM-${PV}.so ${D}${libdir}/libLLVM-${PV}.so
|
||||
|
||||
install -d ${D}${docdir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${prefix}/docs/llvm/* ${D}${docdir}/${LLVM_DIR}
|
||||
}
|
||||
|
||||
SYSROOT_PREPROCESS_FUNCS += "llvm_sysroot_preprocess"
|
||||
|
||||
llvm_sysroot_preprocess() {
|
||||
install -d ${SYSROOT_DESTDIR}${bindir_crossscripts}
|
||||
mv ${LLVM_INSTALL_DIR}/llvm-config-host ${SYSROOT_DESTDIR}${bindir_crossscripts}/llvm-config${PV}
|
||||
}
|
||||
|
||||
ALLOW_EMPTY_${PN} = "1"
|
||||
ALLOW_EMPTY_${PN}-staticdev = "1"
|
||||
FILES_${PN} = ""
|
||||
|
||||
@ -1,20 +0,0 @@
|
||||
---
|
||||
ARMJITInfo.cpp | 6 ++++++
|
||||
1 file changed, 6 insertions(+)
|
||||
|
||||
--- a/lib/Target/ARM/ARMJITInfo.cpp
|
||||
+++ b/lib/Target/ARM/ARMJITInfo.cpp
|
||||
@@ -99,7 +99,13 @@
|
||||
// The above twiddling of the saved return addresses allows us to
|
||||
// deallocate everything, including the LR the stub saved, all in one
|
||||
// pop instruction.
|
||||
+#ifndef __thumb__
|
||||
"ldmia sp!, {r0, r1, r2, r3, lr, pc}\n"
|
||||
+#else
|
||||
+ // thumb dont allow lr and pc to be poped in the same instruction.
|
||||
+ "pop {r0, r1, r2, r3, lr}\n"
|
||||
+ "pop {pc}\n"
|
||||
+#endif
|
||||
);
|
||||
#else // Not an ARM host
|
||||
void ARMCompilationCallback() {
|
||||
@ -1,113 +0,0 @@
|
||||
Index: llvm-2.8/lib/ExecutionEngine/JIT/JIT.cpp
|
||||
===================================================================
|
||||
--- llvm-2.8.orig/lib/ExecutionEngine/JIT/JIT.cpp 2010-08-17 18:19:18.000000000 +0200
|
||||
+++ llvm-2.8/lib/ExecutionEngine/JIT/JIT.cpp 2011-12-19 21:16:21.884288536 +0100
|
||||
@@ -252,7 +252,12 @@
|
||||
MutexGuard guard(Lock);
|
||||
JITs.erase(jit);
|
||||
}
|
||||
- void *getPointerToNamedFunction(const char *Name) const {
|
||||
+ bool empty() {
|
||||
+ MutexGuard guard(Lock);
|
||||
+ return JITs.empty();
|
||||
+ }
|
||||
+ void *getPointerToNamedFunction(const char *Name,
|
||||
+ bool AbortOnFailure = true) const {
|
||||
MutexGuard guard(Lock);
|
||||
assert(JITs.size() != 0 && "No Jit registered");
|
||||
//search function in every instance of JIT
|
||||
@@ -264,7 +269,19 @@
|
||||
}
|
||||
// The function is not available : fallback on the first created (will
|
||||
// search in symbol of the current program/library)
|
||||
- return (*JITs.begin())->getPointerToNamedFunction(Name);
|
||||
+ return (*JITs.begin())->getPointerToNamedFunction(Name, AbortOnFailure);
|
||||
+ }
|
||||
+ void *getPointerToGlobalIfAvailable(GlobalValue *V) const {
|
||||
+ MutexGuard guard(Lock);
|
||||
+ assert(JITs.size() != 0 && "No Jit registered");
|
||||
+ //search function in every instance of JIT
|
||||
+ for (SmallPtrSet<JIT*, 1>::const_iterator Jit = JITs.begin(),
|
||||
+ end = JITs.end();
|
||||
+ Jit != end; ++Jit) {
|
||||
+ if (void *Ptr = (*Jit)->getPointerToGlobalIfAvailable(V))
|
||||
+ return Ptr;
|
||||
+ }
|
||||
+ return 0;
|
||||
}
|
||||
};
|
||||
ManagedStatic<JitPool> AllJits;
|
||||
@@ -280,6 +297,22 @@
|
||||
}
|
||||
}
|
||||
|
||||
+extern "C" {
|
||||
+ // getPointerToNamedFunctionOrNull - same as the above, but returns
|
||||
+ // NULL instead of aborting if the function cannot be found.
|
||||
+ void *getPointerToNamedFunctionOrNull(const char *Name) {
|
||||
+ return !AllJits->empty() ? AllJits->getPointerToNamedFunction(Name, false) : 0;
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
+extern "C" {
|
||||
+ // getPointerToGlobalIfAvailable - same as the above, but for global
|
||||
+ // variables, and only for those that have been codegened already.
|
||||
+ void *getPointerToGlobalIfAvailable(GlobalValue *V) {
|
||||
+ return !AllJits->empty() ? AllJits->getPointerToGlobalIfAvailable(V) : 0;
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
JIT::JIT(Module *M, TargetMachine &tm, TargetJITInfo &tji,
|
||||
JITMemoryManager *JMM, CodeGenOpt::Level OptLevel, bool GVsWithCode)
|
||||
: ExecutionEngine(M), TM(tm), TJI(tji), AllocateGVsWithCode(GVsWithCode),
|
||||
Index: llvm-2.8/lib/Target/ARM/ARMISelLowering.cpp
|
||||
===================================================================
|
||||
--- llvm-2.8.orig/lib/Target/ARM/ARMISelLowering.cpp 2010-09-03 03:35:08.000000000 +0200
|
||||
+++ llvm-2.8/lib/Target/ARM/ARMISelLowering.cpp 2011-12-19 21:16:21.884288536 +0100
|
||||
@@ -1119,6 +1119,9 @@
|
||||
}
|
||||
}
|
||||
|
||||
+extern "C" void *getPointerToNamedFunctionOrNull(const char *Name);
|
||||
+extern "C" void *getPointerToGlobalIfAvailable(GlobalValue *Value);
|
||||
+
|
||||
/// LowerCall - Lowering a call into a callseq_start <-
|
||||
/// ARMISD:CALL <- callseq_end chain. Also add input and output parameter
|
||||
/// nodes.
|
||||
@@ -1272,6 +1275,26 @@
|
||||
InFlag =SDValue();
|
||||
}
|
||||
|
||||
+ EVT PtrVT = DAG.getTargetLoweringInfo().getPointerTy();
|
||||
+
|
||||
+ // XXX Work around for http://llvm.org/bugs/show_bug.cgi?id=5201
|
||||
+ // and http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=399
|
||||
+ // for Shark.
|
||||
+ //
|
||||
+ // If the callee is an ExternalSymbol node, and the symbol can be
|
||||
+ // resolved to a function pointer, then insert that pointer as a
|
||||
+ // constant. This causes the next block of code to fall into the
|
||||
+ // block that emits an indirect call. This works around
|
||||
+ //
|
||||
+ // This works for Shark because the only kinds of call that Shark
|
||||
+ // makes that do not already fall into the indirect call block are
|
||||
+ // calls to pre-existing external functions.
|
||||
+ if (ExternalSymbolSDNode *S = dyn_cast<ExternalSymbolSDNode>(Callee)) {
|
||||
+ void *FuncPtr = getPointerToNamedFunctionOrNull(S->getSymbol());
|
||||
+ if (FuncPtr)
|
||||
+ Callee = DAG.getConstant((uint64_t) FuncPtr, PtrVT);
|
||||
+ }
|
||||
+
|
||||
// If the callee is a GlobalAddress/ExternalSymbol node (quite common, every
|
||||
// direct call is) turn it into a TargetGlobalAddress/TargetExternalSymbol
|
||||
// node so that legalize doesn't hack it.
|
||||
Index: llvm-2.8/tools/llc/CMakeLists.txt
|
||||
===================================================================
|
||||
--- llvm-2.8.orig/tools/llc/CMakeLists.txt 2009-09-03 00:45:31.000000000 +0200
|
||||
+++ llvm-2.8/tools/llc/CMakeLists.txt 2011-12-19 21:16:21.884288536 +0100
|
||||
@@ -1,4 +1,4 @@
|
||||
-set(LLVM_LINK_COMPONENTS ${LLVM_TARGETS_TO_BUILD} bitreader asmparser)
|
||||
+set(LLVM_LINK_COMPONENTS ${LLVM_TARGETS_TO_BUILD} jit bitreader asmparser)
|
||||
|
||||
add_llvm_tool(llc
|
||||
llc.cpp
|
||||
@ -1,12 +0,0 @@
|
||||
Index: llvm-2.8/lib/ExecutionEngine/JIT/Intercept.cpp
|
||||
===================================================================
|
||||
--- llvm-2.8.orig/lib/ExecutionEngine/JIT/Intercept.cpp 2012-05-14 18:31:21.008318473 +0200
|
||||
+++ llvm-2.8/lib/ExecutionEngine/JIT/Intercept.cpp 2012-05-14 18:32:53.523734850 +0200
|
||||
@@ -19,6 +19,7 @@
|
||||
#include "llvm/Support/ErrorHandling.h"
|
||||
#include "llvm/System/DynamicLibrary.h"
|
||||
#include "llvm/Config/config.h"
|
||||
+#include <unistd.h>
|
||||
using namespace llvm;
|
||||
|
||||
// AtExitHandlers - List of functions to call when the program exits,
|
||||
@ -1,12 +0,0 @@
|
||||
Index: llvm-2.8/tools/CMakeLists.txt
|
||||
===================================================================
|
||||
--- llvm-2.8.orig/tools/CMakeLists.txt 2010-08-24 11:16:51.000000000 +0200
|
||||
+++ llvm-2.8/tools/CMakeLists.txt 2011-12-21 16:47:47.718508763 +0100
|
||||
@@ -14,7 +14,6 @@
|
||||
add_subdirectory(opt)
|
||||
add_subdirectory(llvm-as)
|
||||
add_subdirectory(llvm-dis)
|
||||
-add_subdirectory(llvm-mc)
|
||||
|
||||
add_subdirectory(llc)
|
||||
add_subdirectory(llvm-ranlib)
|
||||
@ -1,16 +0,0 @@
|
||||
require llvm.inc
|
||||
require llvm2.inc
|
||||
|
||||
PR = "r3"
|
||||
|
||||
SRC_URI += " \
|
||||
file://30may-llvm2.8-pr399-ppc-arm.patch \
|
||||
file://0019-issue6065.patch \
|
||||
file://add-unistd.patch \
|
||||
file://llvm-mc_disable.patch \
|
||||
"
|
||||
|
||||
EXTRA_OECMAKE += " -DBUILD_SHARED_LIBS:BOOL=OFF "
|
||||
|
||||
SRC_URI[md5sum] = "220d361b4d17051ff4bb21c64abe05ba"
|
||||
SRC_URI[sha256sum] = "25addb742f1c6cc12877ed0ee924dda962d848368ee095be8e48342ae613d43b"
|
||||
@ -1,35 +0,0 @@
|
||||
--- llvm-2.9.orig/lib/Target/ARM/ARMJITInfo.cpp 2013-04-19 14:49:28.063566919 +0200
|
||||
+++ llvm-2.9/lib/Target/ARM/ARMJITInfo.cpp 2013-04-19 15:24:31.065435029 +0200
|
||||
@@ -59,7 +59,17 @@
|
||||
// for the real target function right now. We have to act as if this
|
||||
// whole compilation callback doesn't exist as far as the caller is
|
||||
// concerned, so we can't just preserve the callee saved regs.
|
||||
+ // stmdb introduced in http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/ARMJITInfo.cpp?diff_format=h&r1=57911&r2=57910&pathrev=57911
|
||||
+ // but fails on armv4t
|
||||
+ // | {standard input}: Assembler messages:
|
||||
+ // | {standard input}:22: Error: selected processor does not support Thumb mode `stmdb sp!,{r0,r1,r2,r3,lr}'
|
||||
+ // | {standard input}:31: Error: lo register required -- `ldmia sp!,{r0,r1,r2,r3,lr}'
|
||||
+ // | {standard input}:32: Error: lo register required -- `ldr pc,[sp],#4'
|
||||
+#ifndef __thumb__
|
||||
"stmdb sp!, {r0, r1, r2, r3, lr}\n"
|
||||
+#else
|
||||
+ "push {r0, r1, r2, r3, lr}\n"
|
||||
+#endif
|
||||
#if (defined(__VFP_FP__) && !defined(__SOFTFP__))
|
||||
"fstmfdd sp!, {d0, d1, d2, d3, d4, d5, d6, d7}\n"
|
||||
#endif
|
||||
@@ -99,8 +109,14 @@
|
||||
// The above twiddling of the saved return addresses allows us to
|
||||
// deallocate everything, including the LR the stub saved, with two
|
||||
// updating load instructions.
|
||||
+#ifndef __thumb__
|
||||
"ldmia sp!, {r0, r1, r2, r3, lr}\n"
|
||||
"ldr pc, [sp], #4\n"
|
||||
+#else
|
||||
+ // thumb dont allow lr and pc to be poped in the same instruction.
|
||||
+ "pop {r0, r1, r2, r3, lr}\n"
|
||||
+ "pop {pc}\n"
|
||||
+#endif
|
||||
);
|
||||
#else // Not an ARM host
|
||||
void ARMCompilationCallback() {
|
||||
@ -1,16 +0,0 @@
|
||||
Upstream-Status: Pending
|
||||
|
||||
Imported from http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=673266
|
||||
|
||||
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
|
||||
|
||||
--- a/lib/ExecutionEngine/JIT/Intercept.cpp 2012-05-17 16:11:46.956180361 +0200
|
||||
+++ b/lib/ExecutionEngine/JIT/Intercept.cpp 2012-05-17 16:14:35.256184996 +0200
|
||||
@@ -52,6 +52,7 @@
|
||||
#include <sys/stat.h>
|
||||
#endif
|
||||
#include <fcntl.h>
|
||||
+#include <unistd.h>
|
||||
/* stat functions are redirecting to __xstat with a version number. On x86-64
|
||||
* linking with libc_nonshared.a and -Wl,--export-dynamic doesn't make 'stat'
|
||||
* available as an exported symbol, so we have to add it explicitly.
|
||||
@ -1,14 +0,0 @@
|
||||
Index: llvm-2.9/include/llvm/Support/FEnv.h
|
||||
===================================================================
|
||||
--- llvm-2.9.orig/include/llvm/Support/FEnv.h 2010-11-29 20:44:50.000000000 +0100
|
||||
+++ llvm-2.9/include/llvm/Support/FEnv.h 2011-11-18 18:42:22.580161297 +0100
|
||||
@@ -17,6 +17,9 @@
|
||||
|
||||
#include "llvm/Config/config.h"
|
||||
#include <cerrno>
|
||||
+
|
||||
+#undef HAVE_FENV_H
|
||||
+
|
||||
#ifdef HAVE_FENV_H
|
||||
#include <fenv.h>
|
||||
#endif
|
||||
@ -1,21 +0,0 @@
|
||||
require llvm.inc
|
||||
require llvm2.inc
|
||||
|
||||
PR = "r3"
|
||||
|
||||
SRC_URI += "file://0035-gcc-4.7.patch"
|
||||
|
||||
ARM_INSTRUCTION_SET = "arm"
|
||||
|
||||
# 0019-issue6065.patch is still needed but a bit modified, because it was resolved by
|
||||
# http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/ARMJITInfo.cpp?r1=120304&r2=124694&pathrev=124694
|
||||
# http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/ARM/ARMJITInfo.cpp?diff_format=h&r1=57911&r2=57910&pathrev=57911
|
||||
# and still it fails with
|
||||
# {standard input}:31: Error: invalid register list to push/pop instruction -- `pop {r0,r1,r2,r3,lr}'
|
||||
# make[2]: *** [lib/Target/ARM/CMakeFiles/LLVMARMCodeGen.dir/ARMJITInfo.cpp.o] Error 1
|
||||
# SRC_URI += "file://0019-issue6065.patch"
|
||||
|
||||
SRC_URI_append_libc-uclibc = " file://arm_fenv_uclibc.patch "
|
||||
|
||||
SRC_URI[md5sum] = "793138412d2af2c7c7f54615f8943771"
|
||||
SRC_URI[sha256sum] = "661236cfa17428b48cfa9cbb9909f7569c64b8ecd219fd91dbc00e3b557b3779"
|
||||
@ -1,170 +0,0 @@
|
||||
DEPENDS = "llvm${LLVM_RELEASE}-native llvm-common perl-native"
|
||||
DEPENDS_class-native = "llvm-common-native cmake-native"
|
||||
|
||||
SRC_URI = "http://llvm.org/releases/${PV}/llvm-${PV}.tgz"
|
||||
S = "${WORKDIR}/llvm-${PV}"
|
||||
|
||||
LIC_FILES_CHKSUM = "file://LICENSE.TXT;md5=0ac5f799a2d89477c75b0a378b221855"
|
||||
|
||||
inherit cmake
|
||||
|
||||
# Defines the LLVM supported arches. By now we always build either for ${BUILD}
|
||||
# (native) or ${TARGET}. In the future it may make sense to enable all backends
|
||||
# for the non-native build. The decision which backends are used is made by
|
||||
# the 3rd party program or library that uses llvm anyway.
|
||||
LLVM_ARCH = "${@get_llvm_arch(d)}"
|
||||
|
||||
# This is used for generating the install directory for the llvm libraries,
|
||||
# binaries and headers. It makes side by side installation of those possible.
|
||||
LLVM_RELEASE = "${PV}"
|
||||
|
||||
BBCLASSEXTEND = "native"
|
||||
|
||||
LLVM_INSTALL_DIR = "${B}/llvm-install"
|
||||
|
||||
# other architectures require X86 available,
|
||||
LLVM_EXTRA_ARCH = "X86;"
|
||||
LLVM_EXTRA_ARCH_x86 = ""
|
||||
LLVM_EXTRA_ARCH_x86-64 = ""
|
||||
|
||||
EXTRA_OECMAKE = "\
|
||||
-DLLVM_TABLEGEN=${STAGING_BINDIR_NATIVE}/${LLVM_DIR}/tblgen \
|
||||
-DLLVM_TARGETS_TO_BUILD="${LLVM_EXTRA_ARCH}${LLVM_ARCH}" \
|
||||
-DCMAKE_LINKER:FILEPATH=${LD} \
|
||||
-DCMAKE_AR:FILEPATH=${AR} \
|
||||
-DCMAKE_OBJCOPY:FILEPATH=${OBJCOPY} \
|
||||
-DCMAKE_OBJDUMP:FILEPATH=${OBJDUMP} \
|
||||
-DCMAKE_RANLIB:FILEPATH=${RANLIB} \
|
||||
-DCMAKE_STRIP:FILEPATH=${STRIP} \
|
||||
-DNM_PATH:FILEPATH=${NM} \
|
||||
-DLLVM_ENABLE_PIC:BOOL=ON \
|
||||
-DLLVM_TARGET_ARCH:STRING=${LLVM_ARCH} \
|
||||
-DLLVM_ENABLE_ASSERTIONS:BOOL=ON \
|
||||
-DCMAKE_BUILD_TYPE:STRING=RelWithDebInfo \
|
||||
-DBUILD_SHARED_LIBS:BOOL=ON \
|
||||
-DCMAKE_SKIP_BUILD_RPATH:BOOL=ON \
|
||||
"
|
||||
|
||||
# We need to reset this to avoid breakage as we build out of tree
|
||||
TOOLCHAIN_OPTIONS = ""
|
||||
|
||||
# the difference to the non-native build is that we do not need
|
||||
# to declare the location of the tblgen executable.
|
||||
EXTRA_OECMAKE_class-native = "\
|
||||
-DLLVM_TARGETS_TO_BUILD=${LLVM_ARCH} \
|
||||
-DCMAKE_LINKER:FILEPATH=${LD} \
|
||||
-DCMAKE_AR:FILEPATH=${AR} \
|
||||
-DCMAKE_OBJCOPY:FILEPATH=${OBJCOPY} \
|
||||
-DCMAKE_OBJDUMP:FILEPATH=${OBJDUMP} \
|
||||
-DCMAKE_RANLIB:FILEPATH=${RANLIB} \
|
||||
-DCMAKE_STRIP:FILEPATH=${STRIP} \
|
||||
-DNM_PATH:FILEPATH=${NM} \
|
||||
"
|
||||
|
||||
base_do_compile_prepend() {
|
||||
# Avoid *** No rule to make target `native/bin/tblgen', needed by `include/llvm/Intrinsics.gen.tmp'
|
||||
oe_runmake tblgen
|
||||
}
|
||||
|
||||
do_install() {
|
||||
# Install into a private directory to be able to reorganize the files.
|
||||
cd ${B}
|
||||
oe_runmake DESTDIR=${LLVM_INSTALL_DIR} install
|
||||
|
||||
# Create our custom target directories
|
||||
install -d ${D}${bindir}/${LLVM_DIR}
|
||||
install -d ${D}${includedir}/${LLVM_DIR}
|
||||
install -d ${D}${libdir}/${LLVM_DIR}
|
||||
|
||||
# Move headers into their own directory
|
||||
cp -R ${LLVM_INSTALL_DIR}/${prefix}/include/llvm \
|
||||
${D}${includedir}/${LLVM_DIR}/
|
||||
cp -R ${LLVM_INSTALL_DIR}/${prefix}/include/llvm-c \
|
||||
${D}${includedir}/${LLVM_DIR}/
|
||||
|
||||
find ${LLVM_INSTALL_DIR}/${prefix}/lib -name "*" -maxdepth 1 -exec \
|
||||
install {} ${D}${libdir}/${LLVM_DIR} \;
|
||||
|
||||
# I dont know another way out. Binaries are installed into a special subdir
|
||||
find ${LLVM_INSTALL_DIR}/${prefix}/bin -name "*" -maxdepth 1 -exec \
|
||||
install {} ${D}${bindir}/${LLVM_DIR} \;
|
||||
|
||||
# LLVM does not install this by default.
|
||||
install bin/tblgen ${D}${bindir}/${LLVM_DIR}
|
||||
}
|
||||
|
||||
SYSROOT_PREPROCESS_FUNCS_append_class-target = " llvm_sysroot_preprocess"
|
||||
|
||||
llvm_sysroot_preprocess() {
|
||||
cd ${B}
|
||||
|
||||
# Fix the paths in the config script to make it find the binaries and
|
||||
# library files. Doing so allows 3rd party configure scripts working
|
||||
# unmodified.
|
||||
sed -e's!my.*ABS_RUN_DIR =.*!my $ABS_RUN_DIR = "${STAGING_DIR_TARGET}";!' \
|
||||
-e's!my.*INCLUDEDIR =.*!my $INCLUDEDIR = "${STAGING_INCDIR}/${LLVM_DIR}";!' \
|
||||
-e's!my.*LIBDIR.*!my $LIBDIR = "${STAGING_LIBDIR}/${LLVM_DIR}";!' \
|
||||
-e's!my.*BINDIR.*!my $BINDIR = "${STAGING_BINDIR}/${LLVM_DIR}";!' \
|
||||
bin/llvm-config > bin/llvm-config${LLVM_RELEASE}
|
||||
|
||||
install -d ${SYSROOT_DESTDIR}${bindir_crossscripts}
|
||||
install -m 0755 bin/llvm-config${LLVM_RELEASE} ${SYSROOT_DESTDIR}${bindir_crossscripts}
|
||||
}
|
||||
|
||||
do_install_class-native() {
|
||||
# Install into a private directory to be able to reorganize the files.
|
||||
cd ${B}
|
||||
oe_runmake DESTDIR=${LLVM_INSTALL_DIR} install
|
||||
|
||||
# Create our custom target directories
|
||||
install -d ${D}${bindir}/${LLVM_DIR}
|
||||
install -d ${D}${includedir}/${LLVM_DIR}
|
||||
install -d ${D}${libdir}/${LLVM_DIR}
|
||||
|
||||
# Move headers into their own directory
|
||||
cp -R ${LLVM_INSTALL_DIR}/${prefix}/include/llvm \
|
||||
${D}${includedir}/${LLVM_DIR}/
|
||||
cp -R ${LLVM_INSTALL_DIR}/${prefix}/include/llvm-c \
|
||||
${D}${includedir}/${LLVM_DIR}/
|
||||
|
||||
find ${LLVM_INSTALL_DIR}/${prefix}/lib -name "*" -maxdepth 1 -exec \
|
||||
install {} ${D}${libdir}/${LLVM_DIR} \;
|
||||
|
||||
# I dont know another way out. Binaries are installed into a special subdir
|
||||
find ${LLVM_INSTALL_DIR}/${prefix}/bin -name "*" -maxdepth 1 -exec \
|
||||
install {} ${D}${bindir}/${LLVM_DIR} \;
|
||||
|
||||
# LLVM does not install this by default.
|
||||
install bin/tblgen ${D}${bindir}/${LLVM_DIR}
|
||||
|
||||
# Fix the paths in the config script to make it find the binaries and
|
||||
# library files. Doing so allows 3rd party configure scripts working
|
||||
# unmodified.
|
||||
sed -e's!my.*ABS_RUN_DIR =.*!my $ABS_RUN_DIR = "${STAGING_DIR_TARGET}";!' \
|
||||
-e's!my.*INCLUDEDIR =.*!my $INCLUDEDIR = "${STAGING_INCDIR}/${LLVM_DIR}";!' \
|
||||
-e's!my.*LIBDIR.*!my $LIBDIR = "${STAGING_LIBDIR}/${LLVM_DIR}";!' \
|
||||
-e's!my.*BINDIR.*!my $BINDIR = "${STAGING_BINDIR}/${LLVM_DIR}";!' \
|
||||
bin/llvm-config > bin/llvm-config${LLVM_RELEASE}
|
||||
|
||||
install -d ${D}${bindir}
|
||||
install -m 0755 bin/llvm-config${LLVM_RELEASE} ${D}${bindir}
|
||||
}
|
||||
|
||||
# Retrieve the target in a way that is compatible to the arch
|
||||
# value in llvm (>= 2.5)
|
||||
def get_llvm_arch(d):
|
||||
import bb;
|
||||
|
||||
arch = bb.data.getVar('TARGET_ARCH', d, 1)
|
||||
if arch == "x86_64" or arch == "i486" or arch == "i586" or arch == "i686":
|
||||
arch = "X86"
|
||||
elif arch == "arm":
|
||||
arch = "ARM"
|
||||
elif arch == "mipsel" or arch == "mips":
|
||||
arch = "mips"
|
||||
elif arch == "powerpc" or arch == "powerpc64":
|
||||
arch = "PowerPC"
|
||||
else:
|
||||
bb.warn("%s does not support %s yet" % (bb.data.getVar('PN', d, 1), arch) );
|
||||
|
||||
return arch
|
||||
@ -1,5 +1,4 @@
|
||||
require llvm.inc
|
||||
require llvm3.inc
|
||||
|
||||
DEPENDS += "zlib"
|
||||
EXTRA_OECONF += "--enable-zlib"
|
||||
|
||||
@ -1,80 +0,0 @@
|
||||
DEPENDS = "libffi libxml2-native llvm-common"
|
||||
|
||||
SRC_URI = "http://llvm.org/releases/${PV}/llvm-${PV}.src.tar.gz"
|
||||
S = "${WORKDIR}/llvm-${PV}.src"
|
||||
|
||||
inherit autotools
|
||||
|
||||
LLVM_BUILD_DIR = "${WORKDIR}/llvm-${PV}.build"
|
||||
LLVM_INSTALL_DIR = "${WORKDIR}/llvm-install"
|
||||
|
||||
EXTRA_OECONF += "--disable-assertions \
|
||||
--enable-debug-runtime \
|
||||
--disable-expensive-checks \
|
||||
--enable-bindings=none \
|
||||
--enable-keep-symbols \
|
||||
--enable-libffi \
|
||||
--enable-optimized \
|
||||
--enable-shared \
|
||||
--enable-targets=host-only"
|
||||
EXTRA_OEMAKE += "REQUIRES_RTTI=1 VERBOSE=1"
|
||||
|
||||
do_configure_prepend() {
|
||||
# Remove RPATHs
|
||||
sed -i 's:$(RPATH) -Wl,$(\(ToolDir\|LibDir\|ExmplDir\))::g' ${S}/Makefile.rules
|
||||
|
||||
# Drop "svn" suffix from version string
|
||||
sed -i 's/${PV}svn/${PV}/g' ${S}/configure
|
||||
|
||||
# Fix paths in llvm-config
|
||||
sed -i "s|sys::path::parent_path(CurrentPath))\.str()|sys::path::parent_path(sys::path::parent_path(CurrentPath))).str()|g" ${S}/tools/llvm-config/llvm-config.cpp
|
||||
sed -ri "s#/(bin|include|lib)(/?\")#/\1/${LLVM_DIR}\2#g" ${S}/tools/llvm-config/llvm-config.cpp
|
||||
|
||||
# Fails to build unless using separate directory from source
|
||||
mkdir -p ${LLVM_BUILD_DIR}
|
||||
cd ${LLVM_BUILD_DIR}
|
||||
}
|
||||
|
||||
do_compile() {
|
||||
cd ${LLVM_BUILD_DIR}
|
||||
oe_runmake \
|
||||
AR="${BUILD_AR}" \
|
||||
CC="${BUILD_CC}" \
|
||||
CFLAGS="${BUILD_CFLAGS}" \
|
||||
CXX="${BUILD_CXX}" \
|
||||
CXXFLAGS="${BUILD_CXXFLAGS}" \
|
||||
CPP="${BUILD_CPP}" \
|
||||
CPPFLAGS="${BUILD_CPPFLAGS}" \
|
||||
NM="${BUILD_NM}" \
|
||||
RANLIB="${BUILD_RANLIB}" \
|
||||
PATH="${STAGING_BINDIR_NATIVE}:$PATH" \
|
||||
cross-compile-build-tools
|
||||
oe_runmake
|
||||
}
|
||||
|
||||
do_install() {
|
||||
cd ${LLVM_BUILD_DIR}
|
||||
oe_runmake DESTDIR=${LLVM_INSTALL_DIR} install
|
||||
|
||||
mv ${LLVM_INSTALL_DIR}${bindir}/${HOST_SYS}-llvm-config-host ${LLVM_INSTALL_DIR}/llvm-config-host
|
||||
|
||||
install -d ${D}${bindir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${bindir}/* ${D}${bindir}/${LLVM_DIR}/
|
||||
|
||||
install -d ${D}${includedir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${includedir}/* ${D}${includedir}/${LLVM_DIR}/
|
||||
|
||||
install -d ${D}${libdir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${libdir}/* ${D}${libdir}/${LLVM_DIR}/
|
||||
ln -s ${LLVM_DIR}/libLLVM-${PV}.so ${D}${libdir}/libLLVM-${PV}.so
|
||||
|
||||
install -d ${D}${docdir}/${LLVM_DIR}
|
||||
mv ${LLVM_INSTALL_DIR}${prefix}/docs/llvm/* ${D}${docdir}/${LLVM_DIR}
|
||||
}
|
||||
|
||||
SYSROOT_PREPROCESS_FUNCS += "llvm_sysroot_preprocess"
|
||||
|
||||
llvm_sysroot_preprocess() {
|
||||
install -d ${SYSROOT_DESTDIR}${bindir_crossscripts}
|
||||
mv ${LLVM_INSTALL_DIR}/llvm-config-host ${SYSROOT_DESTDIR}${bindir_crossscripts}/llvm-config${PV}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user