]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/blobdiff - lfs/uClibc
Installer-Toolchain nochmals ueberarbeitet.
[people/teissler/ipfire-2.x.git] / lfs / uClibc
index 1164abbd3eb33d0026616774b132e12d0f2ad779..166e1aa5ce529f1102b905d1d460625f01ba39df 100644 (file)
@@ -32,17 +32,31 @@ THISAPP    = uClibc-$(VER)
 DL_FILE    = $(THISAPP).tar.bz2
 DL_FROM    = $(URL_IPFIRE)
 DIR_APP    = $(DIR_SRC)/$(THISAPP)
-TARGET     = $(DIR_INFO)/$(THISAPP)
+ifeq "$(PASS)" "1"
+       TARGET     = $(DIR_INFO)/$(THISAPP)-pass1
+else
+ifeq "$(PASS)" "2"
+       TARGET     = $(DIR_INFO)/$(THISAPP)-pass2
+else
+       TARGET     = $(DIR_INFO)/$(THISAPP)-pass3
+endif
+endif
+
+STAGING_DIR=/opt/$(MACHINE)-uClibc
 
 ###############################################################################
 # Top-level Rules
 ###############################################################################
 
-objects = $(DL_FILE)
+objects = $(DL_FILE) buildroot-snapshot-20061026.tar.bz2 uClibc-locale-030818.tgz
 
-$(DL_FILE)           = $(DL_FROM)/$(DL_FILE)
+$(DL_FILE)                                     = $(DL_FROM)/$(DL_FILE)
+buildroot-snapshot-20061026.tar.bz2    = $(DL_FROM)/buildroot-snapshot-20061026.tar.bz2
+uClibc-locale-030818.tgz                       = $(DL_FROM)/uClibc-locale-030818.tgz
 
-$(DL_FILE)_MD5       = 1ada58d919a82561061e4741fb6abd29
+$(DL_FILE)_MD5                         = 1ada58d919a82561061e4741fb6abd29
+buildroot-snapshot-20061026.tar.bz2_MD5        = ecc5d48a780e46a56d1d39207d5868bd
+uClibc-locale-030818.tgz_MD5           = d75b2239b4e27c3c9cbed1c8f6eabba6
 
 install : $(TARGET)
 
