]>
Commit | Line | Data |
---|---|---|
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 | ||
25 | include Config | |
26 | ||
27 | PATCHLEVEL = .21 | |
28 | VER = 2.6.20.21 | |
29 | ||
30 | THISAPP = linux-$(VER) | |
31 | DL_FILE = $(THISAPP).tar.bz2 | |
32 | DL_FROM = $(URL_IPFIRE) | |
33 | DIR_APP = $(DIR_SRC)/$(THISAPP) | |
34 | CFLAGS = | |
35 | CXXFLAGS = | |
36 | ||
37 | # Normal build or SMP build. | |
38 | # | |
39 | ifeq "$(SMP)" "1" | |
40 | TARGET = $(DIR_INFO)/linux-$(VER)-smp | |
41 | else | |
42 | TARGET = $(DIR_INFO)/linux-$(VER) | |
43 | endif | |
44 | ||
45 | ||
46 | ############################################################################### | |
47 | # Top-level Rules | |
48 | ############################################################################### | |
49 | objects =$(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) | |
59 | patch-o-matic-ng-20061210.tar.bz2 = $(URL_IPFIRE)/patch-o-matic-ng-20061210.tar.bz2 | |
60 | iptables-1.3.8.tar.bz2 = $(URL_IPFIRE)/iptables-1.3.8.tar.bz2 | |
61 | netfilter-layer7-v2.9.tar.gz = $(URL_IPFIRE)/netfilter-layer7-v2.9.tar.gz | |
62 | patch-2.6.16-nath323-1.3.bz2 = $(URL_IPFIRE)/patch-2.6.16-nath323-1.3.bz2 | |
63 | squashfs3.3.tgz = $(URL_IPFIRE)/squashfs3.3.tgz | |
64 | mISDN-1_1_5.tar.gz = $(URL_IPFIRE)/mISDN-1_1_5.tar.gz | |
65 | openswan-2.4.12.tar.gz = $(URL_IPFIRE)/openswan-2.4.12.tar.gz | |
66 | ||
67 | $(DL_FILE)_MD5 = fbedc192e654735936cc780da8deeba4 | |
68 | patch-o-matic-ng-20061210.tar.bz2_MD5 = 76edac76301b45f89e467b41c8cf4393 | |
69 | iptables-1.3.8.tar.bz2_MD5 = 0a9209f928002e5eee9cdff8fef4d4b3 | |
70 | netfilter-layer7-v2.9.tar.gz_MD5 = ebf9043a5352ebe6dbd721989ef83dee | |
71 | patch-2.6.16-nath323-1.3.bz2_MD5 = f926409ff703a307baf54b57ab75d138 | |
72 | squashfs3.3.tgz_MD5 = 95c40fca0d886893631b5de14a0af25b | |
73 | mISDN-1_1_5.tar.gz_MD5 = 93b1cff7817b82638a0475c2b7b7f1b6 | |
74 | openswan-2.4.12.tar.gz_MD5 = 0bca0cc205d2d83eff64a7cea825ce7a | |
75 | ||
76 | install : $(TARGET) | |
77 | ||
78 | check : $(patsubst %,$(DIR_CHK)/%,$(objects)) | |
79 | ||
80 | download :$(patsubst %,$(DIR_DL)/%,$(objects)) | |
81 | ||
82 | md5 : $(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 | |
147 | ifeq "$(XEN)" "" | |
148 | cd $(DIR_APP) && patch -Np1 < $(DIR_SRC)/src/patches/linux-2.6.20-imq.diff | |
149 | endif | |
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 | ||
158 | ifeq "$(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 | |
161 | endif | |
162 | ||
163 | # Cleanup kernel source | |
164 | cd $(DIR_APP) && make mrproper | |
165 | ||
166 | ifeq "$(SMP)" "1" | |
167 | cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE).smp $(DIR_APP)/.config | |
168 | else | |
169 | cp $(DIR_SRC)/config/kernel/kernel.config.$(MACHINE) $(DIR_APP)/.config | |
170 | endif | |
171 | ||
172 | cd $(DIR_APP) && make CC="$(KGCC)" oldconfig | |
173 | cd $(DIR_APP) && make CC="$(KGCC)" clean | |
174 | ||
175 | ifeq "$(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 | |
183 | else | |
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 | |
193 | endif | |
194 | ||
195 | ifeq "$(SMP)" "" | |
196 | # Only do this once on the non-SMP pass | |
197 | cd $(DIR_APP) && install -m 755 usr/gen_init_cpio /sbin/ | |
198 | endif | |
199 | ||
200 | @rm -rf $(DIR_SRC)/patch-o-matic* $(DIR_SRC)/iptables* $(DIR_SRC)/squashfs* $(DIR_SRC)/mISDN-* $(DIR_SRC)/netfilter-layer7-* | |
201 | @$(POSTBUILD) |