]> git.ipfire.org Git - people/teissler/ipfire-2.x.git/commitdiff
SMP wieder aktiviert (Zumindest versucht)
authorms <ms@ea5c0bd1-69bd-2848-81d8-4f18e57aeed8>
Mon, 20 Feb 2006 20:13:28 +0000 (20:13 +0000)
committerms <ms@ea5c0bd1-69bd-2848-81d8-4f18e57aeed8>
Mon, 20 Feb 2006 20:13:28 +0000 (20:13 +0000)
git-svn-id: http://svn.ipfire.org/svn/ipfire/trunk@62 ea5c0bd1-69bd-2848-81d8-4f18e57aeed8

lfs/driver.img
lfs/linux
make.sh

index 848b825085ca0b62e8517e2d72b527998123637d..9c4a9dc8e7fb03b7e2ed83a6bec8439fa8856698 100644 (file)
-###############################################################################
-# This file is part of the IPCop Firewall.                                    #
-#                                                                             #
-# IPCop 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           #
-# (at your option) any later version.                                         #
-#                                                                             #
-# IPCop 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 <rod@sunsetsystems.com>                        #
-#                                                                             #
-# Modifications by:                                                           #
-# ??-12-2003 Mark Wormgoor < mark@wormgoor.com>                               #
-#          - Modified Makefile for IPCop build                                #
-#                                                                             #
-# $Id: driver.img,v 1.24.2.7 2006/01/29 20:17:30 franck78 Exp $
-#                                                                             #
-###############################################################################
-
-###############################################################################
-# Definitions
-###############################################################################
-
-include Config
-
-THISAPP    = driver-$(VERSION).img
-TARGET     = $(DIR_INFO)/$(THISAPP)
-
-###############################################################################
-# Top-level Rules
-###############################################################################
-
-install : $(TARGET)
-
-check :
-
-download :
-
-md5 :
-
-###############################################################################
-# Installation Details
-###############################################################################
-
-$(TARGET) :
-       @$(PREBUILD)
-       -strip --strip-all   /install/misc/bin/*
-
-       # make new dependencies 
-       depmod -a -F /boot/System.map-$(KVER) $(KVER)
-#      if [ "$(MACHINE)" = "i386" ]; then \
-#              depmod -a -F /boot/System.map-$(KVER)-smp $(KVER)-smp; \
-#      fi
-
-       # Create drivers floppy
-       cd /tmp && rm -rf drivers.tgz drivers.tar bin lib etc var
-       cd / && tar -cf /tmp/drivers.tar  \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/acpi/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/block/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/char/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/ide/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/isdn/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/net/ppp*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/net/slip*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/net/slhc*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/net/tun*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/scsi/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/message/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/input/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/usb/storage/*' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/usb/host/*' \
-           --exclude='lib/modules/$(KVER)/kernel/arch/*' \
-           --exclude='lib/modules/$(KVER)/kernel/fs/*' \
-           --exclude='lib/modules/$(KVER)/kernel/net/atm/*' \
-           --exclude='lib/modules/$(KVER)/kernel/net/ipsec/*' \
-           --exclude='lib/modules/$(KVER)/kernel/net/ipv4/*' \
-           --exclude='lib/modules/$(KVER)/kernel/net/sched/*' \
-           --exclude='lib/modules/$(KVER)/*map' \
-           --exclude='lib/modules/$(KVER)/misc/*' \
-           --exclude='lib/modules/$(KVER)/extra/*' \
-           --exclude='lib/modules/$(KVER)/pcmcia/*' \
-           --exclude='lib/modules/$(KVER)/build' \
-           --exclude='lib/modules/$(KVER)/kernel/drivers/atm/*' \
-           --exclude=lib/modules/$(KVER)/kernel/drivers/usb/{3cp4218.o.gz,acm.o.gz,amedyn.o.gz,cxacru.o.gz,speedtch.o.gz,hid.o.gz,usbcore.o.gz} \
-           --exclude='lib/modules/$(KVER)/modules.*' \
-           lib/modules/$(KVER)
-       cd /tmp && tar xf drivers.tar
-       cd /tmp && mkdir -p {bin,etc/pcmcia,var/lib/pcmcia,var/run}
-       cd /tmp && cp -aR /install/misc/bin/* bin
-       cd /tmp && cp -r /etc/pcmcia/{config*,net*} etc/pcmcia
-       # cardmgr wants to execute these to bring up the card, we'll
-       # create blank ones as we'll bring them up ourselves
-       cd /tmp/etc/pcmcia && rm -f network 
-       cd /tmp/etc/pcmcia && touch network
-       cd /tmp/etc/pcmcia && chmod +x network
-       cd /tmp && tar -cf - bin/ etc/pcmcia var lib/modules/$(KVER) | gzip -9 -c > drivers.tgz
-
-       if [ "$(MACHINE)" = "alpha" ]; then \
-               cp /tmp/drivers.tgz /install/images/drivers-$(VERSION).img; \
-       else \
-               dd if=/tmp/drivers.tgz of=/install/images/drivers-$(VERSION).img bs=1440k count=1 conv=sync; \
-       fi
-       rm -rf /tmp/drivers.tgz /tmp/drivers.tar /tmp/bin /tmp/lib
-
-       ### If this fails, the disk is TOO FULL !!!!
-       tar tzf /install/images/drivers-$(VERSION).img >/dev/null 2>&1
-
-       @$(POSTBUILD)
+###############################################################################\r
+# This file is part of the IPCop Firewall.                                    #\r
+#                                                                             #\r
+# IPCop is free software; you can redistribute it and/or modify               #\r
+# it under the terms of the GNU General Public License as published by        #\r
+# the Free Software Foundation; either version 2 of the License, or           #\r
+# (at your option) any later version.                                         #\r
+#                                                                             #\r
+# IPCop is distributed in the hope that it will be useful,                    #\r
+# but WITHOUT ANY WARRANTY; without even the implied warranty of              #\r
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the               #\r
+# GNU General Public License for more details.                                #\r
+#                                                                             #\r
+# You should have received a copy of the GNU General Public License           #\r
+# along with IPCop; if not, write to the Free Software                        #\r
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA    #\r
+#                                                                             #\r
+# Makefiles are based on LFSMake, which is                                    #\r
+# Copyright (C) 2002 Rod Roard <rod@sunsetsystems.com>                        #\r
+#                                                                             #\r
+# Modifications by:                                                           #\r
+# ??-12-2003 Mark Wormgoor < mark@wormgoor.com>                               #\r
+#          - Modified Makefile for IPCop build                                #\r
+#                                                                             #\r
+# $Id: driver.img,v 1.24.2.7 2006/01/29 20:17:30 franck78 Exp $\r
+#                                                                             #\r
+###############################################################################\r
+\r
+###############################################################################\r
+# Definitions\r
+###############################################################################\r
+\r
+include Config\r
+\r
+THISAPP    = driver-$(VERSION).img\r
+TARGET     = $(DIR_INFO)/$(THISAPP)\r
+\r
+###############################################################################\r
+# Top-level Rules\r
+###############################################################################\r
+\r
+install : $(TARGET)\r
+\r
+check :\r
+\r
+download :\r
+\r
+md5 :\r
+\r
+###############################################################################\r
+# Installation Details\r
+###############################################################################\r
+\r
+$(TARGET) :\r
+       @$(PREBUILD)\r
+       -strip --strip-all   /install/misc/bin/*\r
+\r
+       # make new dependencies \r
+       depmod -a -F /boot/System.map-$(KVER) $(KVER)\r
+       if [ "$(MACHINE)" = "i386" ]; then \\r
+               depmod -a -F /boot/System.map-$(KVER)-smp $(KVER)-smp; \\r
+       fi\r
+\r
+       # Create drivers floppy\r
+       cd /tmp && rm -rf drivers.tgz drivers.tar bin lib etc var\r
+       cd / && tar -cf /tmp/drivers.tar  \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/acpi/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/block/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/char/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/ide/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/isdn/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/net/ppp*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/net/slip*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/net/slhc*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/net/tun*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/scsi/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/message/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/input/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/usb/storage/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/usb/host/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/arch/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/fs/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/net/atm/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/net/ipsec/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/net/ipv4/*' \\r
+           --exclude='lib/modules/$(KVER)/kernel/net/sched/*' \\r
+           --exclude='lib/modules/$(KVER)/*map' \\r
+           --exclude='lib/modules/$(KVER)/misc/*' \\r
+           --exclude='lib/modules/$(KVER)/extra/*' \\r
+           --exclude='lib/modules/$(KVER)/pcmcia/*' \\r
+           --exclude='lib/modules/$(KVER)/build' \\r
+           --exclude='lib/modules/$(KVER)/kernel/drivers/atm/*' \\r
+           --exclude=lib/modules/$(KVER)/kernel/drivers/usb/{3cp4218.o.gz,acm.o.gz,amedyn.o.gz,cxacru.o.gz,speedtch.o.gz,hid.o.gz,usbcore.o.gz} \\r
+           --exclude='lib/modules/$(KVER)/modules.*' \\r
+           lib/modules/$(KVER)\r
+       cd /tmp && tar xf drivers.tar\r
+       cd /tmp && mkdir -p {bin,etc/pcmcia,var/lib/pcmcia,var/run}\r
+       cd /tmp && cp -aR /install/misc/bin/* bin\r
+       cd /tmp && cp -r /etc/pcmcia/{config*,net*} etc/pcmcia\r
+       # cardmgr wants to execute these to bring up the card, we'll\r
+       # create blank ones as we'll bring them up ourselves\r
+       cd /tmp/etc/pcmcia && rm -f network \r
+       cd /tmp/etc/pcmcia && touch network\r
+       cd /tmp/etc/pcmcia && chmod +x network\r
+       cd /tmp && tar -cf - bin/ etc/pcmcia var lib/modules/$(KVER) | gzip -9 -c > drivers.tgz\r
+\r
+       if [ "$(MACHINE)" = "alpha" ]; then \\r
+               cp /tmp/drivers.tgz /install/images/drivers-$(VERSION).img; \\r
+       else \\r
+               dd if=/tmp/drivers.tgz of=/install/images/drivers-$(VERSION).img bs=1440k count=1 conv=sync; \\r
+       fi\r
+       rm -rf /tmp/drivers.tgz /tmp/drivers.tar /tmp/bin /tmp/lib\r
+\r
+       ### If this fails, the disk is TOO FULL !!!!\r
+       tar tzf /install/images/drivers-$(VERSION).img >/dev/null 2>&1\r
+\r
+       @$(POSTBUILD)\r
index b9a3e9b32403b3b678795b3fc00024a5813d57b9..d1912387acdacfc622f7582d97d037b56aa689b7 100644 (file)
--- a/lfs/linux
+++ b/lfs/linux
-###############################################################################
-# This file is part of the IPCop Firewall.                                    #
-#                                                                             #
-# IPCop 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           #
-# (at your option) any later version.                                         #
-#                                                                             #
-# IPCop 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 <rod@sunsetsystems.com>                        #
-#                                                                             #
-# Modifications by:                                                           #
-# ??-12-2003 Mark Wormgoor < mark@wormgoor.com>                               #
-#          - Modified Makefile for IPCop build                                #
-#                                                                             #
-# $Id: linux,v 1.42.2.57 2005/07/28 07:01:27 gespinasse Exp $
-#                                                                             #
-###############################################################################
-
-###############################################################################
-# Definitions
-###############################################################################
-
-include Config
-
-VER        = 2.4.31
-
-THISAPP    = linux-$(VER)
-DL_FILE    = $(THISAPP).tar.gz
-DL_FROM    = $(URL_KERNEL)/linux/kernel/v2.4
-DIR_APP    = $(DIR_SRC)/$(THISAPP)
-CFLAGS     =
-CXXFLAGS   =
-
-# Normal build or /tools build.
-#
-ifeq "$(ROOT)" ""
-ifeq "$(LFS_PASS)" "ipcop"
-ifeq "$(EMB)" ""
-  TARGET = $(DIR_INFO)/$(THISAPP)-ipcop
-endif
-ifeq "$(EMB)" "1"
-  TARGET = $(DIR_INFO)/$(THISAPP)-ipcop-EMB
-endif
-ifeq "$(EMB)" "installer"
-  TARGET = $(DIR_INFO)/$(THISAPP)-ipcop-installer
-endif
-else
-  TARGET = $(DIR_INFO)/$(THISAPP)
-endif
-else
-  TARGET = $(DIR_INFO)/$(THISAPP)-tools
-endif
-
-###############################################################################
-# Top-level Rules
-###############################################################################
-objects =$(DL_FILE) \
-       openswan-1.0.10rc2.tar.gz \
-       iptables-1.3.5.tar.bz2 \
-       patch-o-matic-ng-20060206.tar.bz2 \
-       kbc_option_2420.patch \
-       net4801.kernel.patch_2.4.31 \
-       netfilter-layer7-v2.1.tar.gz
-
-$(DL_FILE) = $(DL_FROM)/$(DL_FILE)
-openswan-1.0.10rc2.tar.gz              = ftp://ftp.man.szczecin.pl/disks/disk0/security/network-security/ipsec/openswan/openswan-1.0.10rc2.tar.gz
-patch-o-matic-ng-20060206.tar.bz2      = ftp://ftp.netfilter.org/pub/patch-o-matic-ng/snapshot/patch-o-matic-ng-20060206.tar.bz2
-iptables-1.3.5.tar.bz2                 = http://www.netfilter.org/files/iptables-1.3.5.tar.bz2
-kbc_option_2420.patch                   = http://developer.osdl.org/rddunlap/patches/kbc_option_2420.patch
-net4801.kernel.patch_2.4.31             = http://www.sk-tech.net/support/net4801.kernel.patch_2.4.31
-netfilter-layer7-v2.1.tar.gz                   = http://belnet.dl.sourceforge.net/sourceforge/l7-filter/netfilter-layer7-v2.1.tar.gz
-
-$(DL_FILE)_MD5                         = ea3f99fc82617886059d58d0644dab26
-openswan-1.0.10rc2.tar.gz_MD5          = 20d51ff963da78f826f4e0f0ebc4bcef
-patch-o-matic-ng-20060206.tar.bz2_MD5  = eca9893afb753e331caddfe63142b566
-iptables-1.3.5.tar.bz2_MD5             = 00fb916fa8040ca992a5ace56d905ea5
-kbc_option_2420.patch_MD5               = 6d37870344f7fcf97ace1fbf43323c60
-net4801.kernel.patch_2.4.31_MD5         = c7d64e3caedb2f2b10e1c11db7f73a04
-netfilter-layer7-v2.1.tar.gz_MD5               = 551626a158c2a2cbfd937d27ecc7fac1
-
-install : $(TARGET)
-
-check : $(patsubst %,$(DIR_CHK)/%,$(objects))
-
-download :$(patsubst %,$(DIR_DL)/%,$(objects))
-
-md5 : $(subst %,%_MD5,$(objects))
-
-###############################################################################
-# Downloading, checking, md5sum
-###############################################################################
-
-$(patsubst %,$(DIR_CHK)/%,$(objects)) :
-       @$(CHECK)
-
-$(patsubst %,$(DIR_DL)/%,$(objects)) :
-       @$(LOAD)
-
-$(subst %,%_MD5,$(objects)) :
-       @$(MD5)
-
-###############################################################################
-# Installation Details
-###############################################################################
-
-$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
-       @$(PREBUILD)
-       @rm -rf $(DIR_APP) $(DIR_SRC)/linux && cd $(DIR_SRC) && tar zxf $(DIR_DL)/$(DL_FILE)
-       cd $(DIR_SRC) && ln -sf linux-$(VER) linux
-       cd $(DIR_APP) && sed -i -e 's/-Werror//' drivers/scsi/aic7xxx/Makefile
-
-       # Openswan
-       cd $(DIR_SRC) && rm -rf openswan-*
-       cd $(DIR_SRC) && tar xfz $(DIR_DL)/openswan-1.0.10rc2.tar.gz
-       cd $(DIR_SRC)/openswan-1.0.10rc2 && patch -Np1 < $(DIR_SRC)/src/patches/openswan-1.0.1-plutoctl.patch
-       cd $(DIR_SRC)/openswan-1.0.10rc2 && patch -Np1 < $(DIR_SRC)/src/patches/openswan-1.0.6-numif.patch
-       cd $(DIR_SRC)/openswan-1.0.10rc2 && sed -i 's+^KERNELSRC.*$$+KERNELSRC=$(ROOT)/usr/src/linux-$(VER)+' Makefile.inc
-       cd $(DIR_SRC)/openswan-1.0.10rc2 && sed -i -e 's/local\/sbin/local\/sbin:\/tools\/bin/' utils/patcher
-       cd $(DIR_SRC)/openswan-1.0.10rc2 && make insert
-       
-       # Patch-o-matic
-       cd $(DIR_SRC) && rm -rf iptables-*
-       cd $(DIR_SRC) && tar xfj $(DIR_DL)/iptables-1.3.5.tar.bz2 
-       cd $(DIR_SRC) && ln -sf iptables-1.3.5 iptables
-       cd $(DIR_SRC) && rm -rf patch-o-matic*
-       cd $(DIR_SRC) && tar xfj $(DIR_DL)/patch-o-matic-ng-20060206.tar.bz2
-       
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ pending
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ base
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ h323-conntrack-nat
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ cuseeme-nat
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ mms-conntrack-nat
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ pptp-conntrack-nat
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ rtsp-conntrack
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ quake3-conntrack-nat
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ sip-conntrack-nat
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ip_queue_vwmark
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipp2p
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-01-output-hooks
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-02-input-hooks
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-03-policy-lookup
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-04-policy-checks
-       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ TARPIT
-
-       #imq-patch
-       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.28-imq2.diff
-       
-       #layer7-patch
-       cd $(DIR_SRC) && tar xzf $(DIR_DL)/netfilter-layer7-v2.1.tar.gz
-       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/netfilter-layer7-v2.1/kernel-2.4-layer7-2.1.patch
-
-ifeq "$(EMB)" "1"
-       #Emb-patches
-       cd $(DIR_APP) && patch -Np1 < $(DIR_DL)/kbc_option_2420.patch
-       cd $(DIR_APP) && patch -Np1 < $(DIR_DL)/net4801.kernel.patch_2.4.31
-endif
-
-ifeq "$(EMB)" ""
-       # Only do this once on the non-EMB pass
-       cd $(DIR_SRC) && tar czf $(DIR_DL)/iptables-fixed.tar.gz iptables-1.3.5
-endif
-
-       # Olitec isdn gazel patch
-       cd $(DIR_APP) && patch -Np0 < $(DIR_SRC)/src/patches/linux-2.4.23-olitec-isdn.patch
-
-       # Fix /proc/stat output
-       cd $(DIR_APP) && patch -Np2 < $(DIR_SRC)/src/patches/linux-2.4.26-proc-stat.patch
-
-       # Fix libata-core.c
-       # cd $(DIR_APP) && patch -Np0 < $(DIR_SRC)/src/patches/linux-2.4.26-scsi.patch
-
-       # frandom patch
-       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.27-frandom-2.patch
-
-       # Propolice
-       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.27-ssp-1.patch
-
-       # Support ppp-2.4.3 multilink behavior (terminate when no channel is connected)
-       # need updated libpcap older than 0.8.3
-       # cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/ppp_generic-ppp-2.4.3_multilink.patch
-
-       # R8169 clone D-link GSE-528T
-       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.29_r8169clone.patch
-
-       # Cleanup kernel source
-       cd $(DIR_APP) && make mrproper
-ifeq "$(ROOT)" ""
-ifeq "$(LFS_PASS)" "ipcop"
-ifeq "$(EMB)" ""
-       cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE) $(DIR_APP)/.config
-endif
-ifeq "$(EMB)" "1"
-       cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE).EMB $(DIR_APP)/.config
-endif
-ifeq "$(EMB)" "installer"
-       cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE).installer $(DIR_APP)/.config
-       cd $(DIR_APP) && sed -i -e 's/-O2/-Os/g' Makefile
-endif
-
-       cd $(DIR_APP) && make CC="$(KGCC)" oldconfig
-       cd $(DIR_APP) && make CC="$(KGCC)" dep
-       cd $(DIR_APP) && make CC="$(KGCC)" clean
-       if [ "$(MACHINE)" = "i386" -a "$(EMB)" = "" ]; then \
-               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" bzImage; \
-               cd $(DIR_APP) && cp arch/$(MACHINE)/boot/bzImage /boot/vmlinuz-$(VER); \
-               cd $(DIR_APP) && cp System.map /boot/System.map-$(VER); \
-               ln -sf vmlinuz-$(VER) /boot/vmlinuz; \
-               ln -sf System.map-$(VER) /boot/System.map; \
-               cd $(DIR_APP) && make CC="$(KGCC)" modules; \
-               cd $(DIR_APP) && make CC="$(KGCC)" modules_install; \
-       elif [ "$(MACHINE)" = "i386" -a "$(EMB)" = "1" ]; then \
-               cd $(DIR_APP) && sed -i -e 's/EXTRAVERSION\ =/EXTRAVERSION\ =\ -EMB/' Makefile; \
-               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" bzImage; \
-               cd $(DIR_APP) && cp arch/$(MACHINE)/boot/bzImage /boot/vmlinuz-$(VER)-EMB; \
-               cd $(DIR_APP) && cp System.map /boot/System.map-$(VER)-EMB; \
-               ln -sf vmlinuz-$(VER)-EMB /boot/vmlinuz-EMB; \
-               cd $(DIR_APP) && make CC="$(KGCC)" modules; \
-               cd $(DIR_APP) && make CC="$(KGCC)" modules_install; \
-       elif [ "$(MACHINE)" = "i386" -a "$(EMB)" = "installer" ]; then \
-               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" bzImage; \
-               cd $(DIR_APP) && cp arch/$(MACHINE)/boot/bzImage /boot/vmlinuz-installer; \
-       elif [ "$(MACHINE)" = "alpha" ]; then \
-               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" vmlinux; \
-               cd $(DIR_APP) && gzip -9c vmlinux > /boot/vmlinuz-$(VER); \
-               cd $(DIR_APP) && cp System.map /boot/System.map-$(VER); \
-               ln -sf vmlinuz-$(VER) /boot/vmlinuz; \
-               ln -sf System.map-$(VER) /boot/System.map; \
-               cd $(DIR_APP) && make CC="$(KGCC)" modules; \
-               cd $(DIR_APP) && make CC="$(KGCC)" modules_install; \
-       fi
-       # remove symlinked pcmcia directory
-ifeq "$(EMB)" ""
-       rm -rf /lib/modules/$(VER)/pcmcia
-       find /lib/modules/$(VER)/ -name '*.o' -a -type f | xargs gzip -f9
-
-       # Move these SCSI drivers into same directory for probescsi.sh
-       mv -f  /lib/modules/$(VER)/kernel/drivers/scsi/aic7xxx/*     /lib/modules/$(VER)/kernel/drivers/scsi
-       rm -rf /lib/modules/$(VER)/kernel/drivers/scsi/aic7xxx
-       mv -f  /lib/modules/$(VER)/kernel/drivers/scsi/aacraid/*     /lib/modules/$(VER)/kernel/drivers/scsi
-       rm -rf /lib/modules/$(VER)/kernel/drivers/scsi/aacraid
-       mv -f  /lib/modules/$(VER)/kernel/drivers/scsi/sym53c8xx_2/* /lib/modules/$(VER)/kernel/drivers/scsi
-       rm -rf /lib/modules/$(VER)/kernel/drivers/scsi/sym53c8xx_2
-endif
-ifeq "$(EMB)" "1"
-       rm -rf /lib/modules/$(VER)-EMB/pcmcia
-       find /lib/modules/$(VER)-EMB/ -name '*.o' -a -type f | xargs gzip -f9
-
-       # Move these SCSI drivers into same directory for probescsi.sh
-       mv -f  /lib/modules/$(VER)-EMB/kernel/drivers/scsi/aic7xxx/*     /lib/modules/$(VER)-EMB/kernel/drivers/scsi
-       rm -rf /lib/modules/$(VER)-EMB/kernel/drivers/scsi/aic7xxx
-       mv -f  /lib/modules/$(VER)-EMB/kernel/drivers/scsi/aacraid/*     /lib/modules/$(VER)-EMB/kernel/drivers/scsi
-       rm -rf /lib/modules/$(VER)-EMB/kernel/drivers/scsi/aacraid
-       mv -f  /lib/modules/$(VER)-EMB/kernel/drivers/scsi/sym53c8xx_2/* /lib/modules/$(VER)-EMB/kernel/drivers/scsi
-       rm -rf /lib/modules/$(VER)-EMB/kernel/drivers/scsi/sym53c8xx_2
-endif
-
-ifeq "$(EMB)" ""
-       # Only do this once on the non-EMB pass
-       cd $(DIR_APP) && make mandocs
-       -mkdir -p /usr/share/man/man9/
-       cd $(DIR_APP) && cp -af Documentation/man/* /usr/share/man/man9/
-endif
-else
-       cd $(DIR_APP) && make include/linux/version.h
-       cd $(DIR_APP) && make symlinks
-       cd $(DIR_APP) && cp -HRf include/asm /usr/include
-       cd $(DIR_APP) && cp -Rf include/asm-generic /usr/include
-       cd $(DIR_APP) && cp -Rf include/linux /usr/include
-       touch /usr/include/linux/autoconf.h
-endif
-else
-       cd $(DIR_APP) && make include/linux/version.h
-       cd $(DIR_APP) && make symlinks
-       -mkdir -p /tools/include/asm
-       cd $(DIR_APP) && cp -f include/asm/* /tools/include/asm
-       cd $(DIR_APP) && cp -Rf include/asm-generic /tools/include
-       cd $(DIR_APP) && cp -Rf include/linux /tools/include
-       cd $(DIR_APP) && touch /tools/include/linux/autoconf.h
-endif
-       @rm -rf $(DIR_SRC)/patch-o-matic* $(DIR_SRC)/iptables*
-       @$(POSTBUILD)
+###############################################################################\r
+# This file is part of the IPCop Firewall.                                    #\r
+#                                                                             #\r
+# IPCop is free software; you can redistribute it and/or modify               #\r
+# it under the terms of the GNU General Public License as published by        #\r
+# the Free Software Foundation; either version 2 of the License, or           #\r
+# (at your option) any later version.                                         #\r
+#                                                                             #\r
+# IPCop is distributed in the hope that it will be useful,                    #\r
+# but WITHOUT ANY WARRANTY; without even the implied warranty of              #\r
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the               #\r
+# GNU General Public License for more details.                                #\r
+#                                                                             #\r
+# You should have received a copy of the GNU General Public License           #\r
+# along with IPCop; if not, write to the Free Software                        #\r
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA    #\r
+#                                                                             #\r
+# Makefiles are based on LFSMake, which is                                    #\r
+# Copyright (C) 2002 Rod Roard <rod@sunsetsystems.com>                        #\r
+#                                                                             #\r
+# Modifications by:                                                           #\r
+# ??-12-2003 Mark Wormgoor < mark@wormgoor.com>                               #\r
+#          - Modified Makefile for IPCop build                                #\r
+#                                                                             #\r
+# $Id: linux,v 1.42.2.57 2005/07/28 07:01:27 gespinasse Exp $\r
+#                                                                             #\r
+###############################################################################\r
+\r
+###############################################################################\r
+# Definitions\r
+###############################################################################\r
+\r
+include Config\r
+\r
+VER        = 2.4.31\r
+\r
+THISAPP    = linux-$(VER)\r
+DL_FILE    = $(THISAPP).tar.gz\r
+DL_FROM    = $(URL_KERNEL)/linux/kernel/v2.4\r
+DIR_APP    = $(DIR_SRC)/$(THISAPP)\r
+CFLAGS     =\r
+CXXFLAGS   =\r
+\r
+# Normal build or /tools build.\r
+#\r
+ifeq "$(ROOT)" ""\r
+ifeq "$(LFS_PASS)" "ipcop"\r
+ifeq "$(EMB)" ""\r
+  TARGET = $(DIR_INFO)/$(THISAPP)-ipcop\r
+endif\r
+ifeq "$(SMP)" "1"\r
+  TARGET = $(DIR_INFO)/$(THISAPP)-ipcop-smp\r
+endif\r
+ifeq "$(SMP)" "installer"\r
+  TARGET = $(DIR_INFO)/$(THISAPP)-ipcop-installer\r
+endif\r
+else\r
+  TARGET = $(DIR_INFO)/$(THISAPP)\r
+endif\r
+else\r
+  TARGET = $(DIR_INFO)/$(THISAPP)-tools\r
+endif\r
+\r
+###############################################################################\r
+# Top-level Rules\r
+###############################################################################\r
+objects =$(DL_FILE) \\r
+       openswan-1.0.10rc2.tar.gz \\r
+       iptables-1.3.5.tar.bz2 \\r
+       patch-o-matic-ng-20060206.tar.bz2 \\r
+       kbc_option_2420.patch \\r
+       net4801.kernel.patch_2.4.31 \\r
+       netfilter-layer7-v2.1.tar.gz\r
+\r
+$(DL_FILE) = $(DL_FROM)/$(DL_FILE)\r
+openswan-1.0.10rc2.tar.gz              = ftp://ftp.man.szczecin.pl/disks/disk0/security/network-security/ipsec/openswan/openswan-1.0.10rc2.tar.gz\r
+patch-o-matic-ng-20060206.tar.bz2      = ftp://ftp.netfilter.org/pub/patch-o-matic-ng/snapshot/patch-o-matic-ng-20060206.tar.bz2\r
+iptables-1.3.5.tar.bz2                 = http://www.netfilter.org/files/iptables-1.3.5.tar.bz2\r
+kbc_option_2420.patch                   = http://developer.osdl.org/rddunlap/patches/kbc_option_2420.patch\r
+net4801.kernel.patch_2.4.31             = http://www.sk-tech.net/support/net4801.kernel.patch_2.4.31\r
+netfilter-layer7-v2.1.tar.gz                   = http://belnet.dl.sourceforge.net/sourceforge/l7-filter/netfilter-layer7-v2.1.tar.gz\r
+\r
+$(DL_FILE)_MD5                         = ea3f99fc82617886059d58d0644dab26\r
+openswan-1.0.10rc2.tar.gz_MD5          = 20d51ff963da78f826f4e0f0ebc4bcef\r
+patch-o-matic-ng-20060206.tar.bz2_MD5  = eca9893afb753e331caddfe63142b566\r
+iptables-1.3.5.tar.bz2_MD5             = 00fb916fa8040ca992a5ace56d905ea5\r
+kbc_option_2420.patch_MD5               = 6d37870344f7fcf97ace1fbf43323c60\r
+net4801.kernel.patch_2.4.31_MD5         = c7d64e3caedb2f2b10e1c11db7f73a04\r
+netfilter-layer7-v2.1.tar.gz_MD5               = 551626a158c2a2cbfd937d27ecc7fac1\r
+\r
+install : $(TARGET)\r
+\r
+check : $(patsubst %,$(DIR_CHK)/%,$(objects))\r
+\r
+download :$(patsubst %,$(DIR_DL)/%,$(objects))\r
+\r
+md5 : $(subst %,%_MD5,$(objects))\r
+\r
+###############################################################################\r
+# Downloading, checking, md5sum\r
+###############################################################################\r
+\r
+$(patsubst %,$(DIR_CHK)/%,$(objects)) :\r
+       @$(CHECK)\r
+\r
+$(patsubst %,$(DIR_DL)/%,$(objects)) :\r
+       @$(LOAD)\r
+\r
+$(subst %,%_MD5,$(objects)) :\r
+       @$(MD5)\r
+\r
+###############################################################################\r
+# Installation Details\r
+###############################################################################\r
+\r
+$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))\r
+       @$(PREBUILD)\r
+       @rm -rf $(DIR_APP) $(DIR_SRC)/linux && cd $(DIR_SRC) && tar zxf $(DIR_DL)/$(DL_FILE)\r
+       cd $(DIR_SRC) && ln -sf linux-$(VER) linux\r
+       cd $(DIR_APP) && sed -i -e 's/-Werror//' drivers/scsi/aic7xxx/Makefile\r
+\r
+       # Openswan\r
+       cd $(DIR_SRC) && rm -rf openswan-*\r
+       cd $(DIR_SRC) && tar xfz $(DIR_DL)/openswan-1.0.10rc2.tar.gz\r
+       cd $(DIR_SRC)/openswan-1.0.10rc2 && patch -Np1 < $(DIR_SRC)/src/patches/openswan-1.0.1-plutoctl.patch\r
+       cd $(DIR_SRC)/openswan-1.0.10rc2 && patch -Np1 < $(DIR_SRC)/src/patches/openswan-1.0.6-numif.patch\r
+       cd $(DIR_SRC)/openswan-1.0.10rc2 && sed -i 's+^KERNELSRC.*$$+KERNELSRC=$(ROOT)/usr/src/linux-$(VER)+' Makefile.inc\r
+       cd $(DIR_SRC)/openswan-1.0.10rc2 && sed -i -e 's/local\/sbin/local\/sbin:\/tools\/bin/' utils/patcher\r
+       cd $(DIR_SRC)/openswan-1.0.10rc2 && make insert\r
+       \r
+       # Patch-o-matic\r
+       cd $(DIR_SRC) && rm -rf iptables-*\r
+       cd $(DIR_SRC) && tar xfj $(DIR_DL)/iptables-1.3.5.tar.bz2 \r
+       cd $(DIR_SRC) && ln -sf iptables-1.3.5 iptables\r
+       cd $(DIR_SRC) && rm -rf patch-o-matic*\r
+       cd $(DIR_SRC) && tar xfj $(DIR_DL)/patch-o-matic-ng-20060206.tar.bz2\r
+       \r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ pending\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ base\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ h323-conntrack-nat\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ cuseeme-nat\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ mms-conntrack-nat\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ pptp-conntrack-nat\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ rtsp-conntrack\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ quake3-conntrack-nat\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ sip-conntrack-nat\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ip_queue_vwmark\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipp2p\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-01-output-hooks\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-02-input-hooks\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-03-policy-lookup\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ ipsec-04-policy-checks\r
+       cd $(DIR_SRC)/patch-o-matic* && yes 'y' | ./runme --kernel-path=$(ROOT)/usr/src/linux/ --iptables-path=$(ROOT)/usr/src/iptables/ TARPIT\r
+\r
+       #imq-patch\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.28-imq2.diff\r
+       \r
+       #layer7-patch\r
+       cd $(DIR_SRC) && tar xzf $(DIR_DL)/netfilter-layer7-v2.1.tar.gz\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/netfilter-layer7-v2.1/kernel-2.4-layer7-2.1.patch\r
+\r
+ifeq "$(EMB)" "1"\r
+       #Emb-patches\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_DL)/kbc_option_2420.patch\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_DL)/net4801.kernel.patch_2.4.31\r
+endif\r
+\r
+ifeq "$(SMP)" ""\r
+       # Only do this once on the non-SMP pass\r
+       cd $(DIR_SRC) && tar czf $(DIR_DL)/iptables-fixed.tar.gz iptables-1.2.11\r
+endif\r
+\r
+       # Olitec isdn gazel patch\r
+       cd $(DIR_APP) && patch -Np0 < $(DIR_SRC)/src/patches/linux-2.4.23-olitec-isdn.patch\r
+\r
+       # Fix /proc/stat output\r
+       cd $(DIR_APP) && patch -Np2 < $(DIR_SRC)/src/patches/linux-2.4.26-proc-stat.patch\r
+\r
+       # Fix libata-core.c\r
+       # cd $(DIR_APP) && patch -Np0 < $(DIR_SRC)/src/patches/linux-2.4.26-scsi.patch\r
+\r
+       # frandom patch\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.27-frandom-2.patch\r
+\r
+       # Propolice\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.27-ssp-1.patch\r
+\r
+       # Support ppp-2.4.3 multilink behavior (terminate when no channel is connected)\r
+       # need updated libpcap older than 0.8.3\r
+       # cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/ppp_generic-ppp-2.4.3_multilink.patch\r
+\r
+       # R8169 clone D-link GSE-528T\r
+       cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.4.29_r8169clone.patch\r
+\r
+       # Cleanup kernel source\r
+       cd $(DIR_APP) && make mrproper\r
+ifeq "$(ROOT)" ""\r
+ifeq "$(LFS_PASS)" "ipcop"\r
+ifeq "$(SMP)" ""\r
+       cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE) $(DIR_APP)/.config\r
+endif\r
+ifeq "$(SMP)" "1"\r
+       cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE).smp $(DIR_APP)/.config\r
+endif\r
+ifeq "$(SMP)" "installer"\r
+       cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE).installer $(DIR_APP)/.config\r
+       cd $(DIR_APP) && sed -i -e 's/-O2/-Os/g' Makefile\r
+endif\r
+\r
+       cd $(DIR_APP) && make CC="$(KGCC)" oldconfig\r
+       cd $(DIR_APP) && make CC="$(KGCC)" dep\r
+       cd $(DIR_APP) && make CC="$(KGCC)" clean\r
+       if [ "$(MACHINE)" = "i386" -a "$(EMB)" = "" ]; then \\r
+               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" bzImage; \\r
+               cd $(DIR_APP) && cp arch/$(MACHINE)/boot/bzImage /boot/vmlinuz-$(VER); \\r
+               cd $(DIR_APP) && cp System.map /boot/System.map-$(VER); \\r
+               ln -sf vmlinuz-$(VER) /boot/vmlinuz; \\r
+               ln -sf System.map-$(VER) /boot/System.map; \\r
+               cd $(DIR_APP) && make CC="$(KGCC)" modules; \\r
+               cd $(DIR_APP) && make CC="$(KGCC)" modules_install; \\r
+       elif [ "$(MACHINE)" = "i386" -a "$(EMB)" = "1" ]; then \\r
+               cd $(DIR_APP) && sed -i -e 's/EXTRAVERSION\ =/EXTRAVERSION\ =\ -EMB/' Makefile; \\r
+               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" bzImage; \\r
+               cd $(DIR_APP) && cp arch/$(MACHINE)/boot/bzImage /boot/vmlinuz-$(VER)-EMB; \\r
+               cd $(DIR_APP) && cp System.map /boot/System.map-$(VER)-EMB; \\r
+               ln -sf vmlinuz-$(VER)-EMB /boot/vmlinuz-EMB; \\r
+               cd $(DIR_APP) && make CC="$(KGCC)" modules; \\r
+               cd $(DIR_APP) && make CC="$(KGCC)" modules_install; \\r
+       elif [ "$(MACHINE)" = "i386" -a "$(EMB)" = "installer" ]; then \\r
+               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" bzImage; \\r
+               cd $(DIR_APP) && cp arch/$(MACHINE)/boot/bzImage /boot/vmlinuz-installer; \\r
+       elif [ "$(MACHINE)" = "alpha" ]; then \\r
+               cd $(DIR_APP) && make -j 3 CC="$(KGCC)" vmlinux; \\r
+               cd $(DIR_APP) && gzip -9c vmlinux > /boot/vmlinuz-$(VER); \\r
+               cd $(DIR_APP) && cp System.map /boot/System.map-$(VER); \\r
+               ln -sf vmlinuz-$(VER) /boot/vmlinuz; \\r
+               ln -sf System.map-$(VER) /boot/System.map; \\r
+               cd $(DIR_APP) && make CC="$(KGCC)" modules; \\r
+               cd $(DIR_APP) && make CC="$(KGCC)" modules_install; \\r
+       fi\r
+       # remove symlinked pcmcia directory\r
+ifeq "$(SMP)" ""\r
+       rm -rf /lib/modules/$(VER)/pcmcia\r
+       find /lib/modules/$(VER)/ -name '*.o' -a -type f | xargs gzip -f9\r
+\r
+       # Move these SCSI drivers into same directory for probescsi.sh\r
+       mv -f  /lib/modules/$(VER)/kernel/drivers/scsi/aic7xxx/*     /lib/modules/$(VER)/kernel/drivers/scsi\r
+       rm -rf /lib/modules/$(VER)/kernel/drivers/scsi/aic7xxx\r
+       mv -f  /lib/modules/$(VER)/kernel/drivers/scsi/aacraid/*     /lib/modules/$(VER)/kernel/drivers/scsi\r
+       rm -rf /lib/modules/$(VER)/kernel/drivers/scsi/aacraid\r
+       mv -f  /lib/modules/$(VER)/kernel/drivers/scsi/sym53c8xx_2/* /lib/modules/$(VER)/kernel/drivers/scsi\r
+       rm -rf /lib/modules/$(VER)/kernel/drivers/scsi/sym53c8xx_2\r
+endif\r
+ifeq "$(SMP)" "1"\r
+       rm -rf /lib/modules/$(VER)-smp/pcmcia\r
+       find /lib/modules/$(VER)-smp/ -name '*.o' -a -type f | xargs gzip -f9\r
+\r
+       # Move these SCSI drivers into same directory for probescsi.sh\r
+       mv -f  /lib/modules/$(VER)-smp/kernel/drivers/scsi/aic7xxx/*     /lib/modules/$(VER)-smp/kernel/drivers/scsi\r
+       rm -rf /lib/modules/$(VER)-smp/kernel/drivers/scsi/aic7xxx\r
+       mv -f  /lib/modules/$(VER)-smp/kernel/drivers/scsi/aacraid/*     /lib/modules/$(VER)-smp/kernel/drivers/scsi\r
+       rm -rf /lib/modules/$(VER)-smp/kernel/drivers/scsi/aacraid\r
+       mv -f  /lib/modules/$(VER)-smp/kernel/drivers/scsi/sym53c8xx_2/* /lib/modules/$(VER)-smp/kernel/drivers/scsi\r
+       rm -rf /lib/modules/$(VER)-smp/kernel/drivers/scsi/sym53c8xx_2\r
+endif\r
+\r
+ifeq "$(SMP)" ""\r
+       # Only do this once on the non-SMP pass\r
+       cd $(DIR_APP) && make mandocs\r
+       -mkdir -p /usr/share/man/man9/\r
+       cd $(DIR_APP) && cp -af Documentation/man/* /usr/share/man/man9/\r
+endif\r
+else\r
+       cd $(DIR_APP) && make include/linux/version.h\r
+       cd $(DIR_APP) && make symlinks\r
+       cd $(DIR_APP) && cp -HRf include/asm /usr/include\r
+       cd $(DIR_APP) && cp -Rf include/asm-generic /usr/include\r
+       cd $(DIR_APP) && cp -Rf include/linux /usr/include\r
+       touch /usr/include/linux/autoconf.h\r
+endif\r
+else\r
+       cd $(DIR_APP) && make include/linux/version.h\r
+       cd $(DIR_APP) && make symlinks\r
+       -mkdir -p /tools/include/asm\r
+       cd $(DIR_APP) && cp -f include/asm/* /tools/include/asm\r
+       cd $(DIR_APP) && cp -Rf include/asm-generic /tools/include\r
+       cd $(DIR_APP) && cp -Rf include/linux /tools/include\r
+       cd $(DIR_APP) && touch /tools/include/linux/autoconf.h\r
+endif\r
+       @rm -rf $(DIR_SRC)/patch-o-matic* $(DIR_SRC)/iptables*\r
+       @$(POSTBUILD)\r
diff --git a/make.sh b/make.sh
index ae549013520bdab751c316cb1758c5065b7a037d..9e4a1a6f7a63b39ed7111fdec53d7485b42ec513 100644 (file)
--- a/make.sh
+++ b/make.sh
-#!/bin/bash
-#
-############################################################################
-#                                                                          #
-# This file is part of the IPCop Firewall.                                 #
-#                                                                          #
-# IPCop 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        #
-# (at your option) any later version.                                      #
-#                                                                          #
-# IPCop 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 #
-#                                                                          #
-# Copyright (C) 2001 Mark Wormgoor <mark@wormgoor.com>.                    #
-#                                                                          #
-# (c) 2001 Eric S. Johansson <esj@harvee.billerica.ma.us> Check for Bash   #
-# (c) 2002 Thorsten Fischer <frosch@cs.tu-berlin.de> MD5Sum checking       #
-#                                                                          #
-############################################################################
-#
-# $Id: make.sh,v 1.129.2.145 2006/02/01 07:04:09 gespinasse Exp $
-#
-
-  NAME="IPFire"                                        # Software name
-  SNAME="ipfire"                                       # Short name
-  VERSION="1.4"                                # Version number
-  PREVIOUSTAG=IPCOP_v1_4_10_FINAL
-  SLOGAN="We save your network"                # Software slogan
-  CONFIG_ROOT=/var/ipfire                      # Configuration rootdir
-  NICE=10
-  MAX_RETRIES=3                                        # prefetch/check loop
-  KVER=`grep --max-count=1 VER lfs/linux | awk '{ print $3 }'`
-  MACHINE=`uname -m`
-
-  # Debian specific settings
-  if [ ! -e /etc/debian_version ]; then
-       FULLPATH=`which $0`
-  else
-       if [ -x /usr/bin/realpath ]; then
-               FULLPATH=`/usr/bin/realpath $0`
-       else
-               echo "ERROR: Need to do apt-get install realpath"
-               exit 1
-       fi
-  fi
-
-
-  PWD=`pwd`
-  BASENAME=`basename $0`
-  BASEDIR=`echo $FULLPATH | sed "s/\/$BASENAME//g"`
-  LOGFILE=$BASEDIR/log/_build.preparation.log
-  export BASEDIR LOGFILE
-  DIR_CHK=$BASEDIR/cache/check
-  mkdir $BASEDIR/log/ 2>/dev/null
-
-  if [ 'x86_64' = $MACHINE -o 'i686' = $MACHINE -o 'i586' = $MACHINE -o 'i486' = $MACHINE -o 'i386' = $MACHINE ]; then
-       echo "`date -u '+%b %e %T'`: Machine is ix86 (or equivalent)" | tee -a $LOGFILE
-       MACHINE=i386
-       BUILDTARGET=i386-pc-linux-gnu
-       CFLAGS="-O2 -mcpu=i386 -march=i386 -pipe -fomit-frame-pointer"
-       CXXFLAGS="-O2 -mcpu=i386 -march=i386 -pipe -fomit-frame-pointer"
-  elif [ 'alpha' = $MACHINE ]; then
-       echo "`date -u '+%b %e %T'`: Machine is Alpha AXP" | tee -a $LOGFILE
-       BUILDTARGET=alpha-unknown-linux-gnu
-       CFLAGS="-O2 -mcpu=ev4 -mieee -pipe"
-       CXXFLAGS="-O2 -mcpu=ev4 -mieee -pipe"
-  else
-       echo "`date -u '+%b %e %T'`: Can't determine your architecture - $MACHINE" | tee -a $LOGFILE
-       exit 1
-  fi
-
-# Define immediately
-stdumount() {
-       umount $BASEDIR/build/dev/pts           2>/dev/null;
-       umount $BASEDIR/build/proc              2>/dev/null;
-       umount $BASEDIR/build/install/mnt       2>/dev/null;
-       umount $BASEDIR/build/usr/src/cache     2>/dev/null;
-       umount $BASEDIR/build/usr/src/ccache    2>/dev/null;
-       umount $BASEDIR/build/usr/src/config    2>/dev/null;
-       umount $BASEDIR/build/usr/src/doc       2>/dev/null;
-       umount $BASEDIR/build/usr/src/html      2>/dev/null;
-       umount $BASEDIR/build/usr/src/langs     2>/dev/null;
-       umount $BASEDIR/build/usr/src/lfs       2>/dev/null;
-       umount $BASEDIR/build/usr/src/log       2>/dev/null;
-       umount $BASEDIR/build/usr/src/src       2>/dev/null;
-}
-
-exiterror() {
-       stdumount
-       for i in `seq 0 7`; do
-           if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then
-               losetup -d /dev/loop${i} 2>/dev/null
-           fi;
-       done
-       echo "ERROR: $*"
-       echo "       Check $LOGFILE for errors if applicable"
-       exit 1
-}
-
-entershell() {
-       if [ ! -e $BASEDIR/build/usr/src/lfs/ ]; then
-               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/"
-       fi
-       echo "Entering to a shell inside LFS chroot, go out with exit"
-       chroot $LFS /tools/bin/env -i HOME=/root TERM=$TERM PS1='\u:\w\$ ' \
-               PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \
-               VERSION=$VERSION CONFIG_ROOT=$CONFIG_ROOT \
-               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
-               CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
-               CCACHE_DIR=/usr/src/ccache \
-               CCACHE_HASHDIR=1 \
-               KVER=$KVER \
-               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
-               KGCC="ccache /usr/bin/gcc" \
-               /tools/bin/bash
-       if [ $? -ne 0 ]; then
-                       exiterror "chroot error"
-       else
-               stdumount
-       fi
-}
-
-prepareenv() {
-    ############################################################################
-    #                                                                          #
-    # Are we running the right shell?                                          #
-    #                                                                          #
-    ############################################################################
-    if [ ! "$BASH" ]; then
-       exiterror "BASH environment variable is not set.  You're probably running the wrong shell."
-    fi
-
-    if [ -z "${BASH_VERSION}" ]; then
-       exiterror "Not running BASH shell."
-    fi
-
-
-    ############################################################################
-    #                                                                          #
-    # Trap on emergency exit                                                   #
-    #                                                                          #
-    ############################################################################
-    trap "exiterror 'Build process interrupted'" SIGINT SIGTERM SIGKILL SIGSTOP SIGQUIT
-
-
-    ############################################################################
-    #                                                                          #
-    # Resetting our nice level                                                 #
-    #                                                                          #
-    ############################################################################
-    echo "`date -u '+%b %e %T'`: Resetting our nice level to $NICE" | tee -a $LOGFILE
-    renice $NICE $$ > /dev/null
-    if [ `nice` != "$NICE" ]; then
-       exiterror "Failed to set correct nice level"
-    fi
-
-    ############################################################################
-    #                                                                          #
-    # Checking if running as root user                                         #
-    #                                                                          #
-    ############################################################################
-    echo "`date -u '+%b %e %T'`: Checking if we're running as root user" | tee -a $LOGFILE
-    if [ `id -u` != 0 ]; then
-       exiterror "Not building as root"
-    fi
-
-
-    ############################################################################
-    #                                                                          #
-    # Checking for necessary temporary space                                   #
-    #                                                                          #
-    ############################################################################
-    echo "`date -u '+%b %e %T'`: Checking for necessary space on disk $BASE_DEV" | tee -a $LOGFILE
-    BASE_DEV=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $1 }'`
-    BASE_ASPACE=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $4 }'`
-    if (( 2202000 > $BASE_ASPACE )); then
-       BASE_USPACE=`du -skx $BASEDIR | awk '{print $1}'`
-       if (( 2202000 - $BASE_USPACE > $BASE_ASPACE )); then
-               exiterror "Not enough temporary space available, need at least 2.1GB on $BASE_DEV"
-       fi
-    fi
-
-    ############################################################################
-    #                                                                          #
-    # Building Linux From Scratch system                                       #
-    #                                                                          #
-    ############################################################################
-    echo "`date -u '+%b %e %T'`: Building Linux From Scratch system" | tee -a $LOGFILE
-
-    # Set umask
-    umask 022
-
-    # Set LFS Directory
-    LFS=$BASEDIR/build
-
-    # Check /tools symlink
-    if [ -h /tools ]; then
-        rm -f /tools
-    fi
-    if [ ! -a /tools ]; then
-       ln -s $BASEDIR/build/tools /
-    fi
-    if [ ! -h /tools ]; then
-       exiterror "Could not create /tools symbolic link."
-    fi
-
-    # Setup environment
-    set +h
-    LC_ALL=POSIX
-    export LFS LC_ALL CFLAGS CXXFLAGS
-    unset CC CXX CPP LD_LIBRARY_PATH LD_PRELOAD
-
-    # Make some extra directories
-    mkdir -p $BASEDIR/build/{tools,etc,usr/src} 2>/dev/null
-    mkdir -p $BASEDIR/{cache,ccache} 2>/dev/null
-    mkdir -p $BASEDIR/build/dev/pts $BASEDIR/build/proc $BASEDIR/build/usr/src/{cache,config,doc,html,langs,lfs,log,src,ccache}
-
-    # Make all sources and proc available under lfs build
-    mount --bind /dev/pts        $BASEDIR/build/dev/pts
-    mount --bind /proc           $BASEDIR/build/proc
-    mount --bind $BASEDIR/cache  $BASEDIR/build/usr/src/cache
-    mount --bind $BASEDIR/ccache $BASEDIR/build/usr/src/ccache
-    mount --bind $BASEDIR/config $BASEDIR/build/usr/src/config
-    mount --bind $BASEDIR/doc    $BASEDIR/build/usr/src/doc
-    mount --bind $BASEDIR/html   $BASEDIR/build/usr/src/html
-    mount --bind $BASEDIR/langs  $BASEDIR/build/usr/src/langs
-    mount --bind $BASEDIR/lfs    $BASEDIR/build/usr/src/lfs
-    mount --bind $BASEDIR/log    $BASEDIR/build/usr/src/log
-    mount --bind $BASEDIR/src    $BASEDIR/build/usr/src/src
-
-    # Run LFS static binary creation scripts one by one
-    export CCACHE_DIR=$BASEDIR/ccache
-    export CCACHE_HASHDIR=1
-
-    # Remove pre-install list of installed files in case user erase some files before rebuild
-    rm -f $BASEDIR/build/usr/src/lsalr 2>/dev/null
-}
-
-
-############################################################################
-#                                                                          #
-# Necessary shell functions                                                #
-#                                                                          #
-############################################################################
-lfsmake1() {
-       if [ -f $BASEDIR/lfs/$1 ]; then
-               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Download error in $1"
-               fi
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "md5sum error in $1, check file in cache or signature"
-               fi
-               cd $BASEDIR/lfs && make -f $*   BUILDTARGET=$BUILDTARGET \
-                                               MACHINE=$MACHINE \
-                                               LFS_BASEDIR=$BASEDIR \
-                                               ROOT=$LFS \
-                                               KVER=$KVER \
-                                               install >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Building $*";
-               fi
-       else
-               exiterror "No such file or directory: $BASEDIR/$1"
-       fi
-       return 0
-}
-
-lfsmake2() {
-       if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
-               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Download error in $1"
-               fi
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "md5sum error in $1, check file in cache or signature"
-               fi
-               chroot $LFS /tools/bin/env -i   HOME=/root \
-                                               TERM=$TERM PS1='\u:\w\$ ' \
-                                               PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \
-                                               VERSION=$VERSION \
-                                               CONFIG_ROOT=$CONFIG_ROOT \
-                                               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
-                                               CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
-                                               CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
-                                               KVER=$KVER \
-                                               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
-                   /tools/bin/bash -x -c "cd /usr/src/lfs && \
-                   make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Building $*"
-               fi
-       else
-               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
-       fi
-       return 0
-}
-
-ipcopmake() {
-       if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
-               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Download error in $1"
-               fi
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "md5sum error in $1, check file in cache or signature"
-               fi
-               chroot $LFS /tools/bin/env -i   HOME=/root \
-                                               TERM=$TERM PS1='\u:\w\$ ' \
-                                               PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin \
-                                               VERSION=$VERSION \
-                                               CONFIG_ROOT=$CONFIG_ROOT \
-                                               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
-                                               CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \
-                                               CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
-                                               KVER=$KVER \
-                                               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
-                   /bin/bash -x -c "cd /usr/src/lfs && \
-                   make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Building $*"
-               fi
-       else
-               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
-       fi
-       return 0
-}
-
-
-installmake() {
-       if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then
-               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Download error in $1"
-               fi
-               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "md5sum error in $1, check file in cache or signature"
-               fi
-               chroot $LFS /tools/bin/env -i   HOME=/root \
-                                               TERM=$TERM PS1='\u:\w\$ ' \
-                                               PATH=/usr/local/bin:/opt/$MACHINE-uClibc/usr/bin:/bin:/usr/bin:/sbin:/usr/sbin \
-                                               VERSION=$VERSION \
-                                               CONFIG_ROOT=$CONFIG_ROOT \
-                                               LFS_PASS="install" \
-                                               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \
-                                               CFLAGS="-Os" CXXFLAGS="-Os" \
-                                               CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \
-                                               KVER=$KVER \
-                                               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \
-                   /bin/bash -x -c "cd /usr/src/lfs && \
-                   make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1
-               if [ $? -ne 0 ]; then
-                       exiterror "Building $*"
-               fi
-       else
-               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"
-       fi
-       return 0
-}
-
-buildtoolchain() {
-    LOGFILE="$BASEDIR/log/_build.toolchain.log"
-    export LOGFILE
-    echo -ne "`date -u '+%b %e %T'`: Stage1 toolchain build \n" | tee -a $LOGFILE
-    # Build sed now, as we use some extensions
-    ORG_PATH=$PATH
-    NATIVEGCC=`gcc --version | grep GCC | awk {'print $3'}`
-    export NATIVEGCC GCCmajor=${NATIVEGCC:0:1} GCCminor=${NATIVEGCC:2:1} GCCrelease=${NATIVEGCC:4:1}
-    lfsmake1 ccache
-    lfsmake1 sed       LFS_PASS=1
-    lfsmake1 m4                LFS_PASS=1
-    lfsmake1 bison     LFS_PASS=1
-    lfsmake1 flex      LFS_PASS=1
-    lfsmake1 binutils   LFS_PASS=1
-    lfsmake1 gcc        LFS_PASS=1
-    export PATH=$BASEDIR/build/usr/local/bin:$BASEDIR/build/tools/bin:$PATH
-    
-    lfsmake1 linux
-    lfsmake1 tcl
-    lfsmake1 expect
-    lfsmake1 glibc
-    lfsmake1 dejagnu
-    lfsmake1 gcc        LFS_PASS=2
-    lfsmake1 binutils   LFS_PASS=2
-    lfsmake1 gawk
-    lfsmake1 coreutils
-    lfsmake1 bzip2
-    lfsmake1 gzip
-    lfsmake1 diffutils
-    lfsmake1 findutils
-    lfsmake1 make
-    lfsmake1 grep
-    lfsmake1 sed       LFS_PASS=2
-    lfsmake1 m4                LFS_PASS=2
-    lfsmake1 bison     LFS_PASS=2
-    lfsmake1 flex      LFS_PASS=2
-    lfsmake1 gettext
-    lfsmake1 ncurses
-    lfsmake1 patch
-    lfsmake1 tar
-    lfsmake1 texinfo
-    lfsmake1 bash
-    lfsmake1 util-linux
-    lfsmake1 perl
-    export PATH=$ORG_PATH
-}
-
-buildbase() {
-    LOGFILE="$BASEDIR/log/_build.base.log"
-    export LOGFILE
-    echo -ne "`date -u '+%b %e %T'`: Stage2 linux base build \n" | tee -a $LOGFILE
-    # Run LFS dynamic binary creation scripts one by one
-    lfsmake2 stage2
-    lfsmake2 makedev
-    lfsmake2 linux
-    lfsmake2 man-pages
-    lfsmake2 glibc
-    lfsmake2 binutils
-    lfsmake2 gcc
-    lfsmake2 coreutils
-    lfsmake2 zlib
-    lfsmake2 mktemp
-    lfsmake2 iana-etc
-    lfsmake2 findutils
-    lfsmake2 gawk
-    lfsmake2 ncurses
-    lfsmake2 vim
-    lfsmake2 m4
-    lfsmake2 bison
-    lfsmake2 less
-    lfsmake2 groff
-    lfsmake2 sed
-    lfsmake2 flex
-    lfsmake2 gettext
-    lfsmake2 net-tools
-    lfsmake2 inetutils
-    lfsmake2 perl
-    lfsmake2 texinfo
-    lfsmake2 autoconf
-    lfsmake2 automake
-    lfsmake2 bash
-    lfsmake2 file
-    lfsmake2 libtool
-    lfsmake2 bzip2
-    lfsmake2 diffutils
-    lfsmake2 ed
-    lfsmake2 kbd
-    lfsmake2 e2fsprogs
-    lfsmake2 grep
-    if [ 'i386' = $MACHINE ]; then 
-       lfsmake2 grub
-    elif [ 'alpha' = $MACHINE ]; then 
-       lfsmake2 aboot
-    fi
-    lfsmake2 gzip
-    lfsmake2 man
-    lfsmake2 make
-    lfsmake2 modutils
-    lfsmake2 patch
-    lfsmake2 procinfo
-    lfsmake2 procps
-    lfsmake2 psmisc
-    lfsmake2 shadow
-    lfsmake2 sysklogd
-    lfsmake2 sysvinit
-    lfsmake2 tar
-    lfsmake2 util-linux
-}
-
-buildipcop() {
-  # Run IPCop make scripts one by one
-  LOGFILE="$BASEDIR/log/_build.ipcop.log"
-  export LOGFILE
-  echo -ne "`date -u '+%b %e %T'`: Stage3 $NAME build \n" | tee -a $LOGFILE
-
-  # Build these first as some of the kernel packages below rely on 
-  # these for some of their client program functionality 
-  ipcopmake configroot
-  ipcopmake dhcp
-  ipcopmake dhcpcd
-  ipcopmake libusb
-  ipcopmake libpcap
-  ipcopmake linux-atm
-  ipcopmake ppp
-  ipcopmake rp-pppoe
-  ipcopmake unzip
-  # Do SMP now
-#  if [ 'i386' = $MACHINE ]; then 
-#      # abuse the SMP flag, and make an minimal installer kernel first
-#      # so that the boot floppy always works.....
-#      ipcopmake linux         LFS_PASS=ipcop SMP=installer
-#      ipcopmake linux         LFS_PASS=ipcop SMP=1
-#      ipcopmake 3cp4218       SMP=1
-#      ipcopmake amedyn        SMP=1
-#      ipcopmake cxacru        SMP=1
-#      ipcopmake eagle         SMP=1
-#
-#      # These are here because they have i386 only binary libraries
-#      # included in the package.
-#      ipcopmake cnx_pci       SMP=1
-#      ipcopmake fcdsl         SMP=1
-#      ipcopmake fcdsl2        SMP=1
-#      ipcopmake fcdslsl       SMP=1
-#      ipcopmake fcdslusb      SMP=1
-#      ipcopmake fcdslslusb    SMP=1
-#      ipcopmake pulsar        SMP=1
-#      ipcopmake unicorn       SMP=1
-#  fi
-
-  ipcopmake linux      LFS_PASS=ipcop
-  ipcopmake 3cp4218    
-  ipcopmake amedyn     
-  ipcopmake cxacru     
-  ipcopmake eciadsl    
-  ipcopmake eagle      
-  ipcopmake speedtouch         
-  if [ 'i386' = $MACHINE ]; then 
-       # These are here because they have i386 only binary libraries
-       # included in the package.
-       ipcopmake cnx_pci       
-       ipcopmake fcdsl         
-       ipcopmake fcdsl2        
-       ipcopmake fcdslsl       
-       ipcopmake fcdslusb      
-       ipcopmake fcdslslusb    
-       ipcopmake pulsar        
-       ipcopmake unicorn       
-  fi
-
-  ipcopmake pcmcia-cs
-  ipcopmake expat
-  ipcopmake gdbm
-  ipcopmake gmp
-  ipcopmake openssl
-  ipcopmake python
-  ipcopmake libnet
-  ipcopmake libpng
-  ipcopmake gd
-  ipcopmake popt
-  ipcopmake slang
-  ipcopmake newt
-  ipcopmake libcap
-  ipcopmake pciutils
-  ipcopmake pcre
-  ipcopmake apache
-  ipcopmake arping
-  ipcopmake beep
-  ipcopmake bind
-  ipcopmake capi4k-utils
-  ipcopmake cdrtools
-  ipcopmake dnsmasq
-  ipcopmake dosfstools
-  ipcopmake ethtool
-  ipcopmake ez-ipupdate
-  ipcopmake fcron
-  ipcopmake perl-GD
-  ipcopmake gnupg
-  ipcopmake hdparm
-  ipcopmake ibod
-  ipcopmake initscripts
-  ipcopmake iptables
-  ipcopmake ipac-ng
-  ipcopmake ipaddr
-  ipcopmake iproute2
-  ipcopmake iptstate
-  ipcopmake iputils
-  ipcopmake isapnptools
-  ipcopmake isdn4k-utils
-  ipcopmake kudzu
-  ipcopmake logrotate
-  ipcopmake logwatch
-  ipcopmake mingetty
-  ipcopmake misc-progs
-  ipcopmake mtools
-  ipcopmake nano
-  ipcopmake nash
-  ipcopmake nasm
-  ipcopmake URI
-  ipcopmake HTML-Tagset
-  ipcopmake HTML-Parser
-  ipcopmake Compress-Zlib
-  ipcopmake Digest
-  ipcopmake Digest-SHA1
-  ipcopmake Digest-HMAC
-  ipcopmake libwww-perl
-  ipcopmake Net-DNS
-  ipcopmake Net-IPv4Addr
-  ipcopmake Net_SSLeay
-  ipcopmake noip_updater
-  ipcopmake ntp
-  ipcopmake oinkmaster
-  ipcopmake openssh
-  ipcopmake openswan
-  ipcopmake pptpclient
-  ipcopmake rrdtool
-  ipcopmake setserial
-  ipcopmake setup
-  ipcopmake snort
-  #ipcopmake speedycgi
-  ipcopmake squid
-  ipcopmake squid-graph
-  ipcopmake tcpdump
-  ipcopmake traceroute
-  ipcopmake vlan
-  ipcopmake wireless
-  ipcopmake libsafe
-  ipcopmake 3c5x9setup
-  ipcopmake stund
-  ipcopmake lpd
-  ipcopmake xampp
-  ipcopmake pam
-}
-
-buildinstaller() {
-  # Run installer scripts one by one
-  LOGFILE="$BASEDIR/log/_build.installer.log"
-  export LOGFILE
-  echo -ne "`date -u '+%b %e %T'`: Stage4 installer build \n" | tee -a $LOGFILE
-  if [ 'i386' = $MACHINE ]; then 
-       ipcopmake syslinux
-       ipcopmake as86
-       ipcopmake mbr
-       ipcopmake uClibc
-  fi
-  installmake busybox
-  installmake sysvinit
-  installmake e2fsprogs
-  installmake misc-progs
-  installmake slang
-  installmake util-linux
-  installmake newt
-  installmake pciutils
-  installmake pcmcia-cs
-  installmake kbd
-  installmake installer
-  installmake scsi.img
-  installmake driver.img
-  installmake initrd
-  installmake boot.img
-}
-
-buildpackages() {
-  LOGFILE="$BASEDIR/log/_build.packages.log"
-  export LOGFILE
-  echo "... see detailed log in _build.*.log files" >> $LOGFILE
-  echo -ne "`date -u '+%b %e %T'`: Stage5 packages build \n" | tee -a $LOGFILE
-  # Strip files
-  echo "`date -u '+%b %e %T'`: Stripping files" | tee -a $LOGFILE
-  find $LFS/lib $LFS/usr/lib $LFS/usr/share/rrdtool-* $LFS/install ! -type l \( -name '*.so' -o -name '*.so[\.0-9]*' \) \
-       ! -name 'libc.so' ! -name 'libpthread.so' ! -name 'libcrypto.so.0.9.7.sha1' \
-       -exec $LFS/tools/bin/strip --strip-all {} \; >> $LOGFILE 2>&1
-  # add -ls before -exec if you want to verify what files are stripped
-
-  find $LFS/{,s}bin $LFS/usr/{,s}bin $LFS/usr/local/{,s}bin ! -type l \
-       -exec file {} \; | grep " ELF " | cut -f1 -d ':' | xargs $LFS/tools/bin/strip --strip-all >> $LOGFILE 2>&1
-  # there add -v to strip to verify
-
-  if [ 'i386' = $MACHINE ]; then
-       # Create fcdsl packages
-       echo "`date -u '+%b %e %T'`: Building fcdsl tgz" | tee -a $LOGFILE
-       cp $LFS/install/images/fcdsl/license.txt $LFS  >> $LOGFILE 2>&1
-       touch $LFS/var/run/{need-depmod-$KVER,need-depmod-$KVER-smp}
-       cd $LFS && tar cvfz $LFS/install/images/$SNAME-fcdsl-$VERSION.$MACHINE.tgz \
-               lib/modules/$KVER/misc/fcdsl*.o.gz \
-               lib/modules/$KVER-smp/misc/fcdsl*.o.gz \
-               usr/lib/isdn/{fds?base.bin,fd?ubase.frm} \
-               etc/fcdsl/fcdsl*.conf \
-               etc/drdsl/{drdsl,drdsl.ini} \
-               license.txt \
-               var/run/{need-depmod-$KVER,need-depmod-$KVER-smp} >> $LOGFILE 2>&1
-       rm -f $LFS/license.txt >> $LOGFILE 2>&1
-       cd $BASEDIR
-  fi
-
-  # Create update for this version
-#  echo "`date -u '+%b %e %T'`: Building update $VERSION tgz" | tee -a $LOGFILE
-#  tar -cz -C $BASEDIR/build --files-from=$BASEDIR/updates/$VERSION/ROOTFILES.$MACHINE-$VERSION -f $BASEDIR/updates/$VERSION/patch.tar.gz --exclude='#*'; 
-#  chmod 755 $BASEDIR/updates/$VERSION/setup
-#  tar -cz -C $BASEDIR/updates/$VERSION -f $LFS/install/images/$SNAME-update-$VERSION.$MACHINE.tgz patch.tar.gz setup information
-#  rm -f $LFS/var/run/{need-depmod-$KVER,need-depmod-$KVER-smp}
-  
-  # Generating list of packages used
-  echo "`date -u '+%b %e %T'`: Generating packages list from logs" | tee -a $LOGFILE
-  rm -f $BASEDIR/doc/packages-list
-  for i in `ls -1tr $BASEDIR/log/[^_]*`; do
-       if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
-               echo "* `basename $i`" >>$BASEDIR/doc/packages-list
-       fi
-  done
-  echo "!!! List of softwares used to build $NAME Version:$VERSION" > $BASEDIR/doc/packages-list.txt
-  grep -v 'configroot$\|img$\|initrd$\|initscripts$\|installer$\|install$\|ipcop$\|setup$\|stage2$\|smp$\|tools$\|tools1$\|tools2$' \
-       $BASEDIR/doc/packages-list | sort >> $BASEDIR/doc/packages-list.txt
-  rm -f $BASEDIR/doc/packages-list
-  # packages-list.txt is ready to be displayed for wiki page IPCopSoftwares
-
-  # Create ISO for CDRom and USB-superfloppy
-  ipcopmake cdrom
-  cp $LFS/install/images/{*.iso,*.tgz} $BASEDIR >> $LOGFILE 2>&1
-
-  # Cleanup
-  stdumount
-  rm -rf $BASEDIR/build/tmp/*
-
-  # Generating total list of files
-  echo "`date -u '+%b %e %T'`: Generating files list from logs" | tee -a $LOGFILE
-  rm -f $BASEDIR/log/FILES
-  for i in `ls -1tr $BASEDIR/log/[^_]*`; do
-       if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then
-               echo "##" >>$BASEDIR/log/FILES
-               echo "## `basename $i`" >>$BASEDIR/log/FILES
-               echo "##" >>$BASEDIR/log/FILES
-               cat $i | sed "s%^\./%#%" | sort >> $BASEDIR/log/FILES
-       fi
-  done
-
-  cd $PWD
-
-}
-
-# See what we're supposed to do
-case "$1" in 
-build)
-       BUILDMACHINE=`uname -m`
-       PACKAGE=`ls -v -r $BASEDIR/cache/$SNAME-1.4.*-toolchain-$BUILDMACHINE.tar.gz 2> /dev/null | head -n 1`
-       #only restore on a clean disk
-       if [ ! -f log/perl-*-tools ]; then
-               if [ ! -n "$PACKAGE" ]; then
-                       echo "`date -u '+%b %e %T'`: Full toolchain compilation" | tee -a $LOGFILE
-                       prepareenv
-                       buildtoolchain
-               else
-                       PACKAGENAME=${PACKAGE%.tar.gz}
-                       echo "`date -u '+%b %e %T'`: Restore from $PACKAGE" | tee -a $LOGFILE
-                       if [ `md5sum $PACKAGE | awk '{print $1}'` == `cat $PACKAGENAME.md5 | awk '{print $1}'` ]; then
-                               tar zxf $PACKAGE
-                               prepareenv
-                       else
-                               exiterror "$PACKAGENAME md5 did not match, check downloaded package"
-                       fi
-               fi
-       else
-               echo "`date -u '+%b %e %T'`: Using installed toolchain" | tee -a $LOGFILE
-               prepareenv
-       fi
-       buildbase
-       buildipcop
-       buildinstaller
-       buildpackages
-       ;;
-shell)
-       # enter a shell inside LFS chroot
-       # may be used to changed kernel settings
-       prepareenv
-       entershell
-       ;;
-changelog)
-       echo "Building doc/Changelog from CVS"
-       # cv2cl script come from http://www.red-bean.com/cvs2cl/
-       if [ ! -s $BASEDIR/doc/CVS/Tag ]; then
-               BRANCHOPTS=""
-       else
-               BRANCH=`cat $BASEDIR/doc/CVS/Tag`
-               BRANCH=${BRANCH:1}
-               BRANCHOPTS="--follow-only $BRANCH"
-       fi
-       
-       $BASEDIR/tools/cvs2cl.pl --gmt --show-dead $BRANCHOPTS -f $BASEDIR/doc/ChangeLog
-       rm -f $BASEDIR/doc/ChangeLog.bak
-       echo
-       echo "Commit the change now to update CVS"
-       ;;
-check)
-       echo "Checking sources files availability on the web"
-       if [ ! -d $DIR_CHK ]; then
-               mkdir -p $DIR_CHK
-       fi
-       FINISHED=0
-       cd $BASEDIR/lfs
-       for c in `seq $MAX_RETRIES`; do
-               if (( FINISHED==1 )); then
-                       break
-               fi
-               FINISHED=1
-               cd $BASEDIR/lfs
-               for i in *; do
-                       if [ -f "$i" -a "$i" != "Config" ]; then
-                               make -s -f $i MACHINE=$MACHINE LFS_BASEDIR=$BASEDIR ROOT=$BASEDIR/build \
-                                       MESSAGE="$i\t ($c/$MAX_RETRIES)" check
-                               if [ $? -ne 0 ]; then
-                                       echo "Check : wget error in lfs/$i"
-                                       FINISHED=0
-                               fi
-                       fi
-               done
-       done
-       cd -
-       ;;
-checkclean)
-       echo "Erasing sources files availability tags"
-       rm -rf $DIR_CHK/*
-       ;;
-clean)
-       for i in `mount | grep $BASEDIR | sed 's/^.*loop=\(.*\))/\1/'`; do
-               $LOSETUP -d $i 2>/dev/null
-       done
-       for i in `mount | grep $BASEDIR | cut -d " " -f 1`; do
-               umount $i
-       done
-       stdumount
-       for i in `seq 0 7`; do
-           if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then
-               umount /dev/loop${i}     2>/dev/null;
-               losetup -d /dev/loop${i} 2>/dev/null;
-           fi;
-       done
-       rm -rf $BASEDIR/build
-       rm -rf $BASEDIR/cdrom
-       rm -rf $BASEDIR/log
-       rm -f $BASEDIR/updates/$VERSION/patch.tar.gz;
-       if [ -h /tools ]; then
-               rm -f /tools
-       fi
-       ;;
-dist)
-       echo "Building source package from CVS, list of changed files, MD5 of release files"
-       if [ ! -s $BASEDIR/doc/CVS/Tag ]; then
-               BRANCH=""
-               BRANCHOPTS="-D `date +'%Y-%m-%d'`"
-       else
-               BRANCH=`cat $BASEDIR/doc/CVS/Tag`
-               BRANCH=${BRANCH:1}
-               BRANCHOPTS="-r $BRANCH"
-       fi
-
-       rm -rf $BASEDIR/build/tmp/$SNAME-$VERSION $BASEDIR/doc/release.txt
-       cd $BASEDIR/build/tmp
-       # build sources tgz
-       echo "Export tree $BRANCH $SNAME-$VERSION"
-       cvs -z3 -d `cat $BASEDIR/CVS/Root` export $BRANCHOPTS ipcop
-       if [ $? -eq 0 ]; then
-               mv ipcop $SNAME-$VERSION
-               tar cfz $BASEDIR/$SNAME-sources-$VERSION.tgz $SNAME-$VERSION
-               cd $BASEDIR
-
-               if [ ! -d $BASEDIR/build/tmp/$PREVIOUSTAG ]; then
-                       # export previous version to be compared with actual, this help to check wich files need to go in update
-                       cd $BASEDIR/build/tmp
-                       echo "Export tree $PREVIOUSTAG"
-                       cvs -z3 -d `cat $BASEDIR/CVS/Root` export -r $PREVIOUSTAG ipcop
-                       mv ipcop $PREVIOUSTAG
-               fi
-               if [ -d $BASEDIR/build/tmp/$PREVIOUSTAG -o -d $BASEDIR/build/tmp/$SNAME-$VERSION ]; then
-                       cd $BASEDIR/build/tmp
-                       echo "diff $PREVIOUSTAG <> $BRANCH $SNAME-$VERSION >doc/updated-sources.txt"
-                       diff -rq $PREVIOUSTAG $SNAME-$VERSION > $BASEDIR/doc/updated-sources.txt
-                       mv $BASEDIR/doc/updated-sources.txt $BASEDIR/doc/updated-sources.bak
-                       sed -e "s+Files $PREVIOUSTAG\/++" \
-                               -e "s+ and .*$++" \
-                               -e "s+src/rc.d+etc/rc.d+" \
-                               -e "s+^langs/+var/ipcop/langs/+" \
-                               -e "s+html/cgi-bin+home/httpd/cgi-bin+" $BASEDIR/doc/updated-sources.bak \
-                               > $BASEDIR/doc/updated-sources.txt
-                       rm -f $BASEDIR/doc/updated-sources.bak
-               fi
-       fi
-       ;;
-newupdate)
-       # create structure for $VERSION update
-       if [ ! -f "updates/$VERSION" ]; then
-               mkdir -p updates/$VERSION
-               cd updates/$VERSION
-               touch information
-               echo 'etc/issue' > ROOTFILES.alpha-$VERSION
-               echo 'etc/issue' > ROOTFILES.i386-$VERSION
-               echo 'patch.tar.gz' > .cvsignore
-               sed -e "s+^UPGRADEVERSION.*$+UPGRADEVERSION=$VERSION+" $BASEDIR/src/scripts/updatesetup > setup
-               chmod 755 setup
-               cd ..
-               echo "Adding directory $VERSION to cvs"
-               cvs add $VERSION
-               echo "Adding files to cvs"
-               cvs add $VERSION/ROOTFILES.alpha-$VERSION \
-                       $VERSION/ROOTFILES.i386-$VERSION \
-                       $VERSION/information \
-                       $VERSION/setup \
-                       $VERSION/.cvsignore
-       else
-               echo "update/$VERSION already exist"
-       fi
-       cd -
-       exit 0
-       ;;
-prefetch)
-       if [ ! -d $BASEDIR/cache ]; then
-               mkdir $BASEDIR/cache
-       fi
-       mkdir -p $BASEDIR/log
-       echo "`date -u '+%b %e %T'`:Preload all source files" | tee -a $LOGFILE
-       FINISHED=0
-       cd $BASEDIR/lfs
-       for c in `seq $MAX_RETRIES`; do
-               if (( FINISHED==1 )); then 
-                       break
-               fi
-               FINISHED=1
-               cd $BASEDIR/lfs
-               for i in *; do
-                       if [ -f "$i" -a "$i" != "Config" ]; then
-                               make -s -f $i LFS_BASEDIR=$BASEDIR MESSAGE="$i\t ($c/$MAX_RETRIES)" download >> $LOGFILE 2>&1
-                               if [ $? -ne 0 ]; then
-                                       echo "Prefetch : wget error in lfs/$i"
-                                       FINISHED=0
-                               else
-                                       if [ $c -eq 1 ]; then
-                                               echo "Prefetch : lfs/$i files loaded"
-                                       fi
-                               fi
-                       fi
-               done
-       done
-       echo "Prefetch : verifying md5sum"
-       ERROR=0
-       for i in *; do
-               if [ -f "$i" -a "$i" != "Config" ]; then
-                       make -s -f $i LFS_BASEDIR=$BASEDIR MESSAGE="$i\t " md5 >> $LOGFILE 2>&1
-                       if [ $? -ne 0 ]; then
-                               echo "md5 difference in lfs/$i"
-                               ERROR=1
-                       fi
-               fi
-       done
-       if [ $ERROR -eq 0 ]; then
-               echo "Prefetch : all files md5sum match"
-       fi
-       cd -
-       ;;
-rootfiles)
-       PREVIOUSVERSION=`echo $PREVIOUSTAG | sed -e 's/IPCOP_v//' -e 's/_FINAL//' -e 's/_/\./g'`
-       # make md5 list of actual build
-       # some packages include a timestamp (kernel/perl/python/vim and more), so md5 vary at each build
-       # anyway, it is sometime usable after a patch or a minor upgrade to know wich files include in update
-       if [ ! -f "$BASEDIR/build/install/cdrom/$SNAME-$VERSION.tgz" ]; then
-               echo "need cdrom be build to read include files list, use ./make.sh build before."
-       else
-               tar tzf $BASEDIR/build/install/cdrom/$SNAME-$VERSION.tgz > $BASEDIR/updates/$VERSION/FILES.tmp
-               cd $BASEDIR/build
-               rm -f $BASEDIR/updates/$VERSION/FILES-$MACHINE-$VERSION.md5
-               for line in `cat $BASEDIR/updates/$VERSION/FILES.tmp`; do
-                       if [ -f "$line" -a ! -L "$line" ]; then
-                               md5sum "$line" >> $BASEDIR/updates/$VERSION/FILES-$MACHINE-$VERSION.md5
-                       fi
-               done
-               diff $BASEDIR/updates/$PREVIOUSVERSION/FILES-$MACHINE-$PREVIOUSVERSION.md5 \
-                       $BASEDIR/updates/$VERSION/FILES-$MACHINE-$VERSION.md5 \
-                       > $BASEDIR/updates/$VERSION/FILES-$MACHINE.diff
-               awk '$1==">" {print $3}' $BASEDIR/updates/$VERSION/FILES-$MACHINE.diff \
-                       > $BASEDIR/updates/$VERSION/ROOTFILES.add.$MACHINE
-               awk '$1=="<" {print $3}' $BASEDIR/updates/$VERSION/FILES-$MACHINE.diff \
-                       > $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE.tmp
-               rm -f $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE
-               for line in `cat $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE.tmp`; do
-                       # a file is only removed when not in add file
-                       if ( ! grep -q "^$line$" $BASEDIR/updates/$VERSION/ROOTFILES.add.$MACHINE ); then
-                               echo $line >> $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE
-                       fi
-               done
-               rm -f $BASEDIR/updates/$VERSION/{FILES.tmp,FILES-*.diff,ROOTFILES.remove.*.tmp}
-       fi
-       exit 0
-       ;;
-toolchain)
-       prepareenv
-       buildtoolchain
-       BUILDMACHINE=`uname -m`
-       echo "`date -u '+%b %e %T'`: Create toolchain tar.gz for $BUILDMACHINE" | tee -a $LOGFILE
-       cd $BASEDIR && tar -zc --exclude='log/_build.*.log' -f cache/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz \
-               build/{bin,etc,usr/bin,usr/local} \
-               build/tools/{bin,etc,*-linux-gnu,include,lib,libexec,sbin,share,var} \
-               log >> $LOGFILE
-       md5sum cache/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz \
-               > cache/$SNAME-$VERSION-toolchain-$BUILDMACHINE.md5
-       stdumount
-       ;;
-gettoolchain)
-       BUILDMACHINE=`uname -m`
-       # arbitrary name to be updated in case of new toolchain package upload
-       PACKAGE=$SNAME-1.4.11-toolchain-$BUILDMACHINE
-       URL_SFNET=`grep URL_SFNET lfs/Config | awk '{ print $3 }'`
-       echo "`date -u '+%b %e %T'`: Load toolchain tar.gz for $BUILDMACHINE" | tee -a $LOGFILE
-       cd $BASEDIR/cache
-       wget -c $URL_SFNET/ipcop/$PACKAGE.tar.gz $URL_SFNET/ipcop/$PACKAGE.md5
-       if [ $? -ne 0 ]; then
-               echo "`date -u '+%b %e %T'`: error downloading toolchain for $BUILDMACHINE machine" | tee -a $LOGFILE
-       else
-               if [ "`md5sum $PACKAGE.tar.gz | awk '{print $1}'`" = "`cat $PACKAGE.md5 | awk '{print $1}'`" ]; then
-                       echo "`date -u '+%b %e %T'`: toolchain md5 ok" | tee -a $LOGFILE
-               else
-                       exiterror "$PACKAGE.md5 did not match, check downloaded package"
-               fi
-       fi
-       ;;
-*)
-       echo "Usage: $0 {build|changelog|check|checkclean|clean|dist|gettoolchain|newupdate|prefetch|rootfiles|shell|toolchain}"
-       cat doc/make.sh-usage
-       exit 1
-       ;;
-esac
+#!/bin/bash\r
+#\r
+############################################################################\r
+#                                                                          #\r
+# This file is part of the IPCop Firewall.                                 #\r
+#                                                                          #\r
+# IPCop is free software; you can redistribute it and/or modify            #\r
+# it under the terms of the GNU General Public License as published by     #\r
+# the Free Software Foundation; either version 2 of the License, or        #\r
+# (at your option) any later version.                                      #\r
+#                                                                          #\r
+# IPCop is distributed in the hope that it will be useful,                 #\r
+# but WITHOUT ANY WARRANTY; without even the implied warranty of           #\r
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            #\r
+# GNU General Public License for more details.                             #\r
+#                                                                          #\r
+# You should have received a copy of the GNU General Public License        #\r
+# along with IPCop; if not, write to the Free Software                     #\r
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA #\r
+#                                                                          #\r
+# Copyright (C) 2001 Mark Wormgoor <mark@wormgoor.com>.                    #\r
+#                                                                          #\r
+# (c) 2001 Eric S. Johansson <esj@harvee.billerica.ma.us> Check for Bash   #\r
+# (c) 2002 Thorsten Fischer <frosch@cs.tu-berlin.de> MD5Sum checking       #\r
+#                                                                          #\r
+############################################################################\r
+#\r
+# $Id: make.sh,v 1.129.2.145 2006/02/01 07:04:09 gespinasse Exp $\r
+#\r
+\r
+  NAME="IPFire"                                        # Software name\r
+  SNAME="ipfire"                                       # Short name\r
+  VERSION="1.4"                                # Version number\r
+  PREVIOUSTAG=IPCOP_v1_4_10_FINAL\r
+  SLOGAN="We save your network"                # Software slogan\r
+  CONFIG_ROOT=/var/ipfire                      # Configuration rootdir\r
+  NICE=10\r
+  MAX_RETRIES=3                                        # prefetch/check loop\r
+  KVER=`grep --max-count=1 VER lfs/linux | awk '{ print $3 }'`\r
+  MACHINE=`uname -m`\r
+\r
+  # Debian specific settings\r
+  if [ ! -e /etc/debian_version ]; then\r
+       FULLPATH=`which $0`\r
+  else\r
+       if [ -x /usr/bin/realpath ]; then\r
+               FULLPATH=`/usr/bin/realpath $0`\r
+       else\r
+               echo "ERROR: Need to do apt-get install realpath"\r
+               exit 1\r
+       fi\r
+  fi\r
+\r
+\r
+  PWD=`pwd`\r
+  BASENAME=`basename $0`\r
+  BASEDIR=`echo $FULLPATH | sed "s/\/$BASENAME//g"`\r
+  LOGFILE=$BASEDIR/log/_build.preparation.log\r
+  export BASEDIR LOGFILE\r
+  DIR_CHK=$BASEDIR/cache/check\r
+  mkdir $BASEDIR/log/ 2>/dev/null\r
+\r
+  if [ 'x86_64' = $MACHINE -o 'i686' = $MACHINE -o 'i586' = $MACHINE -o 'i486' = $MACHINE -o 'i386' = $MACHINE ]; then\r
+       echo "`date -u '+%b %e %T'`: Machine is ix86 (or equivalent)" | tee -a $LOGFILE\r
+       MACHINE=i386\r
+       BUILDTARGET=i386-pc-linux-gnu\r
+       CFLAGS="-O2 -mcpu=i386 -march=i386 -pipe -fomit-frame-pointer"\r
+       CXXFLAGS="-O2 -mcpu=i386 -march=i386 -pipe -fomit-frame-pointer"\r
+  elif [ 'alpha' = $MACHINE ]; then\r
+       echo "`date -u '+%b %e %T'`: Machine is Alpha AXP" | tee -a $LOGFILE\r
+       BUILDTARGET=alpha-unknown-linux-gnu\r
+       CFLAGS="-O2 -mcpu=ev4 -mieee -pipe"\r
+       CXXFLAGS="-O2 -mcpu=ev4 -mieee -pipe"\r
+  else\r
+       echo "`date -u '+%b %e %T'`: Can't determine your architecture - $MACHINE" | tee -a $LOGFILE\r
+       exit 1\r
+  fi\r
+\r
+# Define immediately\r
+stdumount() {\r
+       umount $BASEDIR/build/dev/pts           2>/dev/null;\r
+       umount $BASEDIR/build/proc              2>/dev/null;\r
+       umount $BASEDIR/build/install/mnt       2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/cache     2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/ccache    2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/config    2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/doc       2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/html      2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/langs     2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/lfs       2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/log       2>/dev/null;\r
+       umount $BASEDIR/build/usr/src/src       2>/dev/null;\r
+}\r
+\r
+exiterror() {\r
+       stdumount\r
+       for i in `seq 0 7`; do\r
+           if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then\r
+               losetup -d /dev/loop${i} 2>/dev/null\r
+           fi;\r
+       done\r
+       echo "ERROR: $*"\r
+       echo "       Check $LOGFILE for errors if applicable"\r
+       exit 1\r
+}\r
+\r
+entershell() {\r
+       if [ ! -e $BASEDIR/build/usr/src/lfs/ ]; then\r
+               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/"\r
+       fi\r
+       echo "Entering to a shell inside LFS chroot, go out with exit"\r
+       chroot $LFS /tools/bin/env -i HOME=/root TERM=$TERM PS1='\u:\w\$ ' \\r
+               PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \\r
+               VERSION=$VERSION CONFIG_ROOT=$CONFIG_ROOT \\r
+               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \\r
+               CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \\r
+               CCACHE_DIR=/usr/src/ccache \\r
+               CCACHE_HASHDIR=1 \\r
+               KVER=$KVER \\r
+               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \\r
+               KGCC="ccache /usr/bin/gcc" \\r
+               /tools/bin/bash\r
+       if [ $? -ne 0 ]; then\r
+                       exiterror "chroot error"\r
+       else\r
+               stdumount\r
+       fi\r
+}\r
+\r
+prepareenv() {\r
+    ############################################################################\r
+    #                                                                          #\r
+    # Are we running the right shell?                                          #\r
+    #                                                                          #\r
+    ############################################################################\r
+    if [ ! "$BASH" ]; then\r
+       exiterror "BASH environment variable is not set.  You're probably running the wrong shell."\r
+    fi\r
+\r
+    if [ -z "${BASH_VERSION}" ]; then\r
+       exiterror "Not running BASH shell."\r
+    fi\r
+\r
+\r
+    ############################################################################\r
+    #                                                                          #\r
+    # Trap on emergency exit                                                   #\r
+    #                                                                          #\r
+    ############################################################################\r
+    trap "exiterror 'Build process interrupted'" SIGINT SIGTERM SIGKILL SIGSTOP SIGQUIT\r
+\r
+\r
+    ############################################################################\r
+    #                                                                          #\r
+    # Resetting our nice level                                                 #\r
+    #                                                                          #\r
+    ############################################################################\r
+    echo "`date -u '+%b %e %T'`: Resetting our nice level to $NICE" | tee -a $LOGFILE\r
+    renice $NICE $$ > /dev/null\r
+    if [ `nice` != "$NICE" ]; then\r
+       exiterror "Failed to set correct nice level"\r
+    fi\r
+\r
+    ############################################################################\r
+    #                                                                          #\r
+    # Checking if running as root user                                         #\r
+    #                                                                          #\r
+    ############################################################################\r
+    echo "`date -u '+%b %e %T'`: Checking if we're running as root user" | tee -a $LOGFILE\r
+    if [ `id -u` != 0 ]; then\r
+       exiterror "Not building as root"\r
+    fi\r
+\r
+\r
+    ############################################################################\r
+    #                                                                          #\r
+    # Checking for necessary temporary space                                   #\r
+    #                                                                          #\r
+    ############################################################################\r
+    echo "`date -u '+%b %e %T'`: Checking for necessary space on disk $BASE_DEV" | tee -a $LOGFILE\r
+    BASE_DEV=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $1 }'`\r
+    BASE_ASPACE=`df -P -k $BASEDIR | tail -n 1 | awk '{ print $4 }'`\r
+    if (( 2202000 > $BASE_ASPACE )); then\r
+       BASE_USPACE=`du -skx $BASEDIR | awk '{print $1}'`\r
+       if (( 2202000 - $BASE_USPACE > $BASE_ASPACE )); then\r
+               exiterror "Not enough temporary space available, need at least 2.1GB on $BASE_DEV"\r
+       fi\r
+    fi\r
+\r
+    ############################################################################\r
+    #                                                                          #\r
+    # Building Linux From Scratch system                                       #\r
+    #                                                                          #\r
+    ############################################################################\r
+    echo "`date -u '+%b %e %T'`: Building Linux From Scratch system" | tee -a $LOGFILE\r
+\r
+    # Set umask\r
+    umask 022\r
+\r
+    # Set LFS Directory\r
+    LFS=$BASEDIR/build\r
+\r
+    # Check /tools symlink\r
+    if [ -h /tools ]; then\r
+        rm -f /tools\r
+    fi\r
+    if [ ! -a /tools ]; then\r
+       ln -s $BASEDIR/build/tools /\r
+    fi\r
+    if [ ! -h /tools ]; then\r
+       exiterror "Could not create /tools symbolic link."\r
+    fi\r
+\r
+    # Setup environment\r
+    set +h\r
+    LC_ALL=POSIX\r
+    export LFS LC_ALL CFLAGS CXXFLAGS\r
+    unset CC CXX CPP LD_LIBRARY_PATH LD_PRELOAD\r
+\r
+    # Make some extra directories\r
+    mkdir -p $BASEDIR/build/{tools,etc,usr/src} 2>/dev/null\r
+    mkdir -p $BASEDIR/{cache,ccache} 2>/dev/null\r
+    mkdir -p $BASEDIR/build/dev/pts $BASEDIR/build/proc $BASEDIR/build/usr/src/{cache,config,doc,html,langs,lfs,log,src,ccache}\r
+\r
+    # Make all sources and proc available under lfs build\r
+    mount --bind /dev/pts        $BASEDIR/build/dev/pts\r
+    mount --bind /proc           $BASEDIR/build/proc\r
+    mount --bind $BASEDIR/cache  $BASEDIR/build/usr/src/cache\r
+    mount --bind $BASEDIR/ccache $BASEDIR/build/usr/src/ccache\r
+    mount --bind $BASEDIR/config $BASEDIR/build/usr/src/config\r
+    mount --bind $BASEDIR/doc    $BASEDIR/build/usr/src/doc\r
+    mount --bind $BASEDIR/html   $BASEDIR/build/usr/src/html\r
+    mount --bind $BASEDIR/langs  $BASEDIR/build/usr/src/langs\r
+    mount --bind $BASEDIR/lfs    $BASEDIR/build/usr/src/lfs\r
+    mount --bind $BASEDIR/log    $BASEDIR/build/usr/src/log\r
+    mount --bind $BASEDIR/src    $BASEDIR/build/usr/src/src\r
+\r
+    # Run LFS static binary creation scripts one by one\r
+    export CCACHE_DIR=$BASEDIR/ccache\r
+    export CCACHE_HASHDIR=1\r
+\r
+    # Remove pre-install list of installed files in case user erase some files before rebuild\r
+    rm -f $BASEDIR/build/usr/src/lsalr 2>/dev/null\r
+}\r
+\r
+\r
+############################################################################\r
+#                                                                          #\r
+# Necessary shell functions                                                #\r
+#                                                                          #\r
+############################################################################\r
+lfsmake1() {\r
+       if [ -f $BASEDIR/lfs/$1 ]; then\r
+               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Download error in $1"\r
+               fi\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "md5sum error in $1, check file in cache or signature"\r
+               fi\r
+               cd $BASEDIR/lfs && make -f $*   BUILDTARGET=$BUILDTARGET \\r
+                                               MACHINE=$MACHINE \\r
+                                               LFS_BASEDIR=$BASEDIR \\r
+                                               ROOT=$LFS \\r
+                                               KVER=$KVER \\r
+                                               install >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Building $*";\r
+               fi\r
+       else\r
+               exiterror "No such file or directory: $BASEDIR/$1"\r
+       fi\r
+       return 0\r
+}\r
+\r
+lfsmake2() {\r
+       if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then\r
+               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Download error in $1"\r
+               fi\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "md5sum error in $1, check file in cache or signature"\r
+               fi\r
+               chroot $LFS /tools/bin/env -i   HOME=/root \\r
+                                               TERM=$TERM PS1='\u:\w\$ ' \\r
+                                               PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin \\r
+                                               VERSION=$VERSION \\r
+                                               CONFIG_ROOT=$CONFIG_ROOT \\r
+                                               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \\r
+                                               CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \\r
+                                               CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \\r
+                                               KVER=$KVER \\r
+                                               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \\r
+                   /tools/bin/bash -x -c "cd /usr/src/lfs && \\r
+                   make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Building $*"\r
+               fi\r
+       else\r
+               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"\r
+       fi\r
+       return 0\r
+}\r
+\r
+ipcopmake() {\r
+       if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then\r
+               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Download error in $1"\r
+               fi\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "md5sum error in $1, check file in cache or signature"\r
+               fi\r
+               chroot $LFS /tools/bin/env -i   HOME=/root \\r
+                                               TERM=$TERM PS1='\u:\w\$ ' \\r
+                                               PATH=/usr/local/bin:/bin:/usr/bin:/sbin:/usr/sbin \\r
+                                               VERSION=$VERSION \\r
+                                               CONFIG_ROOT=$CONFIG_ROOT \\r
+                                               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \\r
+                                               CFLAGS="$CFLAGS" CXXFLAGS="$CXXFLAGS" \\r
+                                               CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \\r
+                                               KVER=$KVER \\r
+                                               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \\r
+                   /bin/bash -x -c "cd /usr/src/lfs && \\r
+                   make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Building $*"\r
+               fi\r
+       else\r
+               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"\r
+       fi\r
+       return 0\r
+}\r
+\r
+\r
+installmake() {\r
+       if [ -f $BASEDIR/build/usr/src/lfs/$1 ]; then\r
+               echo "`date -u '+%b %e %T'`: Building $*" | tee -a $LOGFILE\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t " download  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Download error in $1"\r
+               fi\r
+               cd $BASEDIR/lfs && make -s -f $* LFS_BASEDIR=$BASEDIR MESSAGE="$1\t md5sum" md5  >> $LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "md5sum error in $1, check file in cache or signature"\r
+               fi\r
+               chroot $LFS /tools/bin/env -i   HOME=/root \\r
+                                               TERM=$TERM PS1='\u:\w\$ ' \\r
+                                               PATH=/usr/local/bin:/opt/$MACHINE-uClibc/usr/bin:/bin:/usr/bin:/sbin:/usr/sbin \\r
+                                               VERSION=$VERSION \\r
+                                               CONFIG_ROOT=$CONFIG_ROOT \\r
+                                               LFS_PASS="install" \\r
+                                               NAME="$NAME" SNAME="$SNAME" SLOGAN="$SLOGAN" \\r
+                                               CFLAGS="-Os" CXXFLAGS="-Os" \\r
+                                               CCACHE_DIR=/usr/src/ccache CCACHE_HASHDIR=1 \\r
+                                               KVER=$KVER \\r
+                                               BUILDTARGET="$BUILDTARGET" MACHINE="$MACHINE" \\r
+                   /bin/bash -x -c "cd /usr/src/lfs && \\r
+                   make -f $* LFS_BASEDIR=/usr/src install" >>$LOGFILE 2>&1\r
+               if [ $? -ne 0 ]; then\r
+                       exiterror "Building $*"\r
+               fi\r
+       else\r
+               exiterror "No such file or directory: $BASEDIR/build/usr/src/lfs/$1"\r
+       fi\r
+       return 0\r
+}\r
+\r
+buildtoolchain() {\r
+    LOGFILE="$BASEDIR/log/_build.toolchain.log"\r
+    export LOGFILE\r
+    echo -ne "`date -u '+%b %e %T'`: Stage1 toolchain build \n" | tee -a $LOGFILE\r
+    # Build sed now, as we use some extensions\r
+    ORG_PATH=$PATH\r
+    NATIVEGCC=`gcc --version | grep GCC | awk {'print $3'}`\r
+    export NATIVEGCC GCCmajor=${NATIVEGCC:0:1} GCCminor=${NATIVEGCC:2:1} GCCrelease=${NATIVEGCC:4:1}\r
+    lfsmake1 ccache\r
+    lfsmake1 sed       LFS_PASS=1\r
+    lfsmake1 m4                LFS_PASS=1\r
+    lfsmake1 bison     LFS_PASS=1\r
+    lfsmake1 flex      LFS_PASS=1\r
+    lfsmake1 binutils   LFS_PASS=1\r
+    lfsmake1 gcc        LFS_PASS=1\r
+    export PATH=$BASEDIR/build/usr/local/bin:$BASEDIR/build/tools/bin:$PATH\r
+    \r
+    lfsmake1 linux\r
+    lfsmake1 tcl\r
+    lfsmake1 expect\r
+    lfsmake1 glibc\r
+    lfsmake1 dejagnu\r
+    lfsmake1 gcc        LFS_PASS=2\r
+    lfsmake1 binutils   LFS_PASS=2\r
+    lfsmake1 gawk\r
+    lfsmake1 coreutils\r
+    lfsmake1 bzip2\r
+    lfsmake1 gzip\r
+    lfsmake1 diffutils\r
+    lfsmake1 findutils\r
+    lfsmake1 make\r
+    lfsmake1 grep\r
+    lfsmake1 sed       LFS_PASS=2\r
+    lfsmake1 m4                LFS_PASS=2\r
+    lfsmake1 bison     LFS_PASS=2\r
+    lfsmake1 flex      LFS_PASS=2\r
+    lfsmake1 gettext\r
+    lfsmake1 ncurses\r
+    lfsmake1 patch\r
+    lfsmake1 tar\r
+    lfsmake1 texinfo\r
+    lfsmake1 bash\r
+    lfsmake1 util-linux\r
+    lfsmake1 perl\r
+    export PATH=$ORG_PATH\r
+}\r
+\r
+buildbase() {\r
+    LOGFILE="$BASEDIR/log/_build.base.log"\r
+    export LOGFILE\r
+    echo -ne "`date -u '+%b %e %T'`: Stage2 linux base build \n" | tee -a $LOGFILE\r
+    # Run LFS dynamic binary creation scripts one by one\r
+    lfsmake2 stage2\r
+    lfsmake2 makedev\r
+    lfsmake2 linux\r
+    lfsmake2 man-pages\r
+    lfsmake2 glibc\r
+    lfsmake2 binutils\r
+    lfsmake2 gcc\r
+    lfsmake2 coreutils\r
+    lfsmake2 zlib\r
+    lfsmake2 mktemp\r
+    lfsmake2 iana-etc\r
+    lfsmake2 findutils\r
+    lfsmake2 gawk\r
+    lfsmake2 ncurses\r
+    lfsmake2 vim\r
+    lfsmake2 m4\r
+    lfsmake2 bison\r
+    lfsmake2 less\r
+    lfsmake2 groff\r
+    lfsmake2 sed\r
+    lfsmake2 flex\r
+    lfsmake2 gettext\r
+    lfsmake2 net-tools\r
+    lfsmake2 inetutils\r
+    lfsmake2 perl\r
+    lfsmake2 texinfo\r
+    lfsmake2 autoconf\r
+    lfsmake2 automake\r
+    lfsmake2 bash\r
+    lfsmake2 file\r
+    lfsmake2 libtool\r
+    lfsmake2 bzip2\r
+    lfsmake2 diffutils\r
+    lfsmake2 ed\r
+    lfsmake2 kbd\r
+    lfsmake2 e2fsprogs\r
+    lfsmake2 grep\r
+    if [ 'i386' = $MACHINE ]; then \r
+       lfsmake2 grub\r
+    elif [ 'alpha' = $MACHINE ]; then \r
+       lfsmake2 aboot\r
+    fi\r
+    lfsmake2 gzip\r
+    lfsmake2 man\r
+    lfsmake2 make\r
+    lfsmake2 modutils\r
+    lfsmake2 patch\r
+    lfsmake2 procinfo\r
+    lfsmake2 procps\r
+    lfsmake2 psmisc\r
+    lfsmake2 shadow\r
+    lfsmake2 sysklogd\r
+    lfsmake2 sysvinit\r
+    lfsmake2 tar\r
+    lfsmake2 util-linux\r
+}\r
+\r
+buildipcop() {\r
+  # Run IPCop make scripts one by one\r
+  LOGFILE="$BASEDIR/log/_build.ipcop.log"\r
+  export LOGFILE\r
+  echo -ne "`date -u '+%b %e %T'`: Stage3 $NAME build \n" | tee -a $LOGFILE\r
+\r
+  # Build these first as some of the kernel packages below rely on \r
+  # these for some of their client program functionality \r
+  ipcopmake configroot\r
+  ipcopmake dhcp\r
+  ipcopmake dhcpcd\r
+  ipcopmake libusb\r
+  ipcopmake libpcap\r
+  ipcopmake linux-atm\r
+  ipcopmake ppp\r
+  ipcopmake rp-pppoe\r
+  ipcopmake unzip\r
+  # Do SMP now\r
+  if [ 'i386' = $MACHINE ]; then \r
+       # abuse the SMP flag, and make an minimal installer kernel first\r
+       # so that the boot floppy always works.....\r
+       ipcopmake linux         LFS_PASS=ipcop SMP=installer\r
+       ipcopmake linux         LFS_PASS=ipcop SMP=1\r
+       ipcopmake 3cp4218       SMP=1\r
+       ipcopmake amedyn        SMP=1\r
+       ipcopmake cxacru        SMP=1\r
+       ipcopmake eagle         SMP=1\r
+\r
+       # These are here because they have i386 only binary libraries\r
+       # included in the package.\r
+       ipcopmake cnx_pci       SMP=1\r
+       ipcopmake fcdsl         SMP=1\r
+       ipcopmake fcdsl2        SMP=1\r
+       ipcopmake fcdslsl       SMP=1\r
+       ipcopmake fcdslusb      SMP=1\r
+       ipcopmake fcdslslusb    SMP=1\r
+       ipcopmake pulsar        SMP=1\r
+       ipcopmake unicorn       SMP=1\r
+  fi\r
+\r
+  ipcopmake linux      LFS_PASS=ipcop\r
+  ipcopmake 3cp4218    \r
+  ipcopmake amedyn     \r
+  ipcopmake cxacru     \r
+  ipcopmake eciadsl    \r
+  ipcopmake eagle      \r
+  ipcopmake speedtouch         \r
+  if [ 'i386' = $MACHINE ]; then \r
+       # These are here because they have i386 only binary libraries\r
+       # included in the package.\r
+       ipcopmake cnx_pci       \r
+       ipcopmake fcdsl         \r
+       ipcopmake fcdsl2        \r
+       ipcopmake fcdslsl       \r
+       ipcopmake fcdslusb      \r
+       ipcopmake fcdslslusb    \r
+       ipcopmake pulsar        \r
+       ipcopmake unicorn       \r
+  fi\r
+\r
+  ipcopmake pcmcia-cs\r
+  ipcopmake expat\r
+  ipcopmake gdbm\r
+  ipcopmake gmp\r
+  ipcopmake openssl\r
+  ipcopmake python\r
+  ipcopmake libnet\r
+  ipcopmake libpng\r
+  ipcopmake gd\r
+  ipcopmake popt\r
+  ipcopmake slang\r
+  ipcopmake newt\r
+  ipcopmake libcap\r
+  ipcopmake pciutils\r
+  ipcopmake pcre\r
+  ipcopmake apache\r
+  ipcopmake arping\r
+  ipcopmake beep\r
+  ipcopmake bind\r
+  ipcopmake capi4k-utils\r
+  ipcopmake cdrtools\r
+  ipcopmake dnsmasq\r
+  ipcopmake dosfstools\r
+  ipcopmake ethtool\r
+  ipcopmake ez-ipupdate\r
+  ipcopmake fcron\r
+  ipcopmake perl-GD\r
+  ipcopmake gnupg\r
+  ipcopmake hdparm\r
+  ipcopmake ibod\r
+  ipcopmake initscripts\r
+  ipcopmake iptables\r
+  ipcopmake ipac-ng\r
+  ipcopmake ipaddr\r
+  ipcopmake iproute2\r
+  ipcopmake iptstate\r
+  ipcopmake iputils\r
+  ipcopmake isapnptools\r
+  ipcopmake isdn4k-utils\r
+  ipcopmake kudzu\r
+  ipcopmake logrotate\r
+  ipcopmake logwatch\r
+  ipcopmake mingetty\r
+  ipcopmake misc-progs\r
+  ipcopmake mtools\r
+  ipcopmake nano\r
+  ipcopmake nash\r
+  ipcopmake nasm\r
+  ipcopmake URI\r
+  ipcopmake HTML-Tagset\r
+  ipcopmake HTML-Parser\r
+  ipcopmake Compress-Zlib\r
+  ipcopmake Digest\r
+  ipcopmake Digest-SHA1\r
+  ipcopmake Digest-HMAC\r
+  ipcopmake libwww-perl\r
+  ipcopmake Net-DNS\r
+  ipcopmake Net-IPv4Addr\r
+  ipcopmake Net_SSLeay\r
+  ipcopmake noip_updater\r
+  ipcopmake ntp\r
+  ipcopmake oinkmaster\r
+  ipcopmake openssh\r
+  ipcopmake openswan\r
+  ipcopmake pptpclient\r
+  ipcopmake rrdtool\r
+  ipcopmake setserial\r
+  ipcopmake setup\r
+  ipcopmake snort\r
+  #ipcopmake speedycgi\r
+  ipcopmake squid\r
+  ipcopmake squid-graph\r
+  ipcopmake tcpdump\r
+  ipcopmake traceroute\r
+  ipcopmake vlan\r
+  ipcopmake wireless\r
+  ipcopmake libsafe\r
+  ipcopmake 3c5x9setup\r
+  ipcopmake stund\r
+  ipcopmake lpd\r
+  ipcopmake xampp\r
+  ipcopmake pam\r
+}\r
+\r
+buildinstaller() {\r
+  # Run installer scripts one by one\r
+  LOGFILE="$BASEDIR/log/_build.installer.log"\r
+  export LOGFILE\r
+  echo -ne "`date -u '+%b %e %T'`: Stage4 installer build \n" | tee -a $LOGFILE\r
+  if [ 'i386' = $MACHINE ]; then \r
+       ipcopmake syslinux\r
+       ipcopmake as86\r
+       ipcopmake mbr\r
+       ipcopmake uClibc\r
+  fi\r
+  installmake busybox\r
+  installmake sysvinit\r
+  installmake e2fsprogs\r
+  installmake misc-progs\r
+  installmake slang\r
+  installmake util-linux\r
+  installmake newt\r
+  installmake pciutils\r
+  installmake pcmcia-cs\r
+  installmake kbd\r
+  installmake installer\r
+  installmake scsi.img\r
+  installmake driver.img\r
+  installmake initrd\r
+  installmake boot.img\r
+}\r
+\r
+buildpackages() {\r
+  LOGFILE="$BASEDIR/log/_build.packages.log"\r
+  export LOGFILE\r
+  echo "... see detailed log in _build.*.log files" >> $LOGFILE\r
+  echo -ne "`date -u '+%b %e %T'`: Stage5 packages build \n" | tee -a $LOGFILE\r
+  # Strip files\r
+  echo "`date -u '+%b %e %T'`: Stripping files" | tee -a $LOGFILE\r
+  find $LFS/lib $LFS/usr/lib $LFS/usr/share/rrdtool-* $LFS/install ! -type l \( -name '*.so' -o -name '*.so[\.0-9]*' \) \\r
+       ! -name 'libc.so' ! -name 'libpthread.so' ! -name 'libcrypto.so.0.9.7.sha1' \\r
+       -exec $LFS/tools/bin/strip --strip-all {} \; >> $LOGFILE 2>&1\r
+  # add -ls before -exec if you want to verify what files are stripped\r
+\r
+  find $LFS/{,s}bin $LFS/usr/{,s}bin $LFS/usr/local/{,s}bin ! -type l \\r
+       -exec file {} \; | grep " ELF " | cut -f1 -d ':' | xargs $LFS/tools/bin/strip --strip-all >> $LOGFILE 2>&1\r
+  # there add -v to strip to verify\r
+\r
+  if [ 'i386' = $MACHINE ]; then\r
+       # Create fcdsl packages\r
+       echo "`date -u '+%b %e %T'`: Building fcdsl tgz" | tee -a $LOGFILE\r
+       cp $LFS/install/images/fcdsl/license.txt $LFS  >> $LOGFILE 2>&1\r
+       touch $LFS/var/run/{need-depmod-$KVER,need-depmod-$KVER-smp}\r
+       cd $LFS && tar cvfz $LFS/install/images/$SNAME-fcdsl-$VERSION.$MACHINE.tgz \\r
+               lib/modules/$KVER/misc/fcdsl*.o.gz \\r
+               lib/modules/$KVER-smp/misc/fcdsl*.o.gz \\r
+               usr/lib/isdn/{fds?base.bin,fd?ubase.frm} \\r
+               etc/fcdsl/fcdsl*.conf \\r
+               etc/drdsl/{drdsl,drdsl.ini} \\r
+               license.txt \\r
+               var/run/{need-depmod-$KVER,need-depmod-$KVER-smp} >> $LOGFILE 2>&1\r
+       rm -f $LFS/license.txt >> $LOGFILE 2>&1\r
+       cd $BASEDIR\r
+  fi\r
+\r
+  # Create update for this version\r
+#  echo "`date -u '+%b %e %T'`: Building update $VERSION tgz" | tee -a $LOGFILE\r
+#  tar -cz -C $BASEDIR/build --files-from=$BASEDIR/updates/$VERSION/ROOTFILES.$MACHINE-$VERSION -f $BASEDIR/updates/$VERSION/patch.tar.gz --exclude='#*'; \r
+#  chmod 755 $BASEDIR/updates/$VERSION/setup\r
+#  tar -cz -C $BASEDIR/updates/$VERSION -f $LFS/install/images/$SNAME-update-$VERSION.$MACHINE.tgz patch.tar.gz setup information\r
+#  rm -f $LFS/var/run/{need-depmod-$KVER,need-depmod-$KVER-smp}\r
+  \r
+  # Generating list of packages used\r
+  echo "`date -u '+%b %e %T'`: Generating packages list from logs" | tee -a $LOGFILE\r
+  rm -f $BASEDIR/doc/packages-list\r
+  for i in `ls -1tr $BASEDIR/log/[^_]*`; do\r
+       if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then\r
+               echo "* `basename $i`" >>$BASEDIR/doc/packages-list\r
+       fi\r
+  done\r
+  echo "!!! List of softwares used to build $NAME Version:$VERSION" > $BASEDIR/doc/packages-list.txt\r
+  grep -v 'configroot$\|img$\|initrd$\|initscripts$\|installer$\|install$\|ipcop$\|setup$\|stage2$\|smp$\|tools$\|tools1$\|tools2$' \\r
+       $BASEDIR/doc/packages-list | sort >> $BASEDIR/doc/packages-list.txt\r
+  rm -f $BASEDIR/doc/packages-list\r
+  # packages-list.txt is ready to be displayed for wiki page IPCopSoftwares\r
+\r
+  # Create ISO for CDRom and USB-superfloppy\r
+  ipcopmake cdrom\r
+  cp $LFS/install/images/{*.iso,*.tgz} $BASEDIR >> $LOGFILE 2>&1\r
+\r
+  # Cleanup\r
+  stdumount\r
+  rm -rf $BASEDIR/build/tmp/*\r
+\r
+  # Generating total list of files\r
+  echo "`date -u '+%b %e %T'`: Generating files list from logs" | tee -a $LOGFILE\r
+  rm -f $BASEDIR/log/FILES\r
+  for i in `ls -1tr $BASEDIR/log/[^_]*`; do\r
+       if [ "$i" != "$BASEDIR/log/FILES" -a -n $i ]; then\r
+               echo "##" >>$BASEDIR/log/FILES\r
+               echo "## `basename $i`" >>$BASEDIR/log/FILES\r
+               echo "##" >>$BASEDIR/log/FILES\r
+               cat $i | sed "s%^\./%#%" | sort >> $BASEDIR/log/FILES\r
+       fi\r
+  done\r
+\r
+  cd $PWD\r
+\r
+}\r
+\r
+# See what we're supposed to do\r
+case "$1" in \r
+build)\r
+       BUILDMACHINE=`uname -m`\r
+       PACKAGE=`ls -v -r $BASEDIR/cache/$SNAME-1.4.*-toolchain-$BUILDMACHINE.tar.gz 2> /dev/null | head -n 1`\r
+       #only restore on a clean disk\r
+       if [ ! -f log/perl-*-tools ]; then\r
+               if [ ! -n "$PACKAGE" ]; then\r
+                       echo "`date -u '+%b %e %T'`: Full toolchain compilation" | tee -a $LOGFILE\r
+                       prepareenv\r
+                       buildtoolchain\r
+               else\r
+                       PACKAGENAME=${PACKAGE%.tar.gz}\r
+                       echo "`date -u '+%b %e %T'`: Restore from $PACKAGE" | tee -a $LOGFILE\r
+                       if [ `md5sum $PACKAGE | awk '{print $1}'` == `cat $PACKAGENAME.md5 | awk '{print $1}'` ]; then\r
+                               tar zxf $PACKAGE\r
+                               prepareenv\r
+                       else\r
+                               exiterror "$PACKAGENAME md5 did not match, check downloaded package"\r
+                       fi\r
+               fi\r
+       else\r
+               echo "`date -u '+%b %e %T'`: Using installed toolchain" | tee -a $LOGFILE\r
+               prepareenv\r
+       fi\r
+       buildbase\r
+       buildipcop\r
+       buildinstaller\r
+       buildpackages\r
+       ;;\r
+shell)\r
+       # enter a shell inside LFS chroot\r
+       # may be used to changed kernel settings\r
+       prepareenv\r
+       entershell\r
+       ;;\r
+changelog)\r
+       echo "Building doc/Changelog from CVS"\r
+       # cv2cl script come from http://www.red-bean.com/cvs2cl/\r
+       if [ ! -s $BASEDIR/doc/CVS/Tag ]; then\r
+               BRANCHOPTS=""\r
+       else\r
+               BRANCH=`cat $BASEDIR/doc/CVS/Tag`\r
+               BRANCH=${BRANCH:1}\r
+               BRANCHOPTS="--follow-only $BRANCH"\r
+       fi\r
+       \r
+       $BASEDIR/tools/cvs2cl.pl --gmt --show-dead $BRANCHOPTS -f $BASEDIR/doc/ChangeLog\r
+       rm -f $BASEDIR/doc/ChangeLog.bak\r
+       echo\r
+       echo "Commit the change now to update CVS"\r
+       ;;\r
+check)\r
+       echo "Checking sources files availability on the web"\r
+       if [ ! -d $DIR_CHK ]; then\r
+               mkdir -p $DIR_CHK\r
+       fi\r
+       FINISHED=0\r
+       cd $BASEDIR/lfs\r
+       for c in `seq $MAX_RETRIES`; do\r
+               if (( FINISHED==1 )); then\r
+                       break\r
+               fi\r
+               FINISHED=1\r
+               cd $BASEDIR/lfs\r
+               for i in *; do\r
+                       if [ -f "$i" -a "$i" != "Config" ]; then\r
+                               make -s -f $i MACHINE=$MACHINE LFS_BASEDIR=$BASEDIR ROOT=$BASEDIR/build \\r
+                                       MESSAGE="$i\t ($c/$MAX_RETRIES)" check\r
+                               if [ $? -ne 0 ]; then\r
+                                       echo "Check : wget error in lfs/$i"\r
+                                       FINISHED=0\r
+                               fi\r
+                       fi\r
+               done\r
+       done\r
+       cd -\r
+       ;;\r
+checkclean)\r
+       echo "Erasing sources files availability tags"\r
+       rm -rf $DIR_CHK/*\r
+       ;;\r
+clean)\r
+       for i in `mount | grep $BASEDIR | sed 's/^.*loop=\(.*\))/\1/'`; do\r
+               $LOSETUP -d $i 2>/dev/null\r
+       done\r
+       for i in `mount | grep $BASEDIR | cut -d " " -f 1`; do\r
+               umount $i\r
+       done\r
+       stdumount\r
+       for i in `seq 0 7`; do\r
+           if ( losetup /dev/loop${i} 2>/dev/null | grep -q "/install/images" ); then\r
+               umount /dev/loop${i}     2>/dev/null;\r
+               losetup -d /dev/loop${i} 2>/dev/null;\r
+           fi;\r
+       done\r
+       rm -rf $BASEDIR/build\r
+       rm -rf $BASEDIR/cdrom\r
+       rm -rf $BASEDIR/log\r
+       rm -f $BASEDIR/updates/$VERSION/patch.tar.gz;\r
+       if [ -h /tools ]; then\r
+               rm -f /tools\r
+       fi\r
+       ;;\r
+dist)\r
+       echo "Building source package from CVS, list of changed files, MD5 of release files"\r
+       if [ ! -s $BASEDIR/doc/CVS/Tag ]; then\r
+               BRANCH=""\r
+               BRANCHOPTS="-D `date +'%Y-%m-%d'`"\r
+       else\r
+               BRANCH=`cat $BASEDIR/doc/CVS/Tag`\r
+               BRANCH=${BRANCH:1}\r
+               BRANCHOPTS="-r $BRANCH"\r
+       fi\r
+\r
+       rm -rf $BASEDIR/build/tmp/$SNAME-$VERSION $BASEDIR/doc/release.txt\r
+       cd $BASEDIR/build/tmp\r
+       # build sources tgz\r
+       echo "Export tree $BRANCH $SNAME-$VERSION"\r
+       cvs -z3 -d `cat $BASEDIR/CVS/Root` export $BRANCHOPTS ipcop\r
+       if [ $? -eq 0 ]; then\r
+               mv ipcop $SNAME-$VERSION\r
+               tar cfz $BASEDIR/$SNAME-sources-$VERSION.tgz $SNAME-$VERSION\r
+               cd $BASEDIR\r
+\r
+               if [ ! -d $BASEDIR/build/tmp/$PREVIOUSTAG ]; then\r
+                       # export previous version to be compared with actual, this help to check wich files need to go in update\r
+                       cd $BASEDIR/build/tmp\r
+                       echo "Export tree $PREVIOUSTAG"\r
+                       cvs -z3 -d `cat $BASEDIR/CVS/Root` export -r $PREVIOUSTAG ipcop\r
+                       mv ipcop $PREVIOUSTAG\r
+               fi\r
+               if [ -d $BASEDIR/build/tmp/$PREVIOUSTAG -o -d $BASEDIR/build/tmp/$SNAME-$VERSION ]; then\r
+                       cd $BASEDIR/build/tmp\r
+                       echo "diff $PREVIOUSTAG <> $BRANCH $SNAME-$VERSION >doc/updated-sources.txt"\r
+                       diff -rq $PREVIOUSTAG $SNAME-$VERSION > $BASEDIR/doc/updated-sources.txt\r
+                       mv $BASEDIR/doc/updated-sources.txt $BASEDIR/doc/updated-sources.bak\r
+                       sed -e "s+Files $PREVIOUSTAG\/++" \\r
+                               -e "s+ and .*$++" \\r
+                               -e "s+src/rc.d+etc/rc.d+" \\r
+                               -e "s+^langs/+var/ipcop/langs/+" \\r
+                               -e "s+html/cgi-bin+home/httpd/cgi-bin+" $BASEDIR/doc/updated-sources.bak \\r
+                               > $BASEDIR/doc/updated-sources.txt\r
+                       rm -f $BASEDIR/doc/updated-sources.bak\r
+               fi\r
+       fi\r
+       ;;\r
+newupdate)\r
+       # create structure for $VERSION update\r
+       if [ ! -f "updates/$VERSION" ]; then\r
+               mkdir -p updates/$VERSION\r
+               cd updates/$VERSION\r
+               touch information\r
+               echo 'etc/issue' > ROOTFILES.alpha-$VERSION\r
+               echo 'etc/issue' > ROOTFILES.i386-$VERSION\r
+               echo 'patch.tar.gz' > .cvsignore\r
+               sed -e "s+^UPGRADEVERSION.*$+UPGRADEVERSION=$VERSION+" $BASEDIR/src/scripts/updatesetup > setup\r
+               chmod 755 setup\r
+               cd ..\r
+               echo "Adding directory $VERSION to cvs"\r
+               cvs add $VERSION\r
+               echo "Adding files to cvs"\r
+               cvs add $VERSION/ROOTFILES.alpha-$VERSION \\r
+                       $VERSION/ROOTFILES.i386-$VERSION \\r
+                       $VERSION/information \\r
+                       $VERSION/setup \\r
+                       $VERSION/.cvsignore\r
+       else\r
+               echo "update/$VERSION already exist"\r
+       fi\r
+       cd -\r
+       exit 0\r
+       ;;\r
+prefetch)\r
+       if [ ! -d $BASEDIR/cache ]; then\r
+               mkdir $BASEDIR/cache\r
+       fi\r
+       mkdir -p $BASEDIR/log\r
+       echo "`date -u '+%b %e %T'`:Preload all source files" | tee -a $LOGFILE\r
+       FINISHED=0\r
+       cd $BASEDIR/lfs\r
+       for c in `seq $MAX_RETRIES`; do\r
+               if (( FINISHED==1 )); then \r
+                       break\r
+               fi\r
+               FINISHED=1\r
+               cd $BASEDIR/lfs\r
+               for i in *; do\r
+                       if [ -f "$i" -a "$i" != "Config" ]; then\r
+                               make -s -f $i LFS_BASEDIR=$BASEDIR MESSAGE="$i\t ($c/$MAX_RETRIES)" download >> $LOGFILE 2>&1\r
+                               if [ $? -ne 0 ]; then\r
+                                       echo "Prefetch : wget error in lfs/$i"\r
+                                       FINISHED=0\r
+                               else\r
+                                       if [ $c -eq 1 ]; then\r
+                                               echo "Prefetch : lfs/$i files loaded"\r
+                                       fi\r
+                               fi\r
+                       fi\r
+               done\r
+       done\r
+       echo "Prefetch : verifying md5sum"\r
+       ERROR=0\r
+       for i in *; do\r
+               if [ -f "$i" -a "$i" != "Config" ]; then\r
+                       make -s -f $i LFS_BASEDIR=$BASEDIR MESSAGE="$i\t " md5 >> $LOGFILE 2>&1\r
+                       if [ $? -ne 0 ]; then\r
+                               echo "md5 difference in lfs/$i"\r
+                               ERROR=1\r
+                       fi\r
+               fi\r
+       done\r
+       if [ $ERROR -eq 0 ]; then\r
+               echo "Prefetch : all files md5sum match"\r
+       fi\r
+       cd -\r
+       ;;\r
+rootfiles)\r
+       PREVIOUSVERSION=`echo $PREVIOUSTAG | sed -e 's/IPCOP_v//' -e 's/_FINAL//' -e 's/_/\./g'`\r
+       # make md5 list of actual build\r
+       # some packages include a timestamp (kernel/perl/python/vim and more), so md5 vary at each build\r
+       # anyway, it is sometime usable after a patch or a minor upgrade to know wich files include in update\r
+       if [ ! -f "$BASEDIR/build/install/cdrom/$SNAME-$VERSION.tgz" ]; then\r
+               echo "need cdrom be build to read include files list, use ./make.sh build before."\r
+       else\r
+               tar tzf $BASEDIR/build/install/cdrom/$SNAME-$VERSION.tgz > $BASEDIR/updates/$VERSION/FILES.tmp\r
+               cd $BASEDIR/build\r
+               rm -f $BASEDIR/updates/$VERSION/FILES-$MACHINE-$VERSION.md5\r
+               for line in `cat $BASEDIR/updates/$VERSION/FILES.tmp`; do\r
+                       if [ -f "$line" -a ! -L "$line" ]; then\r
+                               md5sum "$line" >> $BASEDIR/updates/$VERSION/FILES-$MACHINE-$VERSION.md5\r
+                       fi\r
+               done\r
+               diff $BASEDIR/updates/$PREVIOUSVERSION/FILES-$MACHINE-$PREVIOUSVERSION.md5 \\r
+                       $BASEDIR/updates/$VERSION/FILES-$MACHINE-$VERSION.md5 \\r
+                       > $BASEDIR/updates/$VERSION/FILES-$MACHINE.diff\r
+               awk '$1==">" {print $3}' $BASEDIR/updates/$VERSION/FILES-$MACHINE.diff \\r
+                       > $BASEDIR/updates/$VERSION/ROOTFILES.add.$MACHINE\r
+               awk '$1=="<" {print $3}' $BASEDIR/updates/$VERSION/FILES-$MACHINE.diff \\r
+                       > $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE.tmp\r
+               rm -f $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE\r
+               for line in `cat $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE.tmp`; do\r
+                       # a file is only removed when not in add file\r
+                       if ( ! grep -q "^$line$" $BASEDIR/updates/$VERSION/ROOTFILES.add.$MACHINE ); then\r
+                               echo $line >> $BASEDIR/updates/$VERSION/ROOTFILES.remove.$MACHINE\r
+                       fi\r
+               done\r
+               rm -f $BASEDIR/updates/$VERSION/{FILES.tmp,FILES-*.diff,ROOTFILES.remove.*.tmp}\r
+       fi\r
+       exit 0\r
+       ;;\r
+toolchain)\r
+       prepareenv\r
+       buildtoolchain\r
+       BUILDMACHINE=`uname -m`\r
+       echo "`date -u '+%b %e %T'`: Create toolchain tar.gz for $BUILDMACHINE" | tee -a $LOGFILE\r
+       cd $BASEDIR && tar -zc --exclude='log/_build.*.log' -f cache/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz \\r
+               build/{bin,etc,usr/bin,usr/local} \\r
+               build/tools/{bin,etc,*-linux-gnu,include,lib,libexec,sbin,share,var} \\r
+               log >> $LOGFILE\r
+       md5sum cache/$SNAME-$VERSION-toolchain-$BUILDMACHINE.tar.gz \\r
+               > cache/$SNAME-$VERSION-toolchain-$BUILDMACHINE.md5\r
+       stdumount\r
+       ;;\r
+gettoolchain)\r
+       BUILDMACHINE=`uname -m`\r
+       # arbitrary name to be updated in case of new toolchain package upload\r
+       PACKAGE=$SNAME-1.4.11-toolchain-$BUILDMACHINE\r
+       URL_SFNET=`grep URL_SFNET lfs/Config | awk '{ print $3 }'`\r
+       echo "`date -u '+%b %e %T'`: Load toolchain tar.gz for $BUILDMACHINE" | tee -a $LOGFILE\r
+       cd $BASEDIR/cache\r
+       wget -c $URL_SFNET/ipcop/$PACKAGE.tar.gz $URL_SFNET/ipcop/$PACKAGE.md5\r
+       if [ $? -ne 0 ]; then\r
+               echo "`date -u '+%b %e %T'`: error downloading toolchain for $BUILDMACHINE machine" | tee -a $LOGFILE\r
+       else\r
+               if [ "`md5sum $PACKAGE.tar.gz | awk '{print $1}'`" = "`cat $PACKAGE.md5 | awk '{print $1}'`" ]; then\r
+                       echo "`date -u '+%b %e %T'`: toolchain md5 ok" | tee -a $LOGFILE\r
+               else\r
+                       exiterror "$PACKAGE.md5 did not match, check downloaded package"\r
+               fi\r
+       fi\r
+       ;;\r
+*)\r
+       echo "Usage: $0 {build|changelog|check|checkclean|clean|dist|gettoolchain|newupdate|prefetch|rootfiles|shell|toolchain}"\r
+       cat doc/make.sh-usage\r
+       exit 1\r
+       ;;\r
+esac\r