]> git.ipfire.org Git - people/pmueller/ipfire-2.x.git/blame_incremental - lfs/linux
Imported the beginning of the rowie-spezial and possible 2.2 release.
[people/pmueller/ipfire-2.x.git] / lfs / linux
... / ...
CommitLineData
1###############################################################################
2# #
3# IPFire.org - A linux based firewall #
4# Copyright (C) 2007 Michael Tremer & Christian Schmidt #
5# #
6# This program is free software: you can redistribute it and/or modify #
7# it under the terms of the GNU General Public License as published by #
8# the Free Software Foundation, either version 3 of the License, or #
9# (at your option) any later version. #
10# #
11# This program is distributed in the hope that it will be useful, #
12# but WITHOUT ANY WARRANTY; without even the implied warranty of #
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
14# GNU General Public License for more details. #
15# #
16# You should have received a copy of the GNU General Public License #
17# along with this program. If not, see <http://www.gnu.org/licenses/>. #
18# #
19###############################################################################
20
21###############################################################################
22# Definitions
23###############################################################################
24
25include Config
26
27PATCHLEVEL = .21
28VER = 2.6.20.21
29
30THISAPP = linux-$(VER)
31DL_FILE = $(THISAPP).tar.bz2
32DL_FROM = $(URL_IPFIRE)
33DIR_APP = $(DIR_SRC)/$(THISAPP)
34CFLAGS =
35CXXFLAGS =
36
37# Normal build or SMP build.
38#
39ifeq "$(SMP)" "1"
40 TARGET = $(DIR_INFO)/linux-$(VER)-smp
41else
42 TARGET = $(DIR_INFO)/linux-$(VER)
43endif
44
45
46###############################################################################
47# Top-level Rules
48###############################################################################
49objects =$(DL_FILE) \
50 mISDN-1_1_5.tar.gz \
51 squashfs3.3.tgz \
52 iptables-1.3.8.tar.bz2 \
53 patch-o-matic-ng-20061210.tar.bz2 \
54 netfilter-layer7-v2.9.tar.gz \
55 patch-2.6.16-nath323-1.3.bz2 \
56 openswan-2.4.12.tar.gz
57
58$(DL_FILE) = $(URL_IPFIRE)/$(DL_FILE)
59patch-o-matic-ng-20061210.tar.bz2 = $(URL_IPFIRE)/patch-o-matic-ng-20061210.tar.bz2
60iptables-1.3.8.tar.bz2 = $(URL_IPFIRE)/iptables-1.3.8.tar.bz2
61netfilter-layer7-v2.9.tar.gz = $(URL_IPFIRE)/netfilter-layer7-v2.9.tar.gz
62patch-2.6.16-nath323-1.3.bz2 = $(URL_IPFIRE)/patch-2.6.16-nath323-1.3.bz2
63squashfs3.3.tgz = $(URL_IPFIRE)/squashfs3.3.tgz
64mISDN-1_1_5.tar.gz = $(URL_IPFIRE)/mISDN-1_1_5.tar.gz
65openswan-2.4.12.tar.gz = $(URL_IPFIRE)/openswan-2.4.12.tar.gz
66
67$(DL_FILE)_MD5 = fbedc192e654735936cc780da8deeba4
68patch-o-matic-ng-20061210.tar.bz2_MD5 = 76edac76301b45f89e467b41c8cf4393
69iptables-1.3.8.tar.bz2_MD5 = 0a9209f928002e5eee9cdff8fef4d4b3
70netfilter-layer7-v2.9.tar.gz_MD5 = ebf9043a5352ebe6dbd721989ef83dee
71patch-2.6.16-nath323-1.3.bz2_MD5 = f926409ff703a307baf54b57ab75d138
72squashfs3.3.tgz_MD5 = 95c40fca0d886893631b5de14a0af25b
73mISDN-1_1_5.tar.gz_MD5 = 93b1cff7817b82638a0475c2b7b7f1b6
74openswan-2.4.12.tar.gz_MD5 = 0bca0cc205d2d83eff64a7cea825ce7a
75
76install : $(TARGET)
77
78check : $(patsubst %,$(DIR_CHK)/%,$(objects))
79
80download :$(patsubst %,$(DIR_DL)/%,$(objects))
81
82md5 : $(subst %,%_MD5,$(objects))
83
84###############################################################################
85# Downloading, checking, md5sum
86###############################################################################
87
88$(patsubst %,$(DIR_CHK)/%,$(objects)) :
89 @$(CHECK)
90
91$(patsubst %,$(DIR_DL)/%,$(objects)) :
92 @$(LOAD)
93
94$(subst %,%_MD5,$(objects)) :
95 @$(MD5)
96
97###############################################################################
98# Installation Details
99###############################################################################
100
101$(TARGET) : $(patsubst %,$(DIR_DL)/%,$(objects))
102 @$(PREBUILD)
103 @rm -rf $(DIR_APP) $(DIR_SRC)/linux $(DIR_SRC)/xen-* && cd $(DIR_SRC) && tar jxf $(DIR_DL)/$(DL_FILE)
104 ln -s linux-$(VER) /usr/src/linux
105
106 # Openswan 2
107 cd $(DIR_SRC) && rm -rf openswan-*
108 cd $(DIR_SRC) && tar xfz $(DIR_DL)/openswan-2.4.12.tar.gz
109 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/openswan-2.4.12.kernel-2.6-klips.patch
110 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/openswan-2.4.12.kernel-2.6.20.21-natt.patch
111 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/openswan-2.4.12.kernel-2.6.20-cryptoalg.patch
112 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/openswan-2.4.12-missing-files.patch
113 cd $(DIR_SRC)/openswan-* && sed -i -e 's/INC_USRLOCAL=\/usr\/local/INC_USRLOCAL=\/usr/' Makefile.inc
114
115 # Reiser4
116 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/reiser4-for-2.6.20.patch
117
118 # SquashFS
119 cd $(DIR_SRC) && rm -rf squashfs*
120 cd $(DIR_SRC) && tar xfz $(DIR_DL)/squashfs3.3.tgz
121 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/squashfs3.3/kernel-patches/linux-2.6.20/squashfs3.3-patch
122
123 # ip_conntrack permissions from 440 to 444
124 cd $(DIR_APP) && patch -Np0 < $(DIR_SRC)/src/patches/ip_conntrack_standalone-patch-for-ipfire.patch
125
126 # Some VIA patches
127 #cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/padlock-prereq-2.6.16.diff
128 #cd $(DIR_APP) && patch -Np0 < $(DIR_SRC)/src/patches/epia_dma.patch
129
130 # Patch-o-matic
131 cd $(DIR_SRC) && rm -rf iptables-* patch-o-matic*
132 cd $(DIR_SRC) && tar xfj $(DIR_DL)/iptables-1.3.8.tar.bz2
133 cd $(DIR_SRC) && ln -sf iptables-1.3.8 iptables
134 #cd $(DIR_SRC) && tar xfj $(DIR_DL)/patch-o-matic-ng-20061210.tar.bz2
135 #cd $(DIR_SRC)/patch-o-matic-ng* && \
136 # ./runme --batch --kernel-path=$(ROOT)/usr/src/$(THISAPP)/ \
137 # --iptables-path=$(ROOT)/usr/src/iptables/ \
138 # sip-conntrack-nat rtsp-conntrack-nat \
139 # mms-conntrack-nat
140
141 # Layer7-patch
142 cd $(DIR_SRC) && rm -rf $(DIR_SRC)/netfilter-layer7-v2.9
143 cd $(DIR_SRC) && tar xzf $(DIR_DL)/netfilter-layer7-v2.9.tar.gz
144 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/netfilter-layer7-v2.9/kernel-2.6.18-2.6.19-layer7-2.9.patch
145
146 # Linux Intermediate Queueing Device
147ifeq "$(XEN)" ""
148 cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.6.20-imq.diff
149endif
150
151 # mISDN
152 cd $(DIR_SRC) && rm -rf mISDN-*
153 cd $(DIR_SRC) && tar xfz $(DIR_DL)/mISDN-1_1_5.tar.gz
154 cd $(DIR_SRC)/mISDN-1_1_5 && yes 'yes' | ./std2kern -k /usr/src/linux
155
156 cd $(DIR_APP)/drivers/isdn/hardware/mISDN && patch -Np0 < $(DIR_SRC)/src/patches/mISDN-avmfritz.patch
157
158ifeq "$(SMP)" ""
159 # Only do this once on the non-SMP pass
160 cd $(DIR_SRC) && tar czf $(DIR_DL)/iptables-fixed.tar.gz iptables-1.3.8
161endif
162
163 # Cleanup kernel source
164 cd $(DIR_APP) && make mrproper
165
166ifeq "$(SMP)" "1"
167 cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE).smp $(DIR_APP)/.config
168else
169 cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE) $(DIR_APP)/.config
170endif
171
172 cd $(DIR_APP) && make CC="$(KGCC)" oldconfig
173 cd $(DIR_APP) && make CC="$(KGCC)" clean
174
175ifeq "$(SMP)" "1"
176 cd $(DIR_APP) && sed -i -e 's/EXTRAVERSION\ =.*/EXTRAVERSION\ =\ $(PATCHLEVEL)-ipfire-smp/' Makefile
177 cd $(DIR_APP) && make $(MAKETUNING) CC="$(KGCC)" bzImage
178 cd $(DIR_APP) && cp -v arch/i386/boot/bzImage /boot/vmlinuz-$(VER)-ipfire-smp
179 cd $(DIR_APP) && cp -v System.map /boot/System.map-$(VER)-ipfire-smp
180 ln -sf vmlinuz-$(VER)-ipfire-smp /boot/vmlinuz-ipfire-smp
181 cd $(DIR_APP) && make CC="$(KGCC)" $(MAKETUNING) modules
182 cd $(DIR_APP) && make CC="$(KGCC)" $(MAKETUNING) modules_install
183else
184 cd $(DIR_APP) && sed -i -e 's/EXTRAVERSION\ =.*/EXTRAVERSION\ =\ $(PATCHLEVEL)-ipfire/' Makefile
185 cd $(DIR_APP) && make $(MAKETUNING) CC="$(KGCC)" bzImage
186 cd $(DIR_APP) && cp -v arch/i386/boot/bzImage /boot/vmlinuz-$(VER)-ipfire
187 cd $(DIR_APP) && cp -v System.map /boot/System.map-$(VER)-ipfire
188 cd $(DIR_APP) && cp -v .config /boot/config-$(VER)-ipfire
189 ln -sf vmlinuz-$(VER)-ipfire /boot/vmlinuz-ipfire
190 ln -sf System.map-$(VER)-ipfire /boot/System.map-ipfire
191 cd $(DIR_APP) && make CC="$(KGCC)" $(MAKETUNING) modules
192 cd $(DIR_APP) && make CC="$(KGCC)" $(MAKETUNING) modules_install
193endif
194
195ifeq "$(SMP)" ""
196 # Only do this once on the non-SMP pass
197 cd $(DIR_APP) && install -m 755 usr/gen_init_cpio /sbin/
198endif
199
200 @rm -rf $(DIR_SRC)/patch-o-matic* $(DIR_SRC)/iptables* $(DIR_SRC)/squashfs* $(DIR_SRC)/mISDN-* $(DIR_SRC)/netfilter-layer7-*
201 @$(POSTBUILD)