Openembedded Devel Discussions
 help / color / mirror / Atom feed
From: Khem Raj <raj.khem@gmail.com>
To: openembedded-devel@lists.openembedded.org
Subject: [PATCH 06/16] db_5.0.21: Add recipes for target and native packages.
Date: Wed,  2 Jun 2010 13:34:46 -0700	[thread overview]
Message-ID: <1275510896-30845-7-git-send-email-raj.khem@gmail.com> (raw)
In-Reply-To: <1275510896-30845-1-git-send-email-raj.khem@gmail.com>

* Get rid of old style staging.

Signed-off-by: Khem Raj <raj.khem@gmail.com>
---
 recipes/db/db-native_4.2.52.bb             |    1 -
 recipes/db/db-native_5.0.21.bb             |    2 +
 recipes/db/db4-native.inc                  |   13 ----
 recipes/db/db4.inc                         |   13 ----
 recipes/db/db5.inc                         |   83 ++++++++++++++++++++++++++++
 recipes/db/db_4.2.52.bb                    |    2 +-
 recipes/db/db_4.3.29.bb                    |    2 +-
 recipes/db/db_5.0.21.bb                    |   15 +++++
 recipes/db/files/db5-arm-thumb-mutex.patch |   38 +++++++++++++
 9 files changed, 140 insertions(+), 29 deletions(-)
 create mode 100644 recipes/db/db-native_5.0.21.bb
 create mode 100644 recipes/db/db5.inc
 create mode 100644 recipes/db/db_5.0.21.bb
 create mode 100644 recipes/db/files/db5-arm-thumb-mutex.patch

diff --git a/recipes/db/db-native_4.2.52.bb b/recipes/db/db-native_4.2.52.bb
index 9f307d6..4ff80fd 100644
--- a/recipes/db/db-native_4.2.52.bb
+++ b/recipes/db/db-native_4.2.52.bb
@@ -1,5 +1,4 @@
 require db_${PV}.bb
 require db4-native.inc
-
 SRC_URI[md5sum] = "8b5cff6eb83972afdd8e0b821703c33c"
 SRC_URI[sha256sum] = "f4bddd8d1b4cde0daf5e13e3493ed62a25b736b0bf258e1d929e47bc6a82a28c"
diff --git a/recipes/db/db-native_5.0.21.bb b/recipes/db/db-native_5.0.21.bb
new file mode 100644
index 0000000..0e6381b
--- /dev/null
+++ b/recipes/db/db-native_5.0.21.bb
@@ -0,0 +1,2 @@
+require db_${PV}.bb
+require db4-native.inc
diff --git a/recipes/db/db4-native.inc b/recipes/db/db4-native.inc
index cc83d86..7fd753d 100644
--- a/recipes/db/db4-native.inc
+++ b/recipes/db/db4-native.inc
@@ -13,16 +13,3 @@ do_package() {
 }
 
 PACKAGES = ""
-
-do_stage() {
-         # The .h files get installed read-only, the autostage
-         # function just uses cp -pPR, so do this by hand
-         rm -rf ${STAGE_TEMP}
-         mkdir -p ${STAGE_TEMP}
-         oe_runmake DESTDIR="${STAGE_TEMP}" install_include
-         cp -pPRf ${STAGE_TEMP}/${includedir}/* ${STAGING_INCDIR}/.
-         rm -rf ${STAGE_TEMP}
-         oe_libinstall -so -C .libs libdb-${PVM} ${STAGING_LIBDIR}
-         ln -sf libdb-${PVM}.so ${STAGING_LIBDIR}/libdb.so
-         ln -sf libdb-${PVM}.a ${STAGING_LIBDIR}/libdb.a
-}
diff --git a/recipes/db/db4.inc b/recipes/db/db4.inc
index 12d4ad2..73d339d 100644
--- a/recipes/db/db4.inc
+++ b/recipes/db/db4.inc
@@ -81,16 +81,3 @@ do_install_append() {
 		mv "${D}/${prefix}/docs" "${D}/${docdir}"
 	fi
 }
-
-do_stage() {
-	# The .h files get installed read-only, the autostage
-	# function just uses cp -pPR, so do this by hand
-	rm -rf ${STAGE_TEMP}
-	mkdir -p ${STAGE_TEMP}
-	oe_runmake DESTDIR="${STAGE_TEMP}" install_include
-	cp -pPRf ${STAGE_TEMP}/${includedir}/* ${STAGING_INCDIR}/.
-	rm -rf ${STAGE_TEMP}
-	oe_libinstall -so -C .libs libdb-${PVM} ${STAGING_LIBDIR}
-	ln -sf libdb-${PVM}.so ${STAGING_LIBDIR}/libdb.so
-	ln -sf libdb-${PVM}.a ${STAGING_LIBDIR}/libdb.a
-}
diff --git a/recipes/db/db5.inc b/recipes/db/db5.inc
new file mode 100644
index 0000000..599093e
--- /dev/null
+++ b/recipes/db/db5.inc
@@ -0,0 +1,83 @@
+# Version 5 of the Berkeley DB from Oracle
+#
+# At present this package only installs the DB code
+# itself (shared libraries, .a in the dev package),
+# documentation and headers.
+#
+# The headers have the same names as those as v3
+# of the DB, only one version can be used *for dev*
+# at once - DB3 and DB5 both be installed on the
+# same system at the same time if really necessary.
+
+
+DESCRIPTION = "Berkeley DB v5."
+HOMEPAGE = "http://www.oracle.com/technology/products/berkeley-db/db/index.html"
+SECTION = "libs"
+LICENSE = "BSD"
+VIRTUAL_NAME ?= "virtual/db"
+CONFLICTS = "db3 db4"
+
+SRC_URI = "http://download.oracle.com/berkeley-db/db-${PV}.tar.gz"
+
+inherit autotools
+
+# Put virtual/db in any appropriate provider of a
+# relational database, use it as a dependency in
+# place of a specific db and use:
+#
+# PREFERRED_PROVIDER_virtual/db
+#
+# to select the correct db in the build (distro) .conf
+PROVIDES += "${VIRTUAL_NAME}"
+
+# bitbake isn't quite clever enough to deal with db,
+# the distribution sits in the expected directory, but all
+# the builds must occur from a sub-directory.  The following
+# persuades bitbake to go to the right place
+S = "${WORKDIR}/db-${PV}/dist"
+B = "${WORKDIR}/db-${PV}/build_unix"
+
+# The executables go in a separate package - typically there
+# is no need to install these unless doing real database
+# management on the system.
+PACKAGES += " ${PN}-bin"
+
+# Package contents
+FILES_${PN} = "${libdir}/libdb-5*so*"
+FILES_${PN}-bin = "${bindir}/*"
+# The dev package has the .so link (as in db3) and the .a's -
+# it is therefore incompatible (cannot be installed at the
+# same time) as the db3 package
+FILES_${PN}-dev = "${includedir} ${libdir}/*"
+
+EXTRA_OECONF = "${DB5_CONFIG}"
+
+# Override the MUTEX setting here, the POSIX library is
+# the default - "POSIX/pthreads/library".
+# Don't ignore the nice SWP instruction on the ARM:
+# These enable the ARM assembler mutex code, this won't
+# work with thumb compilation...
+ARM_MUTEX = "--with-mutex=ARM/gcc-assembly"
+MUTEX = ""
+MUTEX_arm = "${ARM_MUTEX}"
+MUTEX_armeb = "${ARM_MUTEX}"
+EXTRA_OECONF += "${MUTEX}"
+
+# Cancel the site stuff - it's set for db3 and destroys the
+# configure.
+CONFIG_SITE = ""
+do_configure() {
+	( cd ${WORKDIR}/db-${PV}/dist ; gnu-configize ) 
+	oe_runconf
+}
+
+
+do_install_append() {
+	# The docs end up in /usr/docs - not right.
+	if test -d "${D}/${prefix}/docs"
+	then
+		mkdir -p "${D}/${datadir}"
+		test ! -d "${D}/${docdir}" || rm -rf "${D}/${docdir}"
+		mv "${D}/${prefix}/docs" "${D}/${docdir}"
+	fi
+}
diff --git a/recipes/db/db_4.2.52.bb b/recipes/db/db_4.2.52.bb
index 3b9bab8..5f135ed 100644
--- a/recipes/db/db_4.2.52.bb
+++ b/recipes/db/db_4.2.52.bb
@@ -1,4 +1,4 @@
-PR = "r8"
+PR = "r9"
 
 #major version number
 PVM = "4.2"
diff --git a/recipes/db/db_4.3.29.bb b/recipes/db/db_4.3.29.bb
index c5ecfde..1e54203 100644
--- a/recipes/db/db_4.3.29.bb
+++ b/recipes/db/db_4.3.29.bb
@@ -1,4 +1,4 @@
-PR = "r10"
+PR = "r11"
 
 # major version number
 PVM = "4.3"
diff --git a/recipes/db/db_5.0.21.bb b/recipes/db/db_5.0.21.bb
new file mode 100644
index 0000000..cfa0154
--- /dev/null
+++ b/recipes/db/db_5.0.21.bb
@@ -0,0 +1,15 @@
+PR = "r0"
+
+# major version number
+PVM = "5.0"
+
+#configuration - set in local.conf to override
+# All the --disable-* options replace --enable-smallbuild, which breaks a bunch of stuff (eg. postfix)
+DB5_CONFIG ?= "--enable-o_direct --disable-cryptography --disable-queue --disable-replication --disable-statistics --disable-verify --enable-compat185"
+
+require db5.inc
+
+SRC_URI += "file://db5-arm-thumb-mutex.patch"
+
+SRC_URI[md5sum] = "9a749fd2e98fe15840493ddc34cc66d8"
+SRC_URI[sha256sum] = "061a31a962e992dd1eae5f1e3193241d497a18968e750707526d104b53ab3cc4"
diff --git a/recipes/db/files/db5-arm-thumb-mutex.patch b/recipes/db/files/db5-arm-thumb-mutex.patch
new file mode 100644
index 0000000..51b8882
--- /dev/null
+++ b/recipes/db/files/db5-arm-thumb-mutex.patch
@@ -0,0 +1,38 @@
+Index: db-5.0.21/../dbinc/mutex_int.h
+===================================================================
+--- db-5.0.21.orig/../dbinc/mutex_int.h	2010-03-30 10:36:09.000000000 -0700
++++ db-5.0.21/../dbinc/mutex_int.h	2010-05-22 12:07:38.281286337 -0700
+@@ -474,6 +474,25 @@ typedef unsigned char tsl_t;
+ 
+ #ifdef LOAD_ACTUAL_MUTEX_CODE
+ /* gcc/arm: 0 is clear, 1 is set. */
++#if defined __thumb__
++#define	MUTEX_SET(tsl) ({						\
++	int __r, __p;							\
++	asm volatile(							\
++		".align	2\n\t"						\
++		"bx	pc\n\t"						\
++		"nop\n\t"						\
++		".arm\n\t"						\
++		"swpb	%0, %2, [%3]\n\t"				\
++		"eor	%0, %0, #1\n\t"					\
++		"orr	%1, pc, #1\n\t"					\
++		"bx	%1\n\t"						\
++		".force_thumb"						\
++	    : "=&r" (__r), "=r" (__p)					\
++	    : "r" (1), "r" (tsl)					\
++	    );								\
++	__r & 1;							\
++})
++#else
+ #define	MUTEX_SET(tsl) ({						\
+ 	int __r;							\
+ 	__asm__ volatile(						\
+@@ -484,6 +503,7 @@ typedef unsigned char tsl_t;
+ 	    );								\
+ 	__r & 1;							\
+ })
++#endif
+ 
+ #define	MUTEX_UNSET(tsl)	(*(volatile tsl_t *)(tsl) = 0)
+ #define	MUTEX_INIT(tsl)         (MUTEX_UNSET(tsl), 0)
-- 
1.7.0.4




  parent reply	other threads:[~2010-06-02 20:39 UTC|newest]

Thread overview: 45+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-06-02 20:34 [PATCH 00/16] Upgrade gettext, GNU utilities, fix general build issues with uclibc distros Khem Raj
2010-06-02 20:34 ` [PATCH 01/16] classes/autotools.bbclass: Dont bail out if gettext/config.rpath does not exist Khem Raj
2010-06-04  7:35   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 02/16] classes/gettext.bbclass: Account for libiconv and libintl too Khem Raj
2010-06-04  7:36   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 03/16] gettext-0.18: Add recipe for 0.18 Khem Raj
2010-06-04  7:37   ` Martin Jansa
2010-06-04  9:41     ` Martin Jansa
2010-06-04  9:49       ` Koen Kooi
2010-06-02 20:34 ` [PATCH 04/16] coreutils-8.5: Add recipes for version 8.5 Khem Raj
2010-06-04  7:37   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 05/16] libiconv-1.13.1: Add recipes Khem Raj
2010-06-04  7:38   ` Martin Jansa
2010-06-02 20:34 ` Khem Raj [this message]
2010-06-02 20:41   ` [PATCH 06/16] db_5.0.21: Add recipes for target and native packages Koen Kooi
2010-06-04  0:29     ` Khem Raj
2010-06-04  7:38       ` Martin Jansa
2010-06-08 19:53         ` Jan Paesmans
2010-06-08 21:14           ` Khem Raj
2010-06-02 20:34 ` [PATCH 07/16] grep-2.6.3: Add recipe Khem Raj
2010-06-04  7:39   ` Martin Jansa
2010-06-07  7:35     ` Jan Paesmans
2010-06-07 14:11       ` Khem Raj
2010-06-07 14:19         ` Jan Paesmans
2010-06-07 14:22           ` Jan Paesmans
2010-06-07 17:14             ` Bernhard Reutner-Fischer
2010-06-02 20:34 ` [PATCH 08/16] glib-2.0_2.24.0.bb: Remove virtual/libiconv virtual/libintl from DEPENDS Khem Raj
2010-06-04  7:39   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 09/16] gnutls_2.8.6.bb: Add recipe for version 2.8.6 Khem Raj
2010-06-04  7:40   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 10/16] inetutils_1.8.bb: Add recipe Khem Raj
2010-06-04  7:40   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 11/16] findutils_4.5.9.bb: " Khem Raj
2010-06-04  7:41   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 12/16] gstreamer_0.10.28.bb: Fix to build with gettext 0.18 Khem Raj
2010-06-04  7:41   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 13/16] ncurses: Add -fforward-propagate on arm Khem Raj
2010-06-04  7:41   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 14/16] zlib.inc: " Khem Raj
2010-06-04  7:42   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 15/16] libx11_1.3.2.bb: " Khem Raj
2010-06-04  7:42   ` Martin Jansa
2010-06-02 20:34 ` [PATCH 16/16] shadow_4.1.4.2.bb: add --with-nscd=no when compiling for uclibc Khem Raj
2010-06-04  7:45 ` [PATCH 00/16] Upgrade gettext, GNU utilities, fix general build issues with uclibc distros Martin Jansa
2010-06-05 18:15 ` Koen Kooi

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1275510896-30845-7-git-send-email-raj.khem@gmail.com \
    --to=raj.khem@gmail.com \
    --cc=openembedded-devel@lists.openembedded.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox