I could build both nativesdk-libedit and nativesdk-llvm7 There is: ./meta-openembedded/meta-oe/recipes-devtools/libedit/libedit_20180525-3.1.bb
-----Original Message----- From: Stiffler, Jacob Sent: Friday, August 23, 2019 12:16 PM To: Senicic, Djordje; [email protected] Cc: Senicic, Djordje Subject: Re: [EXTERNAL] [meta-arago] [meta-processor-sdk][PATCHv2 1/5] mesa, llvm, meson: Update llvm to 8.0.1 plus define and use LLVM version globally Djordje, I get an error with this. Have you tried building nativesdk-llvm8? ERROR: Nothing PROVIDES 'nativesdk-libedit' (but virtual:nativesdk:/oe/bld/sources/meta-processor-sdk/recipes-devtools/glow/llvm8_git.bb DEPENDS on or otherwise requires it). And when using "git send-email", you can use the "--no-signed-off-by-cc" flag to prevent CCing those that have "signed-off" in the commit message. - Jake On 8/23/2019 9:58 AM, Djordje Senicic wrote: > - Add missing dependency on libedit > - Define LLVMVERSION on the same lines as GCCVERSION and other tools > - Use LLVMVERSION in mesa and meson.bbclass to get llvm version instead of > hardcoding it > - Use llvm patches unmodified from meta-clang, helps in keeping them in > sync > - Define PREFERRED_VERSION for llvm, llvm-native, nativesdk-llvm > > Signed-off-by: Khem Raj <[email protected]> > Signed-off-by: Richard Purdie <[email protected]> > > The recipe was imported from the OpenEmbedded server > http://cgit.openembedded.org/openembedded-core/commit/meta/recipes-devtools/llvm/llvm_git.bb > commit_id 3c08b638348abd543fc92baf56c28ca16ae6aac6 > Currently this is needed for compiling pytorch glow with CPU backend which > requires llvm7 or later. > To avoid being used globally name before 2020LTS, name of the recipe is not > llvm_git but llvm8_git > > Signed-off-by: Djordje Senicic <[email protected]> > --- > ...ryInfo-Undefine-libc-functions-if-th.patch | 92 +++++++++ > ...-llvm-allow-env-override-of-exe-path.patch | 38 ++++ > recipes-devtools/glow/llvm-glow_git.bb | 180 ++++++++++++++++-- > 3 files changed, 298 insertions(+), 12 deletions(-) > create mode 100644 > recipes-devtools/glow/llvm-glow/0006-llvm-TargetLibraryInfo-Undefine-libc-functions-if-th.patch > create mode 100644 > recipes-devtools/glow/llvm-glow/0007-llvm-allow-env-override-of-exe-path.patch > > diff --git > a/recipes-devtools/glow/llvm-glow/0006-llvm-TargetLibraryInfo-Undefine-libc-functions-if-th.patch > > b/recipes-devtools/glow/llvm-glow/0006-llvm-TargetLibraryInfo-Undefine-libc-functions-if-th.patch > new file mode 100644 > index 0000000..789c308 > --- /dev/null > +++ > b/recipes-devtools/glow/llvm-glow/0006-llvm-TargetLibraryInfo-Undefine-libc-functions-if-th.patch > @@ -0,0 +1,92 @@ > +From 4c08879d2dfbe7face4e679ac8499dc7bff2dd20 Mon Sep 17 00:00:00 2001 > +From: Khem Raj <[email protected]> > +Date: Sat, 21 May 2016 00:33:20 +0000 > +Subject: [PATCH 06/19] llvm: TargetLibraryInfo: Undefine libc functions if > + they are macros > + > +musl defines some functions as macros and not inline functions > +if this is the case then make sure to undefine them > + > +Upstream-Status: Pending > +Signed-off-by: Khem Raj <[email protected]> > +--- > + .../llvm/Analysis/TargetLibraryInfo.def | 21 +++++++++++++++++++ > + 1 file changed, 21 insertions(+) > + > +diff --git a/llvm/include/llvm/Analysis/TargetLibraryInfo.def > b/llvm/include/llvm/Analysis/TargetLibraryInfo.def > +index afed404f04c..876888656f2 100644 > +--- a/llvm/include/llvm/Analysis/TargetLibraryInfo.def > ++++ b/llvm/include/llvm/Analysis/TargetLibraryInfo.def > +@@ -782,6 +782,9 @@ TLI_DEFINE_STRING_INTERNAL("fmodl") > + TLI_DEFINE_ENUM_INTERNAL(fopen) > + TLI_DEFINE_STRING_INTERNAL("fopen") > + /// FILE *fopen64(const char *filename, const char *opentype) > ++#ifdef fopen64 > ++#undef fopen64 > ++#endif > + TLI_DEFINE_ENUM_INTERNAL(fopen64) > + TLI_DEFINE_STRING_INTERNAL("fopen64") > + /// int fork(); > +@@ -829,6 +832,9 @@ TLI_DEFINE_STRING_INTERNAL("fseek") > + /// int fseeko(FILE *stream, off_t offset, int whence); > + TLI_DEFINE_ENUM_INTERNAL(fseeko) > + TLI_DEFINE_STRING_INTERNAL("fseeko") > ++#ifdef fseeko64 > ++#undef fseeko64 > ++#endif > + /// int fseeko64(FILE *stream, off64_t offset, int whence) > + TLI_DEFINE_ENUM_INTERNAL(fseeko64) > + TLI_DEFINE_STRING_INTERNAL("fseeko64") > +@@ -839,6 +845,9 @@ TLI_DEFINE_STRING_INTERNAL("fsetpos") > + TLI_DEFINE_ENUM_INTERNAL(fstat) > + TLI_DEFINE_STRING_INTERNAL("fstat") > + /// int fstat64(int filedes, struct stat64 *buf) > ++#ifdef fstat64 > ++#undef fstat64 > ++#endif > + TLI_DEFINE_ENUM_INTERNAL(fstat64) > + TLI_DEFINE_STRING_INTERNAL("fstat64") > + /// int fstatvfs(int fildes, struct statvfs *buf); > +@@ -854,6 +863,9 @@ TLI_DEFINE_STRING_INTERNAL("ftell") > + TLI_DEFINE_ENUM_INTERNAL(ftello) > + TLI_DEFINE_STRING_INTERNAL("ftello") > + /// off64_t ftello64(FILE *stream) > ++#ifdef ftello64 > ++#undef ftello64 > ++#endif > + TLI_DEFINE_ENUM_INTERNAL(ftello64) > + TLI_DEFINE_STRING_INTERNAL("ftello64") > + /// int ftrylockfile(FILE *file); > +@@ -980,6 +992,9 @@ TLI_DEFINE_STRING_INTERNAL("logl") > + TLI_DEFINE_ENUM_INTERNAL(lstat) > + TLI_DEFINE_STRING_INTERNAL("lstat") > + /// int lstat64(const char *path, struct stat64 *buf); > ++#ifdef lstat64 > ++#undef lstat64 > ++#endif > + TLI_DEFINE_ENUM_INTERNAL(lstat64) > + TLI_DEFINE_STRING_INTERNAL("lstat64") > + /// void *malloc(size_t size); > +@@ -1205,6 +1220,9 @@ TLI_DEFINE_STRING_INTERNAL("sscanf") > + TLI_DEFINE_ENUM_INTERNAL(stat) > + TLI_DEFINE_STRING_INTERNAL("stat") > + /// int stat64(const char *path, struct stat64 *buf); > ++#ifdef stat64 > ++#undef stat64 > ++#endif > + TLI_DEFINE_ENUM_INTERNAL(stat64) > + TLI_DEFINE_STRING_INTERNAL("stat64") > + /// int statvfs(const char *path, struct statvfs *buf); > +@@ -1340,6 +1358,9 @@ TLI_DEFINE_STRING_INTERNAL("times") > + TLI_DEFINE_ENUM_INTERNAL(tmpfile) > + TLI_DEFINE_STRING_INTERNAL("tmpfile") > + /// FILE *tmpfile64(void) > ++#ifdef tmpfile64 > ++#undef tmpfile64 > ++#endif > + TLI_DEFINE_ENUM_INTERNAL(tmpfile64) > + TLI_DEFINE_STRING_INTERNAL("tmpfile64") > + /// int toascii(int c); > +-- > +2.22.0 > + > diff --git > a/recipes-devtools/glow/llvm-glow/0007-llvm-allow-env-override-of-exe-path.patch > > b/recipes-devtools/glow/llvm-glow/0007-llvm-allow-env-override-of-exe-path.patch > new file mode 100644 > index 0000000..f47080c > --- /dev/null > +++ > b/recipes-devtools/glow/llvm-glow/0007-llvm-allow-env-override-of-exe-path.patch > @@ -0,0 +1,38 @@ > +From b66d6f39a374b8df41e7235351e5dee2e81f440c Mon Sep 17 00:00:00 2001 > +From: Martin Kelly <[email protected]> > +Date: Fri, 19 May 2017 00:22:57 -0700 > +Subject: [PATCH 07/19] llvm: allow env override of exe path > + > +When using a native llvm-config from inside a sysroot, we need llvm-config to > +return the libraries, include directories, etc. from inside the sysroot > rather > +than from the native sysroot. Thus provide an env override for calling > +llvm-config from a target sysroot. > + > +Upstream-Status: Pending > +Signed-off-by: Martin Kelly <[email protected]> > +Signed-off-by: Khem Raj <[email protected]> > +--- > + llvm/tools/llvm-config/llvm-config.cpp | 7 +++++++ > + 1 file changed, 7 insertions(+) > + > +diff --git a/llvm/tools/llvm-config/llvm-config.cpp > b/llvm/tools/llvm-config/llvm-config.cpp > +index 7ef7c46a262..a4f7ed82c7b 100644 > +--- a/llvm/tools/llvm-config/llvm-config.cpp > ++++ b/llvm/tools/llvm-config/llvm-config.cpp > +@@ -225,6 +225,13 @@ Typical components:\n\ > + > + /// Compute the path to the main executable. > + std::string GetExecutablePath(const char *Argv0) { > ++ // Hack for Yocto: we need to override the root path when we are using > ++ // llvm-config from within a target sysroot. > ++ const char *Sysroot = std::getenv("YOCTO_ALTERNATE_EXE_PATH"); > ++ if (Sysroot != nullptr) { > ++ return Sysroot; > ++ } > ++ > + // This just needs to be some symbol in the binary; C++ doesn't > + // allow taking the address of ::main however. > + void *P = (void *)(intptr_t)GetExecutablePath; > +-- > +2.22.0 > + > diff --git a/recipes-devtools/glow/llvm-glow_git.bb > b/recipes-devtools/glow/llvm-glow_git.bb > index 58d392b..d3c2642 100644 > --- a/recipes-devtools/glow/llvm-glow_git.bb > +++ b/recipes-devtools/glow/llvm-glow_git.bb > @@ -1,24 +1,180 @@ > -DESCRIPTION = "LLVM release suggested for pytorch glow neural network > compiler" > -HOMEPAGE = "https://github.com/llvm-mirror/llvm" > +# Copyright (C) 2017 Khem Raj <[email protected]> > +# Released under the MIT license (see COPYING.MIT for the terms) > + > +DESCRIPTION = "The LLVM Compiler Infrastructure" > +HOMEPAGE = "http://llvm.org" > +LICENSE = "NCSA" > SECTION = "devel" > -LICENSE = "Apache-2.0" > + > LIC_FILES_CHKSUM = "file://LICENSE.TXT;md5=c6b766a4e85dd28301eeed54a6684648" > -PV = "8.0" > -PR = "r0" > > -DEPENDS = "ninja-native protobuf-native libpng-native protobuf-native > protobuf-c-native gflags-native glog-native" > +DEPENDS = "libffi libxml2 zlib libedit ninja-native llvm8-native" > > -SOLIBVER = "1" > +RDEPENDS_${PN}_append_class-target = " ncurses-terminfo" > + > +inherit cmake pkgconfig > + > +PROVIDES += "llvm${PV}" > > -SRC_URI = > "git://github.com/llvm-mirror/llvm.git;protocol=https;branch=release_80;rev=5563a6a769b48912b9c8052124520610966eda28;destsuffix=git/llvm > \ > - > git://github.com/llvm-mirror/clang.git;protocol=https;branch=release_80;rev=ccfe04576c13497b9c422ceef0b6efe99077a392;destsuffix=git/clang > \ > - " > +LLVM_RELEASE = "${PV}" > +LLVM_DIR = "llvm${LLVM_RELEASE}" > > +SRCREV = "19a71f6bdf2dddb10764939e7f0ec2b98dba76c9" > + > +BRANCH = "release/${MAJOR_VERSION}.x" > +MAJOR_VERSION = "8" > +MINOR_VERSION = "0" > +PATCH_VERSION = "1" > +SOLIBVER = "1" > +PV = "${MAJOR_VERSION}.${MINOR_VERSION}.${PATCH_VERSION}" > +SRC_URI = "git://github.com/llvm/llvm-project.git;branch=${BRANCH} \ > + > file://0006-llvm-TargetLibraryInfo-Undefine-libc-functions-if-th.patch;striplevel=2 > \ > + > file://0007-llvm-allow-env-override-of-exe-path.patch;striplevel=2 \ > + " > > S = "${WORKDIR}/git/llvm" > > -EXTRA_OECMAKE = "-DCMAKE_BUILD_TYPE=Release -DLLVM_INSTALL_UTILS=ON > -DLLVM_ENABLE_PROJECTS=clang" > +LLVM_INSTALL_DIR = "${WORKDIR}/llvm-install" > + > +def get_llvm_arch(bb, d, arch_var): > + import re > + a = d.getVar(arch_var) > + if re.match(r'(i.86|athlon|x86.64)$', a): return 'X86' > + elif re.match(r'arm$', a): return 'ARM' > + elif re.match(r'armeb$', a): return 'ARM' > + elif re.match(r'aarch64$', a): return 'AArch64' > + elif re.match(r'aarch64_be$', a): return 'AArch64' > + elif re.match(r'mips(isa|)(32|64|)(r6|)(el|)$', a): return 'Mips' > + elif re.match(r'p(pc|owerpc)(|64)', a): return 'PowerPC' > + else: > + raise bb.parse.SkipRecipe("Cannot map '%s' to a supported LLVM > architecture" % a) > + > +def get_llvm_host_arch(bb, d): > + return get_llvm_arch(bb, d, 'HOST_ARCH') > + > +# > +# Default to build all OE-Core supported target arches (user overridable). > +# > +LLVM_TARGETS ?= "AMDGPU;${@get_llvm_host_arch(bb, d)}" > + > +ARM_INSTRUCTION_SET_armv5 = "arm" > +ARM_INSTRUCTION_SET_armv4t = "arm" > + > +EXTRA_OECMAKE += "-DLLVM_ENABLE_ASSERTIONS=OFF \ > + -DLLVM_ENABLE_EXPENSIVE_CHECKS=OFF \ > + -DLLVM_ENABLE_PIC=ON \ > + -DLLVM_BINDINGS_LIST='' \ > + -DLLVM_LINK_LLVM_DYLIB=ON \ > + -DLLVM_ENABLE_FFI=ON \ > + -DLLVM_ENABLE_RTTI=ON \ > + -DFFI_INCLUDE_DIR=$(pkg-config --variable=includedir > libffi) \ > + -DLLVM_OPTIMIZED_TABLEGEN=ON \ > + -DLLVM_TARGETS_TO_BUILD='${LLVM_TARGETS}' \ > + -DLLVM_TEMPORARILY_ALLOW_OLD_TOOLCHAIN=ON \ > + -DPYTHON_EXECUTABLE=${HOSTTOOLS_DIR}/python2 \ > + -G Ninja" > + > +EXTRA_OECMAKE_append_class-target = "\ > + -DCMAKE_CROSSCOMPILING:BOOL=ON \ > + -DLLVM_TABLEGEN=${STAGING_BINDIR_NATIVE}/llvm-tblgen${PV} \ > + > -DLLVM_CONFIG_PATH=${STAGING_BINDIR_NATIVE}/llvm-config${PV} \ > + " > + > +EXTRA_OECMAKE_append_class-nativesdk = "\ > + -DCMAKE_CROSSCOMPILING:BOOL=ON \ > + -DLLVM_TABLEGEN=${STAGING_BINDIR_NATIVE}/llvm-tblgen${PV} \ > + > -DLLVM_CONFIG_PATH=${STAGING_BINDIR_NATIVE}/llvm-config${PV} \ > + " > + > +CXXFLAGS_append_class-target_powerpc = " -mlongcall" > + > +do_configure_prepend() { > +# 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 > + sed -ri "s#lib/${LLVM_DIR}#${baselib}/${LLVM_DIR}#g" > ${S}/tools/llvm-config/llvm-config.cpp > +} > + > +do_compile() { > + ninja -v ${PARALLEL_MAKE} > +} > + > +do_compile_class-native() { > + ninja -v ${PARALLEL_MAKE} llvm-config llvm-tblgen > +} > + > +do_install() { > + DESTDIR=${LLVM_INSTALL_DIR} ninja -v install > + install -D -m 0755 ${B}/bin/llvm-config > ${D}${libdir}/${LLVM_DIR}/llvm-config > + > + install -d ${D}${bindir}/${LLVM_DIR} > + cp -r ${LLVM_INSTALL_DIR}${bindir}/* ${D}${bindir}/${LLVM_DIR}/ > + > + install -d ${D}${includedir}/${LLVM_DIR} > + cp -r ${LLVM_INSTALL_DIR}${includedir}/* ${D}${includedir}/${LLVM_DIR}/ > + > + install -d ${D}${libdir}/${LLVM_DIR} > + > + # The LLVM sources have "/lib" embedded and so we cannot completely > rely on the ${libdir} variable > + if [ -d ${LLVM_INSTALL_DIR}${libdir}/ ]; then > + cp -r ${LLVM_INSTALL_DIR}${libdir}/* ${D}${libdir}/${LLVM_DIR}/ > + elif [ -d ${LLVM_INSTALL_DIR}${prefix}/lib ]; then > + cp -r ${LLVM_INSTALL_DIR}${prefix}/lib/* > ${D}${libdir}/${LLVM_DIR}/ > + elif [ -d ${LLVM_INSTALL_DIR}${prefix}/lib64 ]; then > + cp -r ${LLVM_INSTALL_DIR}${prefix}/lib64/* > ${D}${libdir}/${LLVM_DIR}/ > + fi > + > + # Remove unnecessary cmake files > + rm -rf ${D}${libdir}/${LLVM_DIR}/cmake > + > + ln -s ${LLVM_DIR}/libLLVM-${MAJOR_VERSION}${SOLIBSDEV} > ${D}${libdir}/libLLVM-${MAJOR_VERSION}${SOLIBSDEV} > + > + # We'll have to delete the libLLVM.so due to multiple reasons... > + rm -rf ${D}${libdir}/${LLVM_DIR}/libLLVM.so > + rm -rf ${D}${libdir}/${LLVM_DIR}/libLTO.so > +} > + > +do_install_class-native() { > + install -D -m 0755 ${B}/bin/llvm-tblgen ${D}${bindir}/llvm-tblgen${PV} > + install -D -m 0755 ${B}/bin/llvm-config ${D}${bindir}/llvm-config${PV} > + install -D -m 0755 ${B}/lib/libLLVM-${MAJOR_VERSION}.so > ${D}${libdir}/libLLVM-${MAJOR_VERSION}.so > +} > + > +PACKAGES =+ "${PN}-bugpointpasses ${PN}-llvmhello ${PN}-libllvm > ${PN}-liboptremarks ${PN}-liblto" > + > +RRECOMMENDS_${PN}-dev += "${PN}-bugpointpasses ${PN}-llvmhello > ${PN}-liboptremarks" > + > +FILES_${PN}-bugpointpasses = "\ > + ${libdir}/${LLVM_DIR}/BugpointPasses.so \ > +" > + > +FILES_${PN}-libllvm = "\ > + ${libdir}/${LLVM_DIR}/libLLVM-${MAJOR_VERSION}.so \ > + ${libdir}/libLLVM-${MAJOR_VERSION}.so \ > +" > + > +FILES_${PN}-liblto += "\ > + ${libdir}/${LLVM_DIR}/libLTO.so.* \ > +" > + > +FILES_${PN}-liboptremarks += "\ > + ${libdir}/${LLVM_DIR}/libOptRemarks.so.* \ > +" > + > +FILES_${PN}-llvmhello = "\ > + ${libdir}/${LLVM_DIR}/LLVMHello.so \ > +" > + > +FILES_${PN}-dev += " \ > + ${libdir}/${LLVM_DIR}/llvm-config \ > + ${libdir}/${LLVM_DIR}/libOptRemarks.so \ > + > ${libdir}/${LLVM_DIR}/libLLVM-${MAJOR_VERSION}.${MINOR_VERSION}.${PATCH_VERSION}.so > \ > +" > + > +FILES_${PN}-staticdev += "\ > + ${libdir}/${LLVM_DIR}/*.a \ > +" > > -inherit pkgconfig cmake > +INSANE_SKIP_${PN}-libllvm += "dev-so" > > BBCLASSEXTEND = "native nativesdk" _______________________________________________ meta-arago mailing list [email protected] http://arago-project.org/cgi-bin/mailman/listinfo/meta-arago
