754460731d73418bb25e3438c58b983a54aaa931
[openwrt/openwrt.git] / target / linux / brcm63xx / image / Makefile
1 #
2 # Copyright (C) 2006-2011 OpenWrt.org
3 #
4 # This is free software, licensed under the GNU General Public License v2.
5 # See /LICENSE for more information.
6 #
7 include $(TOPDIR)/rules.mk
8 include $(INCLUDE_DIR)/image.mk
9
10 LOADADDR = 0x80010000 # RAM start + 16M
11 KERNEL_ENTRY = $(LOADADDR) # Newer kernels add a jmp to the kernel_entry at the start of the binary
12 RAMSIZE = 0x01000000 # 64MB
13
14 DROP_SECTIONS := .reginfo .mdebug .comment .note .pdr .options .MIPS.options
15 OBJCOPY_BIN := $(TARGET_CROSS)objcopy -S -O binary $(addprefix --remove-section=,$(DROP_SECTIONS))
16
17 LOADER_MAKEOPTS= \
18 KDIR=$(KDIR) \
19 LOADADDR=$(LOADADDR) \
20 KERNEL_ENTRY=$(KERNEL_ENTRY) \
21 RAMSIZE=$(RAMSIZE)
22
23 define trxalign/jffs2-128k
24 -a 0x20000
25 endef
26 define trxalign/jffs2-64k
27 -a 0x10000
28 endef
29 define trxalign/squashfs
30 -a 1024
31 endef
32
33 define Image/LimitName16
34 $(shell expr substr "$(1)" 1 16)
35 endef
36
37 define Image/Build/CFE
38 # Generate the tagged image
39 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
40 --output $(BIN_DIR)/openwrt-$(4)-$(1)-cfe.bin \
41 --boardid $(2) --chipid $(3) --entry $(KERNEL_ENTRY) \
42 --load-addr $(LOADADDR) --rsa-signature "$(5)" \
43 --info1 "-$(call Image/LimitName16,$(4))" --info2 $(1) \
44 $(6) $(7) $(8) $(9)
45 endef
46
47 define Image/Build/CFEFIXUP
48 # Generate the tagged image
49 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
50 --output $(BIN_DIR)/openwrt-$(5)-$(1)-cfe.bin \
51 --boardid $(2) --chipid $(4) --entry $(KERNEL_ENTRY) \
52 --load-addr $(LOADADDR) --rsa-signature "$(6)" \
53 --info1 "+$(call Image/LimitName16,$(3))" --info2 $(1) \
54 $(7) $(8) $(9) $(10)
55 endef
56
57 define Image/Build/CFEHW553
58 # Generate the tagged image
59 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
60 --output $(BIN_DIR)/openwrt-$(5)-$(1)-cfe.bin \
61 --boardid $(2) --chipid $(3) --entry $(LOADADDR) \
62 --load-addr $(LOADADDR) --tag-version 7 \
63 --block-size 0x20000 --image-offset $(4)
64 endef
65
66 define Image/Build/CFEHW556
67 # Generate the tagged image
68 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
69 --output $(BIN_DIR)/openwrt-$(2)-$(1)-cfe.bin \
70 --boardid $(2) --chipid $(3) --entry $(LOADADDR) \
71 --load-addr $(LOADADDR) --tag-version 8 --rsa-signature "$(5)" \
72 --image-offset $(4) --info1 "$(6)" --block-size 0x20000
73 endef
74
75 define Image/Build/CFEAGPF
76 # Generate the tagged image
77 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
78 --output $(BIN_DIR)/openwrt-$(5)-$(1)-cfe.bin \
79 --boardid $(2) --chipid $(3) --entry $(LOADADDR) \
80 --load-addr $(LOADADDR) --tag-version 8 \
81 --signature2 IMAGE --block-size 0x20000 \
82 --image-offset $(4) --info1 "-$(call Image/LimitName16,$(5))" --info2 $(1)
83 endef
84
85 define Image/Build/RG100A
86 # Generate the tagged image
87 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
88 --output $(BIN_DIR)/openwrt-$(5)-$(1)-cfe.bin \
89 --boardid $(2) --chipid $(3) --entry $(LOADADDR) \
90 --load-addr $(LOADADDR) --block-size 0x20000 \
91 --image-offset $(4) --info1 "-$(call Image/LimitName16,$(5))" --info2 $(1)
92 endef
93
94 define Image/Build/RedBoot
95 cp $(KDIR)/vmlinux.elf $(BIN_DIR)/openwrt-$(1)-vmlinux.elf
96 gzip -9 -c $(KDIR)/vmlinux > $(KDIR)/vmlinux.bin.gz
97 $(STAGING_DIR_HOST)/bin/lzma e $(KDIR)/vmlinux $(KDIR)/vmlinux.bin.l7
98 dd if=$(KDIR)/vmlinux.bin.l7 of=$(BIN_DIR)/openwrt-$(1)-vmlinux.lzma bs=65536 conv=sync
99 dd if=$(KDIR)/vmlinux.bin.gz of=$(BIN_DIR)/openwrt-$(1)-vmlinux.gz bs=65536 conv=sync
100 endef
101
102 define Image/Build/SPW303V
103 # Generate the tagged image
104 $(STAGING_DIR_HOST)/bin/imagetag -i $(KDIR)/vmlinux.lzma.cfe -f $(KDIR)/root.$(1) \
105 --output $(BIN_DIR)/openwrt-$(4)-$(1)-cfe.bin.tmp \
106 --boardid $(2) --chipid $(3) --entry $(KERNEL_ENTRY) \
107 --load-addr $(LOADADDR) --rsa-signature "$(5)" \
108 --pad 4 $(6) $(7) $(8) $(9)
109 # Fix up header
110 $(STAGING_DIR_HOST)/bin/spw303v -i $(BIN_DIR)/openwrt-$(4)-$(1)-cfe.bin.tmp \
111 -o $(BIN_DIR)/openwrt-$(4)-$(1)-cfe-sysupgrade.bin
112 $(STAGING_DIR_HOST)/bin/xorimage -i $(BIN_DIR)/openwrt-$(4)-$(1)-cfe-sysupgrade.bin \
113 -o $(BIN_DIR)/openwrt-$(4)-$(1)-cfe-factory.bin
114 rm -f $(BIN_DIR)/openwrt-$(4)-$(1)-cfe.bin.tmp
115 endef
116
117 define Image/Build/CFEOLD
118 $(TOPDIR)/scripts/brcmImage.pl -t -p \
119 -b $(2) -c $(3) \
120 -k $(KDIR)/vmlinux.lzma.cfe \
121 -r $(KDIR)/root.$(1) \
122 -o $(BIN_DIR)/openwrt-$(2)-$(1)-cfe.bin
123 endef
124
125 define Image/Build/HCS
126 $(STAGING_DIR_HOST)/bin/hcsmakeimage --magic_byte=$(3) \
127 --rev_maj=$(4) --rev_min=$(5) --input_file=$(6) \
128 --output_file=$(BIN_DIR)/openwrt-$(2)-$(1).bin
129 endef
130
131 define Build/Clean
132 $(MAKE) -C lzma-loader clean
133 endef
134
135 define Image/Prepare
136 # Binary kernel
137 $(OBJCOPY_BIN) $(LINUX_DIR)/vmlinux $(KDIR)/vmlinux.bin
138 # Standard LZMA kernel
139 cat $(KDIR)/vmlinux | $(STAGING_DIR_HOST)/bin/lzma e -si -so -eos -lc1 -lp2 -pb2 > $(KDIR)/vmlinux.lzma
140
141 # CFE is a LZMA nazi! It took me hours to find out the parameters!
142 # Also I think lzma has a bug cause it generates different output depending on
143 # if you use stdin / stdout or not. Use files instead of stdio here, cause
144 # otherwise CFE will complain and not boot the image.
145 $(STAGING_DIR_HOST)/bin/lzma e -d22 -fb64 -a1 $(KDIR)/vmlinux $(KDIR)/vmlinux.lzma.tmp
146
147 # Strip out the length, CFE doesn't like this
148 dd if=$(KDIR)/vmlinux.lzma.tmp of=$(KDIR)/vmlinux.lzma.cfe bs=5 count=1
149 dd if=$(KDIR)/vmlinux.lzma.tmp of=$(KDIR)/vmlinux.lzma.cfe ibs=13 obs=5 skip=1 seek=1 conv=notrunc
150 rm -f $(KDIR)/vmlinux.lzma.tmp
151
152 # Build the LZMA loader
153 rm -f $(KDIR)/loader.gz
154 $(MAKE) -C lzma-loader \
155 BUILD_DIR="$(KDIR)" \
156 TARGET="$(KDIR)" \
157 clean install
158
159 echo -ne "\\x00" >> $(KDIR)/loader.gz
160 rm -f $(KDIR)/fs_mark
161 touch $(KDIR)/fs_mark
162 $(call prepare_generic_squashfs,$(KDIR)/fs_mark)
163 endef
164
165 define Image/Build
166 dd if=$(KDIR)/root.$(1) of=$(BIN_DIR)/$(IMG_PREFIX)-root.$(1) bs=128k conv=sync
167 # Various routers
168 ifeq ($(CONFIG_TARGET_brcm63xx_generic),y)
169 $(call Image/Build/CFE,$(1),96328avng,6328,96328avng-4M-flash-generic,,--pad 2)
170 $(call Image/Build/CFE,$(1),96328avng,6328,96328avng-8M-flash-generic,,--pad 4)
171 $(call Image/Build/CFE,$(1),96328avng,6328,96328avng-16M-flash-generic,,--pad 8)
172 $(call Image/Build/CFE,$(1),96328A-1241N,6328,96328A-1241N-generic,,--pad 8)
173 $(call Image/Build/CFE,$(1),96328A-1441N1,6328,96328A-1441N1-generic,,--pad 8)
174 $(call Image/Build/CFE,$(1),963281TAN,6328,963281TAN-4M-flash-generic,,--pad 2)
175 $(call Image/Build/CFE,$(1),963281TAN,6328,963281TAN-8M-flash-generic,,--pad 4)
176 $(call Image/Build/CFE,$(1),963281TAN,6328,963281TAN-16M-flash-generic,,--pad 8)
177 $(call Image/Build/CFE,$(1),963281T_TEF,6328,963281T_TEF-generic,,--pad 8)
178 $(call Image/Build/CFE,$(1),96345GW2,6345,96345GW2-generic)
179 $(call Image/Build/CFE,$(1),96345GW2,6345,96348GW2-bc221,,--layoutver 5)
180 $(call Image/Build/CFE,$(1),96345GW2,6345,92345GW2-rev,OpenWRT-$(REVISION))
181 $(call Image/Build/CFE,$(1),96348GW,6348,96348GW-generic,,)
182 $(call Image/Build/CFE,$(1),96348R,6348,96348R-generic,,)
183 $(call Image/Build/CFE,$(1),96348GW,6348,96348GW-bc221,,--layoutver 5)
184 $(call Image/Build/CFE,$(1),6338GW,6338,6338GW-generic,,)
185 $(call Image/Build/CFE,$(1),6338W,6338,6338W-generic,,)
186 $(call Image/Build/CFE,$(1),96348GW-11,6348,96348GW-11-generic)
187 $(call Image/Build/CFE,$(1),96348GW-10,6348,96348GW-10-generic)
188 $(call Image/Build/CFE,$(1),96348A-122,6348,96348A-122-generic)
189 $(call Image/Build/CFE,$(1),96358VW,6358,96358VW-generic)
190 $(call Image/Build/CFE,$(1),96358VW2,6358,96358VW2-generic)
191 endif
192 $(call Image/Build/CFE,$(1),96368MVNgr,6368,96368MVNgr-generic)
193 $(call Image/Build/CFE,$(1),96368MVWG,6368,96368MVWG-generic)
194
195 ifeq ($(CONFIG_TARGET_brcm63xx_generic),y)
196 # BT Voyager V210_BTR
197 $(call Image/Build/CFE,$(1),V210_BB,6348,BTV210_BTR,,--layoutver 5)
198 # BT Voyager V210_ROI, V210_WB
199 $(call Image/Build/CFE,$(1),V210,6348,BTV210_ROI_WB,,--layoutver 5)
200 # BT Voyager V2091_BTR
201 $(call Image/Build/CFE,$(1),V2091_BB,6348,BTV2091_BTR,,--layoutver 5)
202 # BT Voyager V2091_ROI, V2091_WB
203 $(call Image/Build/CFE,$(1),V2091,6348,BTV2091_ROI_WB,,--layoutver 5)
204 # BT Voyager V220V, V220V_MGCP_BTR
205 $(call Image/Build/CFE,$(1),RTA1052V,6348,BTV220V_MGCP_BTR,,--layoutver 5)
206 # BT Voyager V2110, V2110_AA, V2110_ROI
207 $(call Image/Build/CFE,$(1),V2110,6348,BTV2110,,--layoutver 5)
208 # BT Voyager V2500V, V2500V_SIP_CLUB, V2500V_AA
209 $(call Image/Build/CFE,$(1),V2500V_BB,6348,BTV2500V,,--layoutver 5)
210 # RTA1025W_16 (numerous routers)
211 $(call Image/Build/CFE,$(1),RTA1025W_16,6348,RTA1025W_16,,--layoutver 5)
212 # RTA1320_16M (numerous routers)
213 $(call Image/Build/CFE,$(1),RTA1320_16M,6338,RTA1320_16M,,--layoutver 5)
214 # Tecom GW6000
215 $(call Image/Build/CFEFIXUP,$(1),96348GW,GW6000,6348,GW6000)
216 # Tecom GW6200
217 $(call Image/Build/CFEFIXUP,$(1),96348GW,GW6200,6348,GW6200,$(shell printf '\x99'))
218 # Neufbox4
219 $(call Image/Build/CFE,$(1),96358VW,6358,NEUFBOX4,OpenWRT-$(REVISION))
220 endif
221
222 # Neufbox6
223 $(call Image/Build/CFE,$(1),NB6-SER-r0,6362,NEUFBOX6,OpenWRT-$(REVISION))
224
225 ifeq ($(CONFIG_TARGET_brcm63xx_generic),y)
226 # Comtrend 6373
227 $(call Image/Build/CFE,$(1),CT6373-1,6358,CT6373)
228 # Comtrend 536, 5621
229 $(call Image/Build/CFEFIXUP,$(1),96348GW-11,CT536_CT5621,6348,CT536_CT5621)
230 # Davolink DV201AMR
231 $(call Image/Build/CFEOLD,$(1),DV201AMR,6348)
232 # USR 9108
233 $(call Image/Build/CFE,$(1),96348GW-A,6348,USR9108)
234 # NetGear DG834GT, DG834PN
235 $(call Image/Build/CFE,$(1),96348GW-10,6348,DG834GT_DG834PN)
236 # Belkin f5d7633
237 $(call Image/Build/CFE,$(1),96348GW-10,6348,F5D7633)
238 # D-Link DSL-2640B, rev B2
239 $(call Image/Build/CFE,$(1),D-4P-W,6348,DSL2640B-B2)
240 # D-Link DSL-2650U
241 $(call Image/Build/CFE,$(1),96358VW2,6358,DSL2650U)
242 # D-Link DSL-2740B/DSL-2741B, rev C2
243 $(call Image/Build/CFEFIXUP,$(1),96358GW,AW4139,6358,DSL274XB-C2)
244 # D-Link DSL-2740B/DSL-2741B, rev C3
245 $(call Image/Build/CFE,$(1),AW4139,6358,DSL274XB-C3)
246 # D-Link DSL-2740B/DSL-2741B, rev F1
247 $(call Image/Build/CFE,$(1),AW4339U,6328,DSL274XB-F1-EU,,--signature2="4.06.01.EUF1" --pad 4)
248 $(call Image/Build/CFE,$(1),AW4339U,6328,DSL274XB-F1-AU,,--signature2="4.06.01.AUF1" --pad 4)
249 # D-Link DVA-G3810BN/TL
250 $(call Image/Build/CFEFIXUP,$(1),96358VW,DVAG3810BN,6358,DVAG3810BN)
251
252 # TP-Link TD-8810A, TD-8810B, TD-8811A, TD-8811B
253 $(call Image/Build/CFE,$(1),8L-2M-8M,6338,TP8810_8811)
254 # TP-Link 8900GB
255 $(call Image/Build/CFE,$(1),96348GW-11,6348,TD8900GB,$(shell printf 'PRID\x89\x10\x00\x02'))
256
257 # Sagem F@ST2404
258 $(call Image/Build/CFE,$(1),F@ST2404,6348,F@ST2404-cfe)
259 $(call Image/Build/CFE,$(1),F@ST2404,6348,F@ST2404,OpenWRT-$(REVISION))
260 # Sagem F@ST2604
261 $(call Image/Build/CFE,$(1),F@ST2604,6348,F@ST2604-cfe)
262 $(call Image/Build/CFE,$(1),F@ST2604,6348,F@ST2604,OpenWRT-$(REVISION))
263 # Inventel Livebox
264 $(call Image/Build/RedBoot,livebox)
265 # Pirelli Alice Gate VoIP 2 Plus Wi-Fi AGPF-S0
266 $(call Image/Build/CFEAGPF,$(1),AGPF-S0,6358,0x20000,AGV2+W-cfe)
267 $(call Image/Build/CFEAGPF,$(1),AGPF-S0,6358,0x20000,AGV2+W)
268 # Pirelli A226G
269 $(call Image/Build/CFEAGPF,$(1),DWV-S0,6358,0x10000,A226G-cfe)
270 $(call Image/Build/CFEAGPF,$(1),DWV-S0,6358,0x10000,A226G)
271
272 # Pirelli A226M
273 $(call Image/Build/CFEAGPF,$(1),DWV-S0,6358,0x20000,A226M-cfe)
274 $(call Image/Build/CFEAGPF,$(1),DWV-S0,6358,0x20000,A226M)
275
276 # RG100A,DB120 etc.
277 $(call Image/Build/RG100A,$(1),96358VW2,6358,0x20000,RG100A_DB120)
278
279 # Telsey CPVA642-type (e.g. CPA-ZNTE60T)
280 $(call Image/Build/CFE,$(1),CPVA642,6358,CPA-ZNTE60T,,--signature "Telsey Tlc",--signature2 "99.99.999",--second-image-flag "0")
281
282 # T-Com Speedport W 500V
283 $(call Image/Build/CFEFIXUP,$(1),96348GW,SPW500V,6348,SPW500V)
284
285 #HW553
286 $(call Image/Build/CFEHW553,$(1),HW553,6358,0x20000,HW553)
287
288 #HW556
289 $(call Image/Build/CFEHW556,$(1),HW556,6358,0x20000,EchoLife_HG556a,OpenWRT-$(REVISION))
290
291 # T-Com Speedport W 303V Typ B
292 $(call Image/Build/SPW303V,$(1),96358-502V,6358,SPW303V)
293
294 # Netgear CVG834G
295 $(call Image/Build/HCS,$(1),cvg834g,a020,0001,0022,$(KDIR)/vmlinux.bin)
296 endif
297 endef
298
299 $(eval $(call BuildImage))