On 09/26/2017 04:19 AM, Maxin B. John wrote: > Hi Philip, > > On Mon, Sep 25, 2017 at 4:05 PM, Philip Balister <phi...@balister.org> wrote: >> On 09/24/2017 05:05 PM, Maxin B. John wrote: >>> keep a copy of bdwgc recipe in meta-java from meta-oe layer. >>> cacao in meta-java depends on bdwgc. >> >> Duplicating recipes in recipes is frowned upon. > > Thanks for the review. Makes sense here. Will try to find a way to avoid this. > >> Shouldn't we have the discussion why you are not proposing this for >> Openembedded-core instead of duplicating the recipe? Duping a recipe >> just to drop a layer dependency isn't a long term solution. > > agree.
Meta-oe has one recipe that uses it. I'm not sure about other layers. Does the layer index let us search for recipes that depend on another recipe? Philip > >> Philip > > Best Regards, > Maxin > >>> >>> Signed-off-by: Maxin B. John <maxin.j...@intel.com> >>> --- >>> ...ac-add-check-for-NO_GETCONTEXT-definition.patch | 29 +++++++++++++++ >>> recipes-extended/bdwgc/bdwgc/musl_header_fix.patch | 27 ++++++++++++++ >>> recipes-extended/bdwgc/bdwgc_7.6.0.bb | 42 >>> ++++++++++++++++++++++ >>> 3 files changed, 98 insertions(+) >>> create mode 100644 >>> recipes-extended/bdwgc/bdwgc/0001-configure.ac-add-check-for-NO_GETCONTEXT-definition.patch >>> create mode 100644 recipes-extended/bdwgc/bdwgc/musl_header_fix.patch >>> create mode 100644 recipes-extended/bdwgc/bdwgc_7.6.0.bb >>> >>> diff --git >>> a/recipes-extended/bdwgc/bdwgc/0001-configure.ac-add-check-for-NO_GETCONTEXT-definition.patch >>> >>> b/recipes-extended/bdwgc/bdwgc/0001-configure.ac-add-check-for-NO_GETCONTEXT-definition.patch >>> new file mode 100644 >>> index 0000000..8ef774f >>> --- /dev/null >>> +++ >>> b/recipes-extended/bdwgc/bdwgc/0001-configure.ac-add-check-for-NO_GETCONTEXT-definition.patch >>> @@ -0,0 +1,29 @@ >>> +configure.ac: add check for NO_GETCONTEXT definition >>> + >>> +Signed-off-by: Samuel Martin <s.marti...@gmail.com> >>> +[yann.morin.1...@free.fr: add a comment, change variable name, use >>> + AS_IF, remove debug traces, use AC_CHECK_FUNCS (as suggested by >>> + Thomas)] >>> +Signed-off-by: "Yann E. MORIN" <yann.morin.1...@free.fr> >>> +Cc: Thomas Petazzoni <thomas.petazz...@free-electrons.com> >>> + >>> +--- >>> +Upstream-Status: Pending >>> + configure.ac | 6 ++++++ >>> + 1 file changed, 6 insertions(+) >>> + >>> +--- bdwgc-7.2f.orig/configure.ac 2014-06-01 19:00:47.000000000 +0200 >>> ++++ bdwgc-7.2f/configure.ac 2014-12-23 14:13:11.585716713 +0100 >>> +@@ -365,6 +365,12 @@ >>> + AC_MSG_RESULT($ac_cv_fno_strict_aliasing) >>> + fi >>> + >>> ++# Check for getcontext (uClibc can be configured without it, for example) >>> ++AC_CHECK_FUNCS([getcontext]) >>> ++AS_IF([test "$ac_cv_func_getcontext" = "no"], >>> ++ [CFLAGS="$CFLAGS -DNO_GETCONTEXT" >>> ++ CPPFLAGS="$CPPFLAGS -DNO_GETCONTEXT"]) >>> ++ >>> + case "$host" in >>> + # While IRIX 6 has libdl for the O32 and N32 ABIs, it's missing for N64 >>> + # and unnecessary everywhere. >>> diff --git a/recipes-extended/bdwgc/bdwgc/musl_header_fix.patch >>> b/recipes-extended/bdwgc/bdwgc/musl_header_fix.patch >>> new file mode 100644 >>> index 0000000..4a18496 >>> --- /dev/null >>> +++ b/recipes-extended/bdwgc/bdwgc/musl_header_fix.patch >>> @@ -0,0 +1,27 @@ >>> +Add missing header to avoid: >>> + >>> +| 1472659610.016355: ../git/pthread_stop_world.c: In function >>> 'GC_brief_async_signal_safe_sleep': >>> +| 1472659610.0540252: ../git/pthread_stop_world.c:397:22: error: storage >>> size of 'tv' isn't known >>> +| 1472659610.0540252: struct timeval tv; >>> +| 1472659610.0540252: ^~ >>> +| 1472659610.054099: ../git/pthread_stop_world.c:397:22: warning: unused >>> variable 'tv' [-Wunused-variable] >>> +| 1472659610.054099: struct timeval tv; >>> +| 1472659610.054099: ^~ >>> +| 1472659610.054099: Makefile:1530: recipe for target >>> 'pthread_stop_world.lo' failed >>> + >>> +in musl builds. >>> + >>> +Upstream-Status: Pending >>> + >>> +Index: git/pthread_stop_world.c >>> +=================================================================== >>> +--- git.orig/pthread_stop_world.c >>> ++++ git/pthread_stop_world.c >>> +@@ -45,6 +45,7 @@ >>> + #include <semaphore.h> >>> + #include <errno.h> >>> + #include <unistd.h> >>> ++#include <sys/time.h> >>> + #include "atomic_ops.h" >>> + >>> + /* It's safe to call original pthread_sigmask() here. */ >>> diff --git a/recipes-extended/bdwgc/bdwgc_7.6.0.bb >>> b/recipes-extended/bdwgc/bdwgc_7.6.0.bb >>> new file mode 100644 >>> index 0000000..dcb68f0 >>> --- /dev/null >>> +++ b/recipes-extended/bdwgc/bdwgc_7.6.0.bb >>> @@ -0,0 +1,42 @@ >>> +SUMMARY = "A garbage collector for C and C++" >>> + >>> +DESCRIPTION = "The Boehm-Demers-Weiser conservative garbage collector can >>> be\ >>> + used as a garbage collecting replacement for C malloc or C++ new. It >>> allows\ >>> + you to allocate memory basically as you normally would, without >>> explicitly\ >>> + deallocating memory that is no longer useful. The collector automatically\ >>> + recycles memory when it determines that it can no longer be otherwise\ >>> + accessed.\ >>> + The collector is also used by a number of programming language\ >>> + implementations that either use C as intermediate code, want to >>> facilitate\ >>> + easier interoperation with C libraries, or just prefer the simple >>> collector\ >>> + interface.\ >>> + Alternatively, the garbage collector may be used as a leak detector for >>> C\ >>> + or C++ programs, though that is not its primary goal.\ >>> + Empirically, this collector works with most unmodified C programs, >>> simply\ >>> + by replacing malloc with GC_malloc calls, replacing realloc with >>> GC_realloc\ >>> + calls, and removing free calls." >>> + >>> +HOMEPAGE = "http://www.hboehm.info/gc/" >>> +SECTION = "devel" >>> +LICENSE = "MIT" >>> +LIC_FILES_CHKSUM = >>> "file://README.QUICK;md5=4f81f24ec69726c312487c2ac740e9e3" >>> + >>> +SRCREV = "8ac1d84a40eb7a431fec1b8097e3f24b48fb23fa" >>> +SRC_URI = "git://github.com/ivmai/bdwgc.git \ >>> + >>> file://0001-configure.ac-add-check-for-NO_GETCONTEXT-definition.patch \ >>> + file://musl_header_fix.patch \ >>> + " >>> + >>> +FILES_${PN}-doc = "${datadir}" >>> + >>> +S = "${WORKDIR}/git" >>> + >>> +ARM_INSTRUCTION_SET = "arm" >>> + >>> +inherit autotools pkgconfig >>> + >>> +# by default use external libatomic-ops >>> +PACKAGECONFIG ??= "libatomic-ops" >>> +PACKAGECONFIG[libatomic-ops] = >>> "--with-libatomic-ops=yes,--with-libatomic-ops=no,libatomic-ops" >>> + >>> +BBCLASSEXTEND = "native nativesdk" >>> >> -- >> _______________________________________________ >> yocto mailing list >> yocto@yoctoproject.org >> https://lists.yoctoproject.org/listinfo/yocto > -- _______________________________________________ yocto mailing list yocto@yoctoproject.org https://lists.yoctoproject.org/listinfo/yocto