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