X-Git-Url: http://git.ipfire.org/?p=people%2Fpmueller%2Fipfire-2.x.git;a=blobdiff_plain;f=lfs%2FuClibc;h=eeb197884c432cbb5eb3b03680e606b900a52597;hp=ae0e013e5d440c2ef57c8d3c6318121b767d44bd;hb=f55e2865db62bb654a91943abd8016db2b7fd613;hpb=9badc9e9e0c17f73821d0c34239ac5b0177d7a09 diff --git a/lfs/uClibc b/lfs/uClibc index ae0e013e5d..eeb197884c 100644 --- a/lfs/uClibc +++ b/lfs/uClibc @@ -1,22 +1,20 @@ ############################################################################### -# This file is part of the IPCop Firewall. # # # -# IPCop is free software; you can redistribute it and/or modify # +# IPFire.org - A linux based firewall # +# Copyright (C) 2007 Michael Tremer & Christian Schmidt # +# # +# This program is free software: you can redistribute it and/or modify # # it under the terms of the GNU General Public License as published by # -# the Free Software Foundation; either version 2 of the License, or # +# the Free Software Foundation, either version 3 of the License, or # # (at your option) any later version. # # # -# IPCop is distributed in the hope that it will be useful, # +# This program is distributed in the hope that it will be useful, # # but WITHOUT ANY WARRANTY; without even the implied warranty of # # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # # GNU General Public License for more details. # # # # You should have received a copy of the GNU General Public License # -# along with IPCop; if not, write to the Free Software # -# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # -# # -# Makefiles are based on LFSMake, which is # -# Copyright (C) 2002 Rod Roard # +# along with this program. If not, see . # # # ############################################################################### @@ -32,17 +30,29 @@ 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) uClibc-locale-030818.tgz -$(DL_FILE) = $(DL_FROM)/$(DL_FILE) +$(DL_FILE) = $(DL_FROM)/$(DL_FILE) +uClibc-locale-030818.tgz = $(DL_FROM)/uClibc-locale-030818.tgz -$(DL_FILE)_MD5 = 1ada58d919a82561061e4741fb6abd29 +$(DL_FILE)_MD5 = 1ada58d919a82561061e4741fb6abd29 +uClibc-locale-030818.tgz_MD5 = d75b2239b4e27c3c9cbed1c8f6eabba6 install : $(TARGET) @@ -71,34 +81,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 - - -mkdir -p /usr/src/$(THISAPP)/toolchain_build_$(MACHINE)/uClibc_dev/usr - ln -fs /usr/include /usr/src/$(THISAPP)/toolchain_build_$(MACHINE)/uClibc_dev/usr/include - - cd $(DIR_APP) && chmod +x sources/patch-kernel.sh - cd $(DIR_APP) && make JLEVEL=$(MAKETUNING) - -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)