brcm63xx: add kernel space and image support for the Netgear CVG834G
[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))