bdwgc: add a recipe from oe-core

It is required by zile recipe.

Signed-off-by: Alexander Kanavin <alexander.kanavin@linux.intel.com>
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
This commit is contained in:
Alexander Kanavin 2017-06-19 15:50:15 +03:00 committed by Martin Jansa
parent 49e2c0039f
commit 941de88164
3 changed files with 98 additions and 0 deletions

View File

@ -0,0 +1,29 @@
configure.ac: add check for NO_GETCONTEXT definition
Signed-off-by: Samuel Martin <s.martin49@gmail.com>
[yann.morin.1998@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.1998@free.fr>
Cc: Thomas Petazzoni <thomas.petazzoni@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.

View File

@ -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. */

View File

@ -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"