DESCRIPTION = "C library for embedded systems" LICENSE = "LGPL" SECTION = "libs" PRIORITY = "required" MAINTAINER = "Gerald Britton " PV = "${CVSDATE}" PR = "r1" # # 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" # # 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 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 }