###############################################################################
-# This file is part of the IPCop Firewall. #
# #
-# IPCop is free software; you can redistribute it and/or modify #
+# IPFire.org - A linux based firewall #
+# Copyright (C) 2007 Michael Tremer & Christian Schmidt #
+# #
+# This program is free software: you can redistribute it and/or modify #
# it under the terms of the GNU General Public License as published by #
-# the Free Software Foundation; either version 2 of the License, or #
+# the Free Software Foundation, either version 3 of the License, or #
# (at your option) any later version. #
# #
-# IPCop is distributed in the hope that it will be useful, #
+# This program is distributed in the hope that it will be useful, #
# but WITHOUT ANY WARRANTY; without even the implied warranty of #
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
# GNU General Public License for more details. #
# #
# You should have received a copy of the GNU General Public License #
-# along with IPCop; if not, write to the Free Software #
-# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA #
-# #
-# Makefiles are based on LFSMake, which is #
-# Copyright (C) 2002 Rod Roard <rod@sunsetsystems.com> #
-# #
-# Modifications by: #
-# ??-12-2003 Mark Wormgoor < mark@wormgoor.com> #
-# - Modified Makefile for IPCop build #
-# #
-# $Id: glibc,v 1.17.2.12 2005/02/05 15:38:15 gespinasse Exp $
+# along with this program. If not, see <http://www.gnu.org/licenses/>. #
# #
###############################################################################
include Config
-VER = 2.3.3
+VER = 2.3.6
-THISAPP = glibc-$(VER)-lfs-5.1
+THISAPP = glibc-$(VER)
DL_FILE = $(THISAPP).tar.bz2
-DL_FROM = $(URL_LFS_FTP)
+DL_FROM = $(URL_IPFIRE)
DIR_APP = $(DIR_SRC)/$(THISAPP)
CFLAGS =
CXXFLAGS =
ifeq "$(ROOT)" ""
TARGET = $(DIR_INFO)/$(THISAPP)
EXTRA_CONFIG = --prefix=/usr \
- --disable-profile --enable-add-ons=linuxthreads \
- --libexecdir=/usr/lib --with-headers=/usr/include \
- --without-cvs --disable-nls
+ --disable-profile --enable-add-ons \
+ --enable-kernel=2.6.0 --libexecdir=/usr/lib/glibc
EXTRA_MAKE =
EXTRA_INSTALL =
else
TARGET = $(DIR_INFO)/$(THISAPP)-tools
EXTRA_CONFIG = --prefix=/tools \
- --disable-profile --enable-add-ons=linuxthreads \
- --with-headers=/tools/include \
- --with-binutils=/tools/bin --without-gd \
- --without-cvs --disable-nls
- EXTRA_MAKE =
- EXTRA_INSTALL =
+ --disable-profile --enable-add-ons \
+ --enable-kernel=2.6.0 --with-binutils=/tools/bin \
+ --without-gd --with-headers=/tools/include \
+ --without-selinux
+ EXTRA_MAKE =
+ EXTRA_INSTALL =
endif
###############################################################################
# Top-level Rules
###############################################################################
-objects = $(DL_FILE)
+objects = $(DL_FILE) \
+ glibc-libidn-$(VER).tar.bz2
$(DL_FILE) = $(DL_FROM)/$(DL_FILE)
+glibc-libidn-$(VER).tar.bz2 = $(DL_FROM)/glibc-libidn-$(VER).tar.bz2
-$(DL_FILE)_MD5 = cd11fabdf5162ad68329e7b28b308278
+$(DL_FILE)_MD5 = bfdce99f82d6dbcb64b7f11c05d6bc96
+glibc-libidn-$(VER).tar.bz2_MD5 = 49dbe06ce830fc73874d6b38bdc5b4db
install : $(TARGET)
$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
@$(PREBUILD)
@rm -rf $(DIR_APP) $(DIR_SRC)/glibc-build && cd $(DIR_SRC) && tar jxf $(DIR_DL)/$(DL_FILE)
- cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/glibc-2.3.3-ssp_frandom-2.patch
@mkdir $(DIR_SRC)/glibc-build
+ cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/$(THISAPP)-dont_use_origin_on_privil_exec.patch
+
+ifeq "$(ROOT)" ""
+ cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/$(THISAPP)-linux_types-1.patch
+ cd $(DIR_APP) && patch -Np1 -i $(DIR_SRC)/src/patches/$(THISAPP)-inotify-1.patch
+ # This locale causes a loop on bash login - exclude it
+ cd $(DIR_APP) && sed -i '/vi_VN.TCVN/d' localedata/SUPPORTED
+ cd $(DIR_APP) && sed -i 's|libs -o|libs -L/usr/lib -Wl,-dynamic-linker=/lib/ld-linux.so.2 -o|' \
+ scripts/test-installation.pl
+endif
cd $(DIR_SRC)/glibc-build && $(DIR_APP)/configure $(EXTRA_CONFIG)
+
ifeq "$(ROOT)" ""
touch /etc/ld.so.conf
- cd $(DIR_SRC)/glibc-build && make $(EXTRA_MAKE)
+ cd $(DIR_SRC)/glibc-build && make $(MAKETUNING) $(EXTRA_MAKE)
cd $(DIR_SRC)/glibc-build && make $(EXTRA_INSTALL) install
+ cp -v $(DIR_APP)/sysdeps/unix/sysv/linux/inotify.h /usr/include/sys
else
-mkdir /tools/etc
touch /tools/etc/ld.so.conf
- cd $(DIR_SRC)/glibc-build && make $(EXTRA_MAKE) AUTOCONF=no
- cd $(DIR_SRC)/glibc-build && make $(EXTRA_INSTALL) AUTOCONF=no install
-endif
-
- # Locking in the toolchain
-ifeq "$(ROOT)" ""
- SPECFILE=/tools/lib/gcc-lib/*/*/specs && \
- sed -e 's@/tools/lib/ld-linux.so.2@/lib/ld-linux.so.2@g' \
- $$SPECFILE > newspecfile && mv -f newspecfile $$SPECFILE
-else
- SPECFILE=/tools/lib/gcc-lib/*/*/specs && \
- sed -e 's@/lib/ld-linux.so.2@/tools/lib/ld-linux.so.2@g' \
- $$SPECFILE > tempspecfile && mv -f tempspecfile $$SPECFILE
- rm -f /tools/lib/gcc-lib/*/*/include/{pthread.h,bits/sigthread.h}
+ cd $(DIR_SRC)/glibc-build && make $(MAKETUNING) $(EXTRA_MAKE)
+ cd $(DIR_SRC)/glibc-build && make $(EXTRA_INSTALL) install
endif
# Creating the locales
ifeq "$(ROOT)" ""
mkdir -p /usr/lib/locale
-else
- mkdir -p /tools/lib/locale
-endif
cd $(DIR_SRC)/glibc-build && localedef -i en_US -f ISO-8859-1 en_US
cd $(DIR_SRC)/glibc-build && localedef -i en_US -f UTF-8 en_US.utf8
-
- # Configuring Glibc
-ifeq "$(ROOT)" ""
- cp -f /usr/share/zoneinfo/GMT /etc/localtime
+ cp -f /usr/share/zoneinfo/GMT /etc/localtime
endif
- # Cleanup
@rm -rf $(DIR_APP) $(DIR_SRC)/glibc-build
@$(POSTBUILD)