@@ -71,30 +85,55 @@ $(subst %,%_MD5,$(objects)) :
 
 $(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
        @$(PREBUILD)
+ifeq "$(PASS)" "1"
        @rm -rf $(DIR_APP)
-       @rm -rf /opt/$(MACHINE)-uClibc
-       @mkdir -p $(DIR_APP)
-       cd $(DIR_APP) && cp -R $(DIR_SRC)/src/uClibc/* .
-       cd $(DIR_APP) && sed -e 's/UCLIBC_HAS_THREADS=y/# UCLIBC_HAS_THREADS is not set/' \
-                       -e 's/DO_C99_MATH=y/# DO_C99_MATH is not set/' \
-                       -e 's/LDSO_CACHE_SUPPORT=y/# LDSO_CACHE_SUPPORT is not set/' \
-                       -e 's/UCLIBC_HAS_FTW=y/# UCLIBC_HAS_FTW is not set/' \
-                       -e 's,/usr/src/linux,&-$(KVER),' -i sources/uClibc.config-$(MACHINE)
-       cd $(DIR_APP) && sed -e 's,^LINUX_DIR.*$$,&-$(KVER),' -i make/uclibc.mk
-       cd $(DIR_APP) && chmod +x sources/patch-kernel.sh
-       cd $(DIR_APP) && make
-       -mkdir -p /install/initrd/bin
-       cd $(DIR_APP)/toolchain_build_$(MACHINE)/$(THISAPP) && make PREFIX=/opt/$(MACHINE)-uClibc install
-       cd $(DIR_APP)/toolchain_build_$(MACHINE)/$(THISAPP) && make RUNTIME_PREFIX=/install/initrd/ install_runtime
-       chmod 755 /install/initrd/lib/libuClibc-$(VER).so
-       rm -f /install/initrd/lib/{libm*,libcrypt*,libutil*,librt*}
-
-       cp -f /opt/$(MACHINE)-uClibc/lib/libgcc_s.so /lib
+       @mkdir -p /opt/$(MACHINE)-uClibc $(DIR_SRC)/uClibc_dev/usr/include $(DIR_SRC)/uClibc_dev/{,usr}/lib
+       @cd $(DIR_SRC) && tar xfj $(DIR_DL)/$(DL_FILE)
+       cp -f $(DIR_DL)/uClibc-locale-030818.tgz $(DIR_APP)/extra/locale/
+       cp -f $(DIR_SRC)/config/uClibc/{locales,codesets}.txt $(DIR_APP)/extra/locale
+       cd $(DIR_APP)/extra/locale && patch -Np3 < $(DIR_SRC)/src/patches/uClibc-gcc4-genwctype.patch
+       cp -f $(DIR_SRC)/config/uClibc/uClibc.config-$(MACHINE) $(DIR_APP)/.config
+       cd $(DIR_APP) && make oldconfig
+       cd $(DIR_APP)/extra/locale && make
+       cd $(DIR_APP) && make PREFIX=$(DIR_SRC)/uClibc_dev \
+                               DEVEL_PREFIX=/usr/ \
+                               RUNTIME_PREFIX=$(DIR_SRC)/uClibc_dev/ \
+                               pregen install_dev
+else
+ifeq "$(PASS)" "2"
+       cd $(DIR_APP) && make PREFIX= \
+                               DEVEL_PREFIX=/ \
+                               RUNTIME_PREFIX=/ \
+                               all
+       cd $(DIR_APP) && make PREFIX= \
+                               DEVEL_PREFIX=/opt/$(MACHINE)-uClibc/ \
+                               RUNTIME_PREFIX=/opt/$(MACHINE)-uClibc/ \
+                               install_runtime install_dev
+
+       ## This is to fix a small bug
+       if [ ! -h /opt/$(MACHINE)-uClibc/$(MACHINE)-linux-uclibc/lib ]; then \
+         mv -vf /opt/$(MACHINE)-uClibc/$(MACHINE)-linux-uclibc/lib/* /opt/$(MACHINE)-uClibc/lib/; \
+         rm -rf /opt/$(MACHINE)-uClibc/$(MACHINE)-linux-uclibc/lib; \
+         ln -sfv ../lib /opt/$(MACHINE)-uClibc/$(MACHINE)-linux-uclibc/lib; \
+       fi
+
+       cd $(DIR_APP) && make -C utils/ PREFIX=/opt/$(MACHINE)-uClibc \
+                               hostutils
+       cd $(DIR_APP) && make PREFIX=/install/initrd \
+                               DEVEL_PREFIX=/usr/ \
+                               RUNTIME_PREFIX=/ \
+                               install_runtime
        cp -f /opt/$(MACHINE)-uClibc/lib/ld-uClibc-$(VER).so /lib
        cp -f /opt/$(MACHINE)-uClibc/lib/libuClibc-$(VER).so /lib
-       cd /lib && ln -sf libgcc_s.so libgcc_s.so.1
        cd /lib && ln -sf ld-uClibc-$(VER).so ld-uClibc.so.0
        cd /lib && ln -sf libuClibc-$(VER).so libc.so.0
        cd /lib && ln -sf libc.so.0 libc.so
+       ln -sf /opt/$(MACHINE)-uClibc/lib/libm-$(VER).so /lib/libm.so.0
+else
+       cd $(DIR_APP) && make PREFIX=/install/initrd utils install_utils
+       chmod 755 /install/initrd/lib/libuClibc-$(VER).so
+       rm -f /install/initrd/lib/{libm*,libcrypt*,libutil*,librt*}
        @rm -rf $(DIR_APP)
+endif
+endif
        @$(POSTBUILD)