summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGerald Britton <gbritton@doomcom.org>2004-03-06 22:09:59 +0000
committerGerald Britton <gbritton@doomcom.org>2004-03-06 22:09:59 +0000
commit5ddc8e17e70a0d17073b1117e2287549dccbe68e (patch)
tree4e0d1332c71900914b12a07d7a07f5e692b25254
parenta3abef71361570075274537d5364d77974c5be6d (diff)
uclibc error out on no appropriate .config
BKrev: 404a4c37YJypbGR3Dz8tO4Z4a3W2EA
-rw-r--r--uclibc/uclibc_0.9.26.oe96
1 files changed, 96 insertions, 0 deletions
diff --git a/uclibc/uclibc_0.9.26.oe b/uclibc/uclibc_0.9.26.oe
index e69de29bb2..d8252527c9 100644
--- a/uclibc/uclibc_0.9.26.oe
+++ b/uclibc/uclibc_0.9.26.oe
@@ -0,0 +1,96 @@
+DESCRIPTION := C library for embedded systems
+LICENSE := LGPL
+SECTION := libs
+PRIORITY := required
+MAINTAINER := Gerald Britton <gbritton@doomcom.org>
+
+FILESDIR := ${@os.path.dirname(oe.data.getVar('FILE',d,1))}/uclibc-${PV}
+
+DEPENDS := virtual/${TARGET_PREFIX}binutils virtual/${TARGET_PREFIX}gcc-initial
+PROVIDES := virtual/libc
+
+SRC_URI := http://www.uclibc.org/downloads/uClibc-${PV}.tar.bz2 \
+ http://www.uclibc.org/downloads/toolchain/kernel-headers-2.4.21.tar.bz2
+
+S := ${WORKDIR}/uClibc-${PV}
+
+UCLIBC_PREFIX := ${CROSS_DIR}/${TARGET_SYS}
+
+EXTRA_OEMAKE =
+
+uclibcbuild_do_patch() {
+ rm -f ${WORKDIR}/linux/include/asm
+ ln -sf asm-${TARGET_ARCH} ${WORKDIR}/linux/include/asm
+
+ touch ${WORKDIR}/linux/include/linux/autoconf.h
+
+ echo "#define UTS_RELEASE \"2.4.21\"" > ${WORKDIR}/linux/include/linux/version.h
+ echo "#define LINUX_VERSION_CODE 132117" >> ${WORKDIR}/linux/include/linux/version.h
+ echo "#define KERNEL_VERSION(a,b,c) (((a) << 16) + ((b) << 8) + (c))" \
+ >> ${WORKDIR}/linux/include/linux/version.h
+
+ if [ -f ${FILESDIR}/uClibc.config.${TARGET_ARCH} ]; then
+ cp ${FILESDIR}/uClibc.config.${TARGET_ARCH} ${S}/.config
+ else
+ echo ERROR: No target specific config for ${TARGET_ARCH}
+ fi
+
+ perl -i -p -e 's,^CROSS=.*,TARGET_ARCH=${TARGET_ARCH}\nCROSS=${TARGET_PREFIX},g' ${S}/Rules.mak
+ perl -i -p -e 's,^KERNEL_SOURCE=.*,KERNEL_SOURCE=\"${WORKDIR}/linux\",g' ${S}/.config
+ perl -i -p -e 's,^DEVEL_PREFIX=.*,DEVEL_PREFIX=\"${UCLIBC_PREFIX}\",g' ${S}/.config
+ perl -i -p -e 's,^SYSTEM_DEVEL_PREFIX=.*,SYSTEM_DEVEL_PREFIX=\"${UCLIBC_PREFIX}\",g' ${S}/.config
+ perl -i -p -e 's,^DEVEL_TOOL_PREFIX=.*,DEVEL_TOOL_PREFIX=\"${UCLIBC_PREFIX}\",g' ${S}/.config
+ perl -i -p -e 's,^SHARED_LIB_LOADER_PATH=.*,SHARED_LIB_LOADER_PATH=\"/lib\",g' ${S}/.config
+ perl -i -p -e 's,.*UCLIBC_HAS_WCHAR.*,UCLIBC_HAS_WCHAR=y\nUCLIBC_HAS_LOCALE=n,g' ${S}/.config
+ perl -i -p -e 's,^GCC_BIN.*,GCC_BIN=${CROSS_DIR}/bin/${TARGET_PREFIX}gcc,g' ${S}/extra/gcc-uClibc/Makefile
+ perl -i -p -e 's,^LD_BIN.*,LD_BIN=${CROSS_DIR}/bin/${TARGET_PREFIX}ld,g' ${S}/extra/gcc-uClibc/Makefile
+
+ make oldconfig
+ make headers
+}
+
+python do_patch () {
+ oe.build.exec_func('base_do_patch', d)
+ oe.build.exec_func('uclibcbuild_do_patch', d)
+}
+
+do_stage() {
+ make install_dev install_runtime install_utils
+
+ # Make links to ${STAGING_DIR}/target/include so many
+ # cross builds work easier...
+ mkdir -p ${STAGING_DIR}/target/include
+ for f in ${CROSS_DIR}/${TARGET_SYS}/include/*; do
+ ln -s $f ${STAGING_DIR}/target/include/
+ done
+
+ # We don't really need these
+ rmdir ${CROSS_DIR}/${TARGET_SYS}/${libdir} || :
+ rmdir ${CROSS_DIR}/${TARGET_SYS}/${prefix} || :
+}
+
+do_install() {
+ make DEVEL_PREFIX= SYSTEM_DEVEL_PREFIX= TARGET_PREFIX= \
+ DEVEL_TOOL_PREFIX=${prefix} PREFIX=${D}/ \
+ install_dev install_target install_target_utils
+
+ # binutils has a readelf, so forget about this one...
+ rm -f ${D}/${bindir}/readelf
+
+ # move devel headers/libs/objects from / into ${prefix}
+ mv -f ${D}/lib/*.a ${D}/lib/*.o ${D}${libdir}/
+ rm -f ${D}/include/.cvsignore
+ mv -f ${D}/include ${D}${prefix}/
+ for lib in libc.so libcrypt.so libdl.so libm.so libnsl.so \
+ libpthread.so libresolv.so libthread_db.so libutil.so; do
+ ln -s ../../lib/`readlink ${D}/lib/$lib` ${D}${libdir}/$lib
+ rm -f ${D}/lib/$lib
+ done
+
+ # ensure we have a /sbin/ldconfig as some scripts expect one
+ if ! [ -e ${D}/sbin/ldconfig ]; then
+ mkdir -p ${D}/sbin
+ ln -sf ../bin/true ${D}/sbin/ldconfig
+ fi
+}
+