[oe-commits] org.oe.dev eglibc: add svn recipe for eglibc

koen commit openembedded-commits at lists.openembedded.org
Thu Aug 2 00:16:33 UTC 2007


eglibc: add svn recipe for eglibc
* this is WIP, but it completes do_compile
* Need to bother Khem about how to do localegen the eglibc way

Author: koen at openembedded.org
Branch: org.openembedded.dev
Revision: 2d281351e8579e348717227c6b84f55ef13fd0ff
ViewMTN: http://monotone.openembedded.org/revision.psp?id=2d281351e8579e348717227c6b84f55ef13fd0ff
Files:
1
packages/glibc/eglibc_svn.bb
Diffs:

#
# mt diff -r856cd651f1bd26f6178f1b13bdfbb749a1ea2bb9 -r2d281351e8579e348717227c6b84f55ef13fd0ff
#
# 
# 
# add_file "packages/glibc/eglibc_svn.bb"
#  content [497397984a43053f50f67e5f4050b058f3b51193]
# 
============================================================
--- packages/glibc/eglibc_svn.bb	497397984a43053f50f67e5f4050b058f3b51193
+++ packages/glibc/eglibc_svn.bb	497397984a43053f50f67e5f4050b058f3b51193
@@ -0,0 +1,87 @@
+require glibc.inc
+
+DEFAULT_PREFERENCE = "-1"
+
+PV = "2.6+svnr${SRCREV}"
+SRC_URI = "svn://svn.eglibc.org;module=trunk \
+          "
+S = "${WORKDIR}/trunk/libc"
+B = "${WORKDIR}/build-${TARGET_SYS}"
+
+#PACKAGES_DYNAMIC = "libc6*"
+#RPROVIDES_${PN}-dev = "libc6-dev"
+
+# the -isystem in bitbake.conf screws up glibc do_stage
+BUILD_CPPFLAGS = "-I${STAGING_DIR}/${BUILD_SYS}/include"
+TARGET_CPPFLAGS = "-I${STAGING_DIR}/${TARGET_SYS}/include"
+
+GLIBC_ADDONS ?= "ports,nptl,libidn"
+
+GLIBC_BROKEN_LOCALES = " _ER _ET so_ET yn_ER sid_ET tr_TR mn_MN gez_ET gez_ER bn_BD te_IN"
+
+#
+# For now, we will skip building of a gcc package if it is a uclibc one
+# and our build is not a uclibc one, and we skip a glibc one if our build
+# is a uclibc build.
+#
+# See the note in gcc/gcc_3.4.0.oe
+#
+
+python __anonymous () {
+    import bb, re
+    uc_os = (re.match('.*uclibc$', bb.data.getVar('TARGET_OS', d, 1)) != None)
+    if uc_os:
+        raise bb.parse.SkipPackage("incompatible with target %s" %
+                                   bb.data.getVar('TARGET_OS', d, 1))
+}
+
+           
+EXTRA_OECONF = "--enable-kernel=${OLDEST_KERNEL} \
+                --without-cvs --disable-profile --disable-debug --without-gd \
+                --enable-clocale=gnu \
+                --enable-add-ons=${GLIBC_ADDONS} \
+                --with-headers=${STAGING_INCDIR} \
+                --without-selinux \
+                ${GLIBC_EXTRA_OECONF}"
+
+EXTRA_OECONF += "${@get_glibc_fpu_setting(bb, d)}"
+
+do_configure_prepend() {
+        if test -d ${WORKDIR}/trunk/ports ; then
+	    mv ${WORKDIR}/trunk/ports ${S}/
+	fi    
+}
+
+do_configure () {
+# override this function to avoid the autoconf/automake/aclocal/autoheader
+# calls for now
+# don't pass CPPFLAGS into configure, since it upsets the kernel-headers
+# version check and doesn't really help with anything
+        if [ -z "`which rpcgen`" ]; then
+                echo "rpcgen not found.  Install glibc-devel."
+                exit 1
+        fi
+        (cd ${S} && gnu-configize) || die "failure in running gnu-configize"
+        find ${WORKDIR} -name "configure" | xargs touch
+        CPPFLAGS="" oe_runconf
+}
+
+rpcsvc = "bootparam_prot.x nlm_prot.x rstat.x \
+          yppasswd.x klm_prot.x rex.x sm_inter.x mount.x \
+          rusers.x spray.x nfs_prot.x rquota.x key_prot.x"
+
+do_compile () { 
+        # -Wl,-rpath-link <staging>/lib in LDFLAGS can cause breakage if another glibc is in staging
+        unset LDFLAGS
+	base_do_compile
+	(
+                cd ${S}/sunrpc/rpcsvc
+                for r in ${rpcsvc}; do
+                        h=`echo $r|sed -e's,\.x$,.h,'`
+                        rpcgen -h $r -o $h || oewarn "unable to generate header for $r"
+                done
+        ) 
+}       
+
+
+require glibc-package.bbclass






More information about the Openembedded-commits mailing list