Unbork uclibc build.. need to install the crt1.o before we can build ldd.
authorChris Larson <clarson@kergoth.com>
Sat, 18 Sep 2004 01:53:53 +0000 (01:53 +0000)
committerChris Larson <clarson@kergoth.com>
Sat, 18 Sep 2004 01:53:53 +0000 (01:53 +0000)
BKrev: 414b9531RVzriod2lkzZdxc0pVDAMA

uclibc/uclibc_0.9.26.oe
uclibc/uclibc_cvs.oe

index 1de577e..71231af 100644 (file)
@@ -81,16 +81,17 @@ do_configure() {
        oe_runmake oldconfig
 }
 
-do_compile () {
-       oe_runmake all utils
-}
-
 do_stage() {
        # Install into the cross dir (this MUST be done first because we
        # will install crt1.o in the install_dev stage and gcc needs it)
        oe_runmake PREFIX= DEVEL_PREFIX=${UCLIBC_PREFIX}/ \
                RUNTIME_PREFIX=${UCLIBC_PREFIX}/ \
-               install_dev install_runtime install_utils
+               install_dev install_runtime
+
+       oe_runmake utils
+       oe_runmake PREFIX= DEVEL_PREFIX=${UCLIBC_PREFIX}/ \
+               RUNTIME_PREFIX=${UCLIBC_PREFIX}/ \
+               install_utils
 
        # We don't really need this
        rm -f ${UCLIBC_PREFIX}/include/.cvsignore
index e69de29..8eb15dc 100644 (file)
@@ -0,0 +1,140 @@
+DESCRIPTION = "C library for embedded systems"
+LICENSE = "LGPL"
+SECTION = "libs"
+PRIORITY = "required"
+MAINTAINER = "Gerald Britton <gbritton@doomcom.org>"
+PV = "0.0cvs${CVSDATE}"
+PR = "r2"
+DEFAULT_PREFERENCE = "1"
+
+#
+# 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 oe, re
+    uc_os = (re.match('.*uclibc$', oe.data.getVar('TARGET_OS', d, 1)) != None)
+    if not uc_os:
+        raise oe.parse.SkipPackage("incompatible with target %s" %
+                                   oe.data.getVar('TARGET_OS', d, 1))
+}
+
+PROVIDES += " virtual/libc virtual/${TARGET_PREFIX}libc-for-gcc"
+DEPENDS = "patcher-native virtual/${TARGET_PREFIX}binutils \
+          virtual/${TARGET_PREFIX}gcc-initial linux-libc-headers"
+INHIBIT_DEFAULT_DEPS = "1"
+
+FILESPATH = "${@base_set_filespath([ '${FILE_DIRNAME}/uclibc-cvs', '${FILE_DIRNAME}/uclibc', '${FILE_DIRNAME}/files', '${FILE_DIRNAME}' ], d)}"
+
+#
+# This locale file gets copied into uClibc-${PV}/extra/locale/ prior to
+# build, it does not need to be unpacked, but we can't inhibit the unpacking
+# in the current build system.
+#
+UCLIBC_LOCALE_FILE = "uClibc-locale-030818.tgz"
+UCLIBC_LOCALE_FILE_arm = "uClibc-locale-030818.arm.tgz"
+UCLIBC_LOCALE_URI = "http://www.uclibc.org/downloads/${UCLIBC_LOCALE_FILE}"
+UCLIBC_LOCALE_URI_arm = "http://openembedded.org/dl/uclibc-locale/${UCLIBC_LOCALE_FILE}"
+
+SRC_URI = "cvs://anonymous:@uclibc.org/var/cvs;module=uClibc \
+          ${UCLIBC_LOCALE_URI} \
+           file://nokernelheadercheck.patch;patch=1 \
+           file://uClibc.config"
+
+S = "${WORKDIR}/uClibc"
+
+UCLIBC_PREFIX = "${CROSS_DIR}/${TARGET_SYS}"
+UCLIBC_STAGE_PREFIX = "${STAGING_DIR}/${HOST_SYS}"
+
+EXTRA_OEMAKE = "'OPTIMIZATION=' 'CPU_CFLAGS=${CFLAGS}' 'STRIPTOOL=true' 'LD=${LD}' \
+               'LOCALE_DATA_FILENAME=${UCLIBC_LOCALE_FILE}'"
+configmangle = 's,^KERNEL_SOURCE=.*,KERNEL_SOURCE="${CROSS_DIR}/${TARGET_SYS}/include",g; \
+               s,^RUNTIME_PREFIX=.*,RUNTIME_PREFIX="/",g; \
+               s,^DEVEL_PREFIX=.*,DEVEL_PREFIX="/${prefix}",g; \
+               s,^SHARED_LIB_LOADER_PATH=.*,SHARED_LIB_LOADER_PATH="/lib",; \
+               s,.*UCLIBC_HAS_WCHAR.*,UCLIBC_HAS_WCHAR=y\nUCLIBC_HAS_LOCALE=n,g;'
+
+python () {
+       if oe.data.getVar('TARGET_FPU', d, 1) in [ 'soft' ]:
+               oe.data.setVar('configmangle_append', ' s,^HAS_FPU=y,# HAS_FPU is not set,;', d)
+}
+
+uclibcbuild_do_patch() {
+       ln -sf ${STAGING_INCDIR}/linux ${S}/include/linux
+       ln -sf ${STAGING_INCDIR}/asm ${S}/include/asm
+       
+       cp ${DL_DIR}/${UCLIBC_LOCALE_FILE} extra/locale
+}
+
+python do_patch () {
+       oe.build.exec_func('base_do_patch', d)
+       oe.build.exec_func('uclibcbuild_do_patch', d)
+}
+
+do_configure() {
+       cp ${WORKDIR}/uClibc.config ${S}/.config
+
+       perl -i -p -e 's,^CROSS=.*,TARGET_ARCH=${TARGET_ARCH}\nCROSS=${TARGET_PREFIX},g' ${S}/Rules.mak
+       perl -i -p -e '${configmangle}' ${S}/.config
+
+       oe_runmake oldconfig
+}
+
+do_stage() {
+       # Install into the cross dir (this MUST be done first because we
+       # will install crt1.o in the install_dev stage and gcc needs it)
+       oe_runmake PREFIX= DEVEL_PREFIX=${UCLIBC_PREFIX}/ \
+               RUNTIME_PREFIX=${UCLIBC_PREFIX}/ \
+               install_dev install_runtime
+
+       oe_runmake utils
+       oe_runmake PREFIX= DEVEL_PREFIX=${UCLIBC_PREFIX}/ \
+               RUNTIME_PREFIX=${UCLIBC_PREFIX}/ \
+               install_utils
+
+       # We don't really need this
+       rm -f ${UCLIBC_PREFIX}/include/.cvsignore
+
+       # Fixup shared lib symlinks
+       ( cd ${UCLIBC_PREFIX}/lib
+               for f in c crypt dl m nsl pthread resolv thread_db util; do
+                       ln -sf lib${f}.so.? lib${f}.so
+               done
+       )
+
+       # This conflicts with the c++ version of this header
+       rm -f ${UCLIBC_PREFIX}/include/bits/atomicity.h
+
+       # Install into the staging dir
+       oe_runmake PREFIX= DEVEL_PREFIX=${UCLIBC_STAGE_PREFIX}/ \
+               RUNTIME_PREFIX=${UCLIBC_STAGE_PREFIX}/ \
+               install_dev install_runtime install_utils
+
+       # We don't really need this
+       rm -f ${UCLIBC_STAGE_PREFIX}/include/.cvsignore
+
+       # Fixup shared lib symlinks
+       ( cd ${UCLIBC_STAGE_PREFIX}/lib
+               for f in c crypt dl m nsl pthread resolv thread_db util; do
+                       ln -sf lib${f}.so.? lib${f}.so
+               done
+       )
+
+       # This conflicts with the c++ version of this header
+       rm -f ${UCLIBC_STAGE_PREFIX}/include/bits/atomicity.h
+}
+
+do_install() {
+       oe_runmake PREFIX=${D} DEVEL_PREFIX=${prefix}/ RUNTIME_PREFIX=/ \
+               install_dev install_runtime install_utils
+
+       # We don't really need this in /usr/include
+       rm -f ${D}/${prefix}/include/.cvsignore
+
+       # This conflicts with the c++ version of this header
+       rm -f ${D}/${prefix}/include/bits/atomicity.h
+}