http://downloads.netgear.com/files/GPL/DM111PSP_v3.61d_GPL.tar.gz
[bcm963xx.git] / Makefile
1 #****************************************************************************
2 #
3 #  Copyright (c) 2001, 2002, 2003, 2004  Broadcom Corporation
4 #  All Rights Reserved
5 #  No portions of this material may be reproduced in any form without the
6 #  written permission of:
7 #          Broadcom Corporation
8 #          16251 Laguna Canyon Road
9 #          Irvine, California 92618
10 #  All information contained in this document is Broadcom Corporation
11 #  company private, proprietary, and trade secret.
12 #
13 #****************************************************************************
14
15 # Top-level Makefile for all commengine xDSL platforms
16
17 include version.make
18
19 BRCM_RELEASETAG=$(BRCM_VERSION).$(BRCM_RELEASE)L.$(BRCM_EXTRAVERSION)
20
21 ###########################################
22 #
23 # Define Basic Variables
24 #
25 ###########################################
26 BUILD_DIR = $(shell pwd)
27 KERNEL_VER = 2.6
28 ifeq ($(strip $(KERNEL_VER)),2.6)
29 INC_KERNEL_BASE = $(BUILD_DIR)/kernel
30 ORIGINAL_KERNEL = linuxmips.tar.bz2
31 endif
32 KERNEL_DIR = $(INC_KERNEL_BASE)/linux
33 BRCMDRIVERS_DIR = $(BUILD_DIR)/bcmdrivers
34 USERAPPS_DIR = $(BUILD_DIR)/userapps
35 LINUXDIR = $(INC_KERNEL_BASE)/linux
36 HOSTTOOLS_DIR = $(BUILD_DIR)/hostTools
37 IMAGES_DIR = $(BUILD_DIR)/images
38 TARGETS_DIR = $(BUILD_DIR)/targets
39 DEFAULTCFG_DIR = $(TARGETS_DIR)/defaultcfg
40 XCHANGE_DIR = $(BUILD_DIR)/xChange
41 FSSRC_DIR = $(TARGETS_DIR)/fs.src
42 CFE_FILE = $(TARGETS_DIR)/cfe/cfe$(BRCM_CHIP).bin
43 SHARED_DIR = $(BUILD_DIR)/shared
44 CONFIG_SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \
45           else if [ -x /bin/bash ]; then echo /bin/bash; \
46           else echo sh; fi ; fi)
47 GENDEFCONFIG_CMD = $(HOSTTOOLS_DIR)/scripts/gendefconfig
48 RUN_NOISE=0
49 6510_REF_CODE=$(BUILD_DIR)/userapps/broadcom/6510refCode
50
51 ###########################################
52 #
53 # Import Build Profiles
54 #
55 ###########################################
56 BRCM_BOARD=bcm963xx
57 LAST_PROFILE=$(shell find targets -name vmlinux | sed -e "s?targets/??" -e "s?/.*??" -e "q")
58 ifeq ($(strip $(PROFILE)),)
59 PROFILE=$(LAST_PROFILE)
60 export PROFILE
61 endif
62
63 ifneq ($(strip $(PROFILE)),)
64 include $(TARGETS_DIR)/$(PROFILE)/$(PROFILE)
65 export BRCM_CHIP
66 export BRCM_FLASHPSI_SIZE
67 export BRCM_DRIVER_WIRELESS_PCMCIA_DATASWAP BRCM_DRIVER_WIRELESS_EBI_DMA
68 export BRCM_DRIVER_USB BRCM_DRIVER_ETHERNET_CONFIG
69 export BRCM_DEFAULTCFG
70 export BRCM_KERNEL_NF_FIREWALL BRCM_KERNEL_NF_MANGLE BRCM_KERNEL_NF_NAT
71 endif
72
73 ###########################################
74 #
75 # Define Toolchain
76 #
77 ###########################################
78 ifeq ($(strip $(BRCM_UCLIBC)),y)
79 NTC=1
80 ifeq ($(strip $(NTC)),1)
81 TOOLCHAIN=/opt/toolchains/uclibc-crosstools_gcc-3.4.2_uclibc-20050502
82 CROSS_COMPILE = $(TOOLCHAIN)/bin/mips-linux-uclibc-
83 else
84 TOOLCHAIN=/opt/toolchains/uclibc
85 CROSS_COMPILE = $(TOOLCHAIN)/bin/mips-uclibc-
86 endif
87 else
88 TOOLCHAIN=/usr/crossdev/mips
89 CROSS_COMPILE = $(TOOLCHAIN)/bin/mips-linux-
90 endif
91
92 AR              = $(CROSS_COMPILE)ar
93 AS              = $(CROSS_COMPILE)as
94 LD              = $(CROSS_COMPILE)ld
95 CC              = $(CROSS_COMPILE)gcc
96 CXX             = $(CROSS_COMPILE)g++
97 CPP             = $(CROSS_COMPILE)cpp
98 NM              = $(CROSS_COMPILE)nm
99 STRIP           = $(CROSS_COMPILE)strip
100 SSTRIP          = $(CROSS_COMPILE)sstrip
101 OBJCOPY         = $(CROSS_COMPILE)objcopy
102 OBJDUMP         = $(CROSS_COMPILE)objdump
103 RANLIB          = $(CROSS_COMPILE)ranlib
104
105 LIB_PATH        = $(TOOLCHAIN)/mips-linux/lib
106 LIBDIR          = $(TOOLCHAIN)/mips-linux/lib
107 LIBCDIR         = $(TOOLCHAIN)/mips-linux
108
109 ###########################################
110 #
111 # Application-specific settings
112 #
113 ###########################################
114 INSTALL_DIR = $(TARGETS_DIR)/fs.src
115 TARGET_FS = $(TARGETS_DIR)/$(PROFILE)/fs
116 PROFILE_DIR = $(TARGETS_DIR)/$(PROFILE)
117 PROFILE_PATH = $(TARGETS_DIR)/$(PROFILE)/$(PROFILE)
118 VENDOR_NAME = bcm
119 FS_KERNEL_IMAGE_NAME = $(VENDOR_NAME)$(PROFILE)_fs_kernel
120 CFE_FS_KERNEL_IMAGE_NAME = $(VENDOR_NAME)$(PROFILE)_cfe_fs_kernel
121 FLASH_IMAGE_NAME = $(VENDOR_NAME)$(PROFILE)_flash_image_$(BRCM_BOARD_ID)
122 INC_BRCMDRIVER_PUB_PATH=$(BRCMDRIVERS_DIR)/opensource/include
123 INC_BRCMDRIVER_PRIV_PATH=$(BRCMDRIVERS_DIR)/broadcom/include
124 INC_ENDPOINT_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/endpoint/bcm9$(BRCM_CHIP)/inc
125 INC_ADSLDRV_PATH=$(BRCMDRIVERS_DIR)/broadcom/char/adsl/impl1
126 BROADCOM_CFM_DIR=$(BROADCOM_DIR)/cfm
127 INC_BRCMCFM_PATH=$(BROADCOM_CFM_DIR)/inc
128 INC_BRCMSHARED_PUB_PATH=$(SHARED_DIR)/opensource/include
129 INC_BRCMSHARED_PRIV_PATH=$(SHARED_DIR)/broadcom/include
130 INC_BRCMBOARDPARMS_PATH=$(SHARED_DIR)/opensource/boardparms
131 INC_FLASH_PATH=$(SHARED_DIR)/opensource/flash
132
133 ifeq ($(strip $(BRCM_APP_PHONE)),sip)
134 export VOXXXLOAD=1
135 export VOIPLOAD=1
136 export SIPLOAD=1
137
138 ifeq ($(strip $(BRCM_VODSL_CONFIG_MANAGER)),y)
139         export BRCM_VODSL_CFGMGR=1
140 endif
141
142 BRCM_RELEASETAG := $(BRCM_RELEASETAG).sip
143 endif
144
145 ifeq ($(strip $(BRCM_APP_PHONE)),mgcp)
146 export VOXXXLOAD=1
147 export VOIPLOAD=1
148 export MGCPLOAD=1
149 export BRCM_VODSL_CFGMGR=0
150 BRCM_RELEASETAG := $(BRCM_RELEASETAG).mgcp
151 endif
152
153 ifeq ($(strip $(BRCM_PROFILER_ENABLED)),y)
154 export BRCM_PROFILER_TOOL=1
155 else
156 export BRCM_PROFILER_TOOL=0
157 endif
158
159 ifneq ($(strip $(BUILD_VODSL)),)
160 export VOXXXLOAD=1
161 endif
162
163 ifeq ($(strip $(BRCM_VODSL_STUNC)),y)
164         export BRCM_VODSL_STUN_CLIENT=1
165 endif
166
167 ifeq ($(strip $(BRCM_VODSL_RANDOMP)),y)
168         export BRCM_VODSL_RANDOM_PORT=1
169 endif
170
171 BRCM_DSP_HAL := gw
172 BRCM_DSP_HAL_EXTENSION :=
173 XCHANGE_DSP_APP_EXTENSION :=
174 export XCHANGE_DSP_APP=$(BRCM_DSP_CODEC)
175
176 ifeq ($(strip $(BRCM_DSP_PCM)),y)
177 XCHANGE_DSP_APP := dspApp3341_tdm
178 BRCM_DSP_HAL_EXTENSION := _pcm
179 endif
180
181 ifeq ($(strip $(BRCM_DSP_PCM_G726)),y)
182 XCHANGE_DSP_APP := dspApp3341_tdm_g726
183 BRCM_DSP_HAL_EXTENSION := _pcm
184 endif
185
186 ifeq ($(strip $(BRCM_DSP_PCM_T38_EXT)),y)
187 XCHANGE_DSP_APP := dspApp3341_tdm_t38
188 BRCM_DSP_HAL_EXTENSION := _pcm
189 endif
190
191 ifeq ($(strip $(BRCM_DSP_APM_FXO_EXT)),y)
192 XCHANGE_DSP_APP := dspApp3341
193 BRCM_DSP_HAL_EXTENSION := _hybrid
194 XCHANGE_DSP_APP_EXTENSION := _fxo_ext
195 endif
196
197 ifeq ($(strip $(BUILD_VDSL)),y)
198 export BUILD_VDSL=y
199 VBOOT_BIN="boot.bin"
200 ifneq ($(strip $(CPE_ANNEX_B)),)
201   CPE_MODEM="cpe_annex_b.bin"
202 else
203   CPE_MODEM="cpe_annex_a.bin"
204 endif
205 ifeq ($(strip $(VCOPE_TYPE)),CO)
206   VMODEM_BIN="co_modem.bin"
207 endif
208 ifeq ($(strip $(VCOPE_TYPE)),CPE)
209   VMODEM_BIN=$(CPE_MODEM)
210 endif
211
212 endif
213
214 #
215 #  Warning here, we do re-assign some of the variables defined earlier:
216 #  BRCM_DSP_HAL and BRCM_DSP_HAL_EXTENSION for example, in order to pickup
217 #  the correct board HAL application.
218 #
219 ifeq ($(strip $(BRCM_DSP_FXO)),y)
220 ifeq ($(strip $(BRCM_SLIC_LE9502)),y)
221 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)_Le9502FXO
222 BRCM_RELEASETAG := $(BRCM_RELEASETAG)._LE9502
223 BRCM_DSP_HAL := _Le9502FXO
224 BRCM_DSP_HAL_EXTENSION :=
225 export BRCM_SLIC_LE9502
226 else
227 ifeq ($(strip $(BRCM_SLIC_LE9500)),y)
228 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)_Le9500FXO
229 BRCM_RELEASETAG := $(BRCM_RELEASETAG)._LE9500
230 BRCM_DSP_HAL := _Le9500FXO
231 BRCM_DSP_HAL_EXTENSION :=
232 export BRCM_SLIC_LE9500
233 endif
234 endif
235 endif
236
237
238 #
239 # DSP codec flags definition.  To be used throughout the application (for configuration and vodsl)
240 #
241
242 BRCM_DSP_CODEC_DEFINES := -DXCFG_G711_SUPPORT=1
243
244 ifeq ($(strip $(BRCM_DSP_CODEC_G723)),y)
245 BRCM_DSP_CODEC_DEFINES += -DXCFG_G7231_SUPPORT=1
246 endif
247
248 ifeq ($(strip $(BRCM_DSP_CODEC_G726)),y)
249 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
250 endif
251
252 ifeq ($(strip $(BRCM_DSP_CODEC_G729)),y)
253 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
254 endif
255
256 ifeq ($(strip $(BRCM_DSP_CODEC_G7xx)),y)
257 BRCM_DSP_CODEC_DEFINES += -DXCFG_G7231_SUPPORT=1
258 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
259 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
260 endif
261
262 ifeq ($(strip $(BRCM_DSP_PCM)),y)
263 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
264 endif
265
266 ifeq ($(strip $(BRCM_DSP_PCM_G726)),y)
267 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
268 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
269 endif
270
271 ifeq ($(strip $(BRCM_DSP_PCM_T38_EXT)),y)
272 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
273 endif
274
275 ifeq ($(strip $(BRCM_DSP_CODEC_T38_EXT)),y)
276 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
277 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
278 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
279 endif
280
281 ifeq ($(strip $(BRCM_DSP_APM_FXO_EXT)),y)
282 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
283 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
284 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
285 endif
286
287 ifeq ($(strip $(BRCM_DSP_CODEC)),all)
288 BRCM_DSP_CODEC_DEFINES += -DXCFG_G7231_SUPPORT=1
289 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
290 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
291 BRCM_DSP_CODEC_DEFINES += -DXCFG_BV16_SUPPORT=1
292 BRCM_DSP_CODEC_DEFINES += -DXCFG_ILBC_SUPPORT=1
293 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
294 endif
295
296
297 #
298 #  Definition of the number of voice channels supported based on the specific
299 #  application being created.
300 #
301
302 ifeq ($(strip $(BRCM_DSP_APM_FXO_EXT)), y)
303 BRCM_DSP_CHAN_DEFINES = -DNUM_APM_VOICE_CHANNELS=2 -DNUM_TDM_VOICE_CHANNELS=0 -DNUM_FXO_CHANNELS=1
304 else
305 BRCM_DSP_CHAN_DEFINES = -DNUM_APM_VOICE_CHANNELS=0 -DNUM_TDM_VOICE_CHANNELS=0 -DNUM_FXO_CHANNELS=0
306 endif
307
308 export BRCM_DSP_CODEC_DEFINES
309 export BRCM_DSP_CHAN_DEFINES
310 export BRCM_DSP_FXO
311 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)$(BRCM_DSP_HAL)$(BRCM_DSP_HAL_EXTENSION)
312 export XCHANGE_DSP_APP_EXTENSION
313 export BRCM_DSP_HAL_EXTENSION
314
315 # If no codec is selected, build G.711 load.
316 # Any XCHANGE_BUILD_APP directory would be OK
317 # because G.711 is included with all the voice DSP images.
318 ifneq ($(strip $(BUILD_VODSL)),)
319 ifeq ($(strip $(XCHANGE_DSP_APP)),)
320 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)gw
321 export XCHANGE_DSP_APP=g711
322 endif
323 endif
324 BRCM_RELEASETAG := $(BRCM_RELEASETAG).$(XCHANGE_DSP_APP)
325
326 ifeq ($(strip $(BRCM_CHIP)),6358)
327 ifeq ($(strip $(BRCM_6358_G729_FXO)),y)
328 BRCM_DSP_HAL := vw_fxo
329 BRCM_DSP_CHAN_DEFINES = -DNUM_FXO_CHANNELS=1
330 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
331 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
332 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
333 export BRCM_6358_G729_FXO
334 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)vw_fxo
335 export BRCM_DSP_CODEC_DEFINES
336 else
337 ifeq ($(strip $(BRCM_6358_G729_4FXS)),y)
338 BRCM_DSP_HAL := vw_4fxs
339 export BRCM_6358_G729_4FXS
340 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)vw_4fxs
341 else
342 ifeq ($(strip $(BRCM_6358_G729_2FXS_LEGERITY)),y)
343 BRCM_DSP_HAL := vw_legerity
344 export BRCM_6358_G729_2FXS_LEGERITY
345 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)vw_legerity
346 else
347 ifeq ($(strip $(BRCM_6358_G729_FXO_LEGERITY)),y)
348 BRCM_DSP_HAL := vw_fxo_legerity
349 BRCM_DSP_CHAN_DEFINES = -DNUM_FXO_CHANNELS=1
350 export BRCM_6358_G729_FXO_LEGERITY
351 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)vw_fxo_legerity
352 else
353 ifeq ($(strip $(BRCM_6358_G729_ISDN_FXO_LEGERITY)),y)
354 BRCM_DSP_HAL := vw_isdn_fxo
355 BRCM_DSP_CHAN_DEFINES   = -DNUM_FXO_CHANNELS=1
356 BRCM_DSP_CODEC_DEFINES := -DXCFG_G711_SUPPORT=1
357 BRCM_DSP_CODEC_DEFINES += -DXCFG_G729_SUPPORT=1
358 BRCM_DSP_CODEC_DEFINES += -DXCFG_G726_SUPPORT=1
359 BRCM_DSP_CODEC_DEFINES += -DXCFG_FAX_SUPPORT=1
360 export BRCM_6358_G729_ISDN_FXO_LEGERITY
361 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)vw_isdn_fxo
362 export BRCM_DSP_CODEC_DEFINES
363 else
364 BRCM_DSP_HAL := vw
365 export BRCM_6358_G729
366 export XCHANGE_BUILD_APP=Bcm$(BRCM_CHIP)vw
367 endif
368 endif
369 endif
370 endif
371 endif
372 endif
373
374 ifeq ($(strip $(BRCM_VODSL_DUAL_3341)),y)
375 BRCM_RELEASETAG := $(BRCM_RELEASETAG).dual3341
376 endif
377
378 #Set up ADSL standard
379 export ADSL=$(BRCM_ADSL_STANDARD)
380
381 #Set up ADSL_PHY_MODE  {file | obj}
382 export ADSL_PHY_MODE=file
383
384 #Set up ADSL_SELF_TEST
385 export ADSL_SELF_TEST=$(BRCM_ADSL_SELF_TEST)
386
387 #WLan support
388 ifneq ($(strip $(BUILD_MIMO)),)
389 WLAN_IMPL=2
390 else
391 WLAN_IMPL=1
392 endif
393 export BUILD_MIMO
394
395 ###########################################
396 #
397 # Complete list of applications
398 #
399 ###########################################
400 export OPENSOURCE_DIR=$(USERAPPS_DIR)/opensource
401 SUBDIRS_OPENSOURCE = $(OPENSOURCE_DIR)/atm2684/pvc2684ctl \
402         $(OPENSOURCE_DIR)/openssl \
403         $(OPENSOURCE_DIR)/ipsec-tools \
404         $(OPENSOURCE_DIR)/bridge-utils \
405         $(OPENSOURCE_DIR)/ppp/pppoe \
406         $(OPENSOURCE_DIR)/udhcp \
407         $(OPENSOURCE_DIR)/iptables \
408         $(OPENSOURCE_DIR)/ebtables \
409         $(OPENSOURCE_DIR)/reaim  \
410         $(OPENSOURCE_DIR)/iproute2  \
411         $(OPENSOURCE_DIR)/libosip2 \
412         $(OPENSOURCE_DIR)/siproxd \
413         $(OPENSOURCE_DIR)/zebra  \
414         $(OPENSOURCE_DIR)/net-snmp  \
415         $(OPENSOURCE_DIR)/ftpd \
416         $(OPENSOURCE_DIR)/libcreduction \
417         $(OPENSOURCE_DIR)/busybox
418
419 #In future, we need to add soap when it
420 #is decoupled from cli
421
422 export BROADCOM_DIR=$(USERAPPS_DIR)/broadcom
423 SUBDIRS_BROADCOM = $(BROADCOM_DIR)/nvram \
424         $(BROADCOM_DIR)/cfm \
425         $(BROADCOM_DIR)/upnp/router/upnp \
426         $(BROADCOM_DIR)/nas \
427         $(BROADCOM_DIR)/wlctl \
428         $(BROADCOM_DIR)/vodsl \
429         $(BROADCOM_DIR)/atmctl \
430         $(BROADCOM_DIR)/adslctl \
431         $(BROADCOM_DIR)/netctl \
432         $(BROADCOM_DIR)/dnsprobe \
433         $(BROADCOM_DIR)/igmp \
434         $(BROADCOM_DIR)/dhcpr \
435         $(BROADCOM_DIR)/sntp \
436         $(BROADCOM_DIR)/ippd \
437         $(BROADCOM_DIR)/ddnsd \
438         $(BROADCOM_DIR)/ethctl \
439         $(BROADCOM_DIR)/hotplug \
440         $(BROADCOM_DIR)/epittcp \
441         $(BROADCOM_DIR)/snmp \
442         $(BROADCOM_DIR)/tr69c \
443         $(BROADCOM_DIR)/ses \
444         $(BROADCOM_DIR)/relayCtl \
445         $(BROADCOM_DIR)/vdslctl \
446         $(BROADCOM_DIR)/hostCode
447
448 SUBDIRS_APP = $(SUBDIRS_BROADCOM) $(SUBDIRS_OPENSOURCE)
449 SUBDIRS = $(foreach dir, $(SUBDIRS_APP), $(shell if [ -d "$(dir)" ]; then echo $(dir); fi))
450
451 OPENSOURCE_APPS = ipsec-tools pvc2684ctl pvc2684d brctl pppd udhcp iptables ebtables \
452                   reaim tc libosip2 siproxd snmp zebra bftpd busybox 
453
454 BROADCOM_APPS = nvram cfm upnp nas wlctl vodsl atmctl adslctl netctl dnsprobe \
455                 igmp dhcpr diagapp sntp ddnsd ilmi ippd hotplug ethctl epittcp snmp ses \
456                 hmi2proxy relayctl vdslctl
457 LIBC_OPTIMIZATION = libcreduction
458
459 ifneq ($(strip $(BUILD_GDBSERVER)),)
460 TOOLCHAIN_UTIL_APPS = gdbserver
461 endif
462
463 BUSYBOX_DIR = $(OPENSOURCE_DIR)/busybox
464
465 BRCMAPPS = openssl $(BROADCOM_APPS) $(OPENSOURCE_APPS) $(TOOLCHAIN_UTIL_APPS) $(LIBC_OPTIMIZATION)
466
467 all: sanity_check profile_check kernelbuild modbuild app hosttools buildimage
468
469 menuconfig:
470         @cd $(INC_KERNEL_BASE); \
471         if [ ! -e linux/CREDITS ]; then \
472           echo Untarring original Linux kernel source...; \
473           (tar xkfj $(ORIGINAL_KERNEL) 2> /dev/null || true); \
474         fi
475         $(MAKE) -C $(KERNEL_DIR)/scripts/lxdialog HOSTCC=gcc
476         $(CONFIG_SHELL) $(HOSTTOOLS_DIR)/scripts/Menuconfig $(TARGETS_DIR)/config.in
477
478 sanity_check:
479         @if [ "$(PROFILE)" = "" ]; then \
480           echo You need to specify build profile name from $(TARGETS_DIR) using 'make PROFILE=<profile name>...'; exit 1; \
481         fi
482
483 profile_check:
484         @if [ "$(LAST_PROFILE)" != "" ] && [ "$(LAST_PROFILE)" != "$(PROFILE)" ]; then \
485                 echo "The specified profile, $(PROFILE), differs from the last one built, $(LAST_PROFILE)."; \
486                 echo "The entire image must be rebuilt."; \
487                 read -p "Press ENTER to rebuild the entire image or CTRL-C to abort. " ; \
488                 $(MAKE) PROFILE=$(LAST_PROFILE) clean; \
489                 $(MAKE) PROFILE=$(PROFILE); \
490                 echo "Ignore the make exit error, Error 1"; \
491                 exit 1; \
492         fi
493
494 $(KERNEL_DIR)/vmlinux:
495         $(GENDEFCONFIG_CMD) $(PROFILE_PATH)
496         cd $(KERNEL_DIR); \
497         cp -f $(KERNEL_DIR)/arch/mips/defconfig $(KERNEL_DIR)/.config; \
498         $(MAKE) oldconfig; $(MAKE); $(MAKE) modules_install
499
500 kernelbuild:
501 ifeq ($(wildcard $(KERNEL_DIR)/vmlinux),)
502         @cd $(INC_KERNEL_BASE); \
503         if [ ! -e linux/CREDITS ]; then \
504           echo Untarring original Linux kernel source...; \
505           (tar xkfj $(ORIGINAL_KERNEL) 2> /dev/null || true); \
506         fi
507         $(GENDEFCONFIG_CMD) $(PROFILE_PATH)
508         cd $(KERNEL_DIR); \
509         cp -f $(KERNEL_DIR)/arch/mips/defconfig $(KERNEL_DIR)/.config; \
510         $(MAKE) oldconfig; $(MAKE)
511 else
512         cd $(KERNEL_DIR); $(MAKE)
513 endif
514
515 kernel: profile_check kernelbuild hosttools buildimage
516
517 ifeq ($(strip $(VOXXXLOAD)),1)
518 modbuild: touch_voice_files
519         cd $(KERNEL_DIR); $(MAKE) modules && $(MAKE) modules_install
520 else
521 modbuild:
522         cd $(KERNEL_DIR); $(MAKE) modules && $(MAKE) modules_install
523 endif
524
525 modules: profile_check modbuild hosttools buildimage
526
527 app: profile_check prebuild $(BRCMAPPS) hosttools buildimage
528
529 prebuild:
530         mkdir -p $(INSTALL_DIR)/bin $(INSTALL_DIR)/lib
531
532 # touch_voice_files doesn't clean up voice, just enables incremental build of voice code
533 touch_voice_files:
534         find bcmdrivers/broadcom/char/endpoint/ \( -name '*.o' -o -name '*.a' -o -name '*.lib' -o -name '*.ko' -o -name '*.cmd' -o -name '.*.cmd' -o -name '*.c' -o -name '*.mod' \) -print -exec rm -f "{}" ";"
535         rm -rf kernel/linux/.tmp_versions/endpointdd.mod
536         rm -rf kernel/linux/arch/mips/defconfig
537         rm -rf kernel/linux/include/config/bcm/endpoint/
538         rm -rf kernel/linux/include/asm-mips/offset.h
539         rm -rf kernel/linux/include/asm-mips/reg.h
540         find kernel/linux/lib/ -name '*.o' -print -exec rm -f "{}" ";"
541         find kernel/linux/lib/ -name '*.lib' -print -exec rm -f "{}" ";"
542
543 # Build user applications depending on if they are
544 # specified in the profile
545 ifneq ($(strip $(BUILD_PVC2684CTL)),)
546 export BUILD_PVC2684D=$(BUILD_PVC2684CTL)
547 pvc2684d:
548 pvc2684ctl:
549         $(MAKE) -C $(OPENSOURCE_DIR)/atm2684/pvc2684ctl $(BUILD_PVC2684CTL)
550 else
551 pvc2684d:
552 pvc2684ctl:
553 endif
554
555 ifneq ($(strip $(BUILD_BRCTL)),)
556 brctl:
557         cd $(OPENSOURCE_DIR);   (tar xkfj bridge-utils.tar.bz2 2> /dev/null || true)
558         $(MAKE) -C $(OPENSOURCE_DIR)/bridge-utils $(BUILD_BRCTL)
559 else
560 brctl:
561 endif
562
563 ifneq ($(strip $(BUILD_VCONFIG)),)
564 export BUILD_VCONFIG=y
565 endif
566
567 ifneq ($(strip $(BUILD_CFM)),)
568
569 ifneq ($(strip $(BUILD_CFM_MENU)),)
570 export BUILD_CFM_MENU=y
571 endif
572
573 cfm:
574         $(MAKE) -C $(BROADCOM_DIR)/cfm $(BUILD_CFM)
575 else
576 cfm:
577 endif
578
579 # iptables is dependent on kernel netfilter modules
580 ifneq ($(strip $(BRCM_KERNEL_NETFILTER)),)
581 ifneq ($(strip $(BUILD_IPTABLES)),)
582 iptables:
583         cd $(OPENSOURCE_DIR);   (tar xkfj iptables.tar.bz2 2> /dev/null || true)
584         $(MAKE) -C $(OPENSOURCE_DIR)/iptables $(BUILD_IPTABLES)
585 iptables-build:
586         cd $(OPENSOURCE_DIR);   (tar xkfj iptables.tar.bz2 2> /dev/null || true)
587         $(MAKE) -C $(OPENSOURCE_DIR)/iptables static
588 else
589 iptables:
590 endif
591 else
592 iptables:
593         @echo Warning: You need to enable netfilter in the kernel !!!!!
594 endif
595
596 ifneq ($(strip $(BUILD_EBTABLES)),)
597 ebtables:
598         cd $(OPENSOURCE_DIR);   (tar xkfj ebtables.tar.bz2 2> /dev/null || true)
599         $(MAKE) -C $(OPENSOURCE_DIR)/ebtables $(BUILD_EBTABLES)
600 else
601 ebtables:
602 endif
603
604 ifneq ($(strip $(BUILD_PPPD)),)
605 pppd:
606         $(MAKE) -C $(OPENSOURCE_DIR)/ppp/pppoe $(BUILD_PPPD)
607 else
608 pppd:
609 endif
610
611 ifneq ($(strip $(BUILD_REAIM)),)
612 reaim:
613         cd $(OPENSOURCE_DIR);   (tar xkfj reaim.tar.bz2 2> /dev/null || true)
614         $(MAKE) -C $(OPENSOURCE_DIR)/reaim $(BUILD_REAIM)
615 else
616 reaim:
617 endif
618
619 ifneq ($(strip $(BRCM_KERNEL_NETQOS)),)
620 tc:
621         cd $(OPENSOURCE_DIR);   (tar xkfj iproute2.tar.bz2 2> /dev/null || true)
622         $(MAKE) -C $(OPENSOURCE_DIR)/iproute2 dynamic
623 else
624 tc:
625 endif
626
627 ifneq ($(strip $(BUILD_GDBSERVER)),)
628 gdbserver:
629         install -m 755 $(TOOLCHAIN)/mips-linux-uclibc/target-apps/usr/bin/gdbserver $(INSTALL_DIR)/bin
630         $(STRIP) $(INSTALL_DIR)/bin/gdbserver
631 else
632 gdbserver:
633 endif
634
635 ifneq ($(strip $(BUILD_ETHWAN)),)
636 export BUILD_ETHWAN=y
637 endif
638
639 ifneq ($(strip $(BUILD_UDHCP)),)
640 udhcp:
641         $(MAKE) -C $(OPENSOURCE_DIR)/udhcp $(BUILD_UDHCP)
642 else
643 udhcp:
644 endif
645
646 # UPNP is dependent on iptables
647 ifneq ($(strip $(BUILD_IPTABLES)),)
648 ifneq ($(strip $(BUILD_UPNP)),)
649 upnp: iptables-build
650         $(MAKE) -C $(BROADCOM_DIR)/upnp/router/upnp  $(BUILD_UPNP)
651 else
652 upnp:
653 endif
654 else
655 upnp:
656         @echo Warning: You need to build iptables first !!!!!
657 endif
658
659 ifneq ($(strip $(BUILD_IPSEC_TOOLS)),)
660 ipsec-tools:
661         cd $(OPENSOURCE_DIR);   (tar xkfj ipsec-tools.tar.bz2 2> /dev/null || true)
662         $(MAKE) -C $(OPENSOURCE_DIR)/ipsec-tools $(BUILD_IPSEC_TOOLS)
663 else
664 ipsec-tools:
665 endif
666
667 ifneq ($(strip $(BUILD_CERT)),)
668 openssl:
669         cd $(OPENSOURCE_DIR);   (tar xkfj openssl.tar.bz2 2> /dev/null || true)
670         $(MAKE) -C $(OPENSOURCE_DIR)/openssl dynamic
671 else
672 openssl:
673 endif
674
675
676 ifneq ($(strip $(BUILD_SIPROXD)),)
677 siproxd:
678         cd $(OPENSOURCE_DIR);   (tar xkfj siproxd.tar.bz2 2> /dev/null || true)
679         $(MAKE) -C $(OPENSOURCE_DIR)/siproxd $(BUILD_SIPROXD)
680 libosip2:
681         cd $(OPENSOURCE_DIR);   (tar xkfj libosip2.tar.bz2 2> /dev/null || true)
682         $(MAKE) -C $(OPENSOURCE_DIR)/libosip2
683 else
684 siproxd:
685
686 libosip2:
687
688 endif
689
690 ifneq ($(strip $(BUILD_SNMP)),)
691
692 ifneq ($(strip $(BUILD_SNMP_SET)),)
693 export SNMP_SET=1
694 else
695 export SNMP_SET=0
696 endif
697
698 ifneq ($(strip $(BUILD_SNMP_ADSL_MIB)),)
699 export SNMP_ADSL_MIB=1
700 else
701 export SNMP_ADSL_MIB=0
702 endif
703
704 ifneq ($(strip $(BUILD_SNMP_ATM_MIB)),)
705 export SNMP_ATM_MIB=1
706 else
707 export SNMP_ATM_MIB=0
708 endif
709
710 ifneq ($(strip $(BUILD_SNMP_AT_MIB)),)
711 export SNMP_AT_MIB=1
712 else
713 export SNMP_AT_MIB=0
714 endif
715
716 ifneq ($(strip $(BUILD_SNMP_SYSOR_MIB)),)
717 export SNMP_SYSOR_MIB=1
718 else
719 export SNMP_SYSOR_MIB=0
720 endif
721
722 ifneq ($(strip $(BUILD_SNMP_TCP_MIB)),)
723 export SNMP_TCP_MIB=1
724 else
725 export SNMP_TCP_MIB=0
726 endif
727
728 ifneq ($(strip $(BUILD_SNMP_UDP_MIB)),)
729 export SNMP_UDP_MIB=1
730 else
731 export SNMP_UDP_MIB=0
732 endif
733
734 ifneq ($(strip $(BUILD_SNMP_IP_MIB)),)
735 export SNMP_IP_MIB=1
736 else
737 export SNMP_IP_MIB=0
738 endif
739
740 ifneq ($(strip $(BUILD_SNMP_ICMP_MIB)),)
741 export SNMP_ICMP_MIB=1
742 else
743 export SNMP_ICMP_MIB=0
744 endif
745
746 ifneq ($(strip $(BUILD_SNMP_SNMP_MIB)),)
747 export SNMP_SNMP_MIB=1
748 else
749 export SNMP_SNMP_MIB=0
750 endif
751
752 ifneq ($(strip $(BUILD_SNMP_ATMFORUM_MIB)),)
753 export SNMP_ATMFORUM_MIB=1
754 else
755 export SNMP_ATMFORUM_MIB=0
756 endif
757
758 ifneq ($(strip $(BRCM_SNMP)),)
759
760 ifneq ($(strip $(BUILD_SNMP_CHINA_TELECOM_CPE_MIB)),)
761 export SNMP_CHINA_TELECOM_CPE_MIB=1
762 export SNMP_MIB2=1
763 endif
764
765 ifneq ($(strip $(BUILD_SNMP_UDP)),)
766 export SNMP_UDP=1
767 endif
768
769 ifneq ($(strip $(BUILD_SNMP_EOC)),)
770 export SNMP_EOC=1
771 endif
772
773 ifneq ($(strip $(BUILD_SNMP_AAL5)),)
774 export SNMP_AAL5=1
775 endif
776
777 ifneq ($(strip $(BUILD_SNMP_AUTO)),)
778 export SNMP_AUTO=1
779 endif
780
781 ifneq ($(strip $(BUILD_SNMP_DEBUG)),)
782 export SNMP_DEBUG=1
783 endif
784
785 ifneq ($(strip $(BUILD_SNMP_TRANSPORT_DEBUG)),)
786 export SNMP_TRANSPORT_DEBUG=1
787 endif
788
789 ifneq ($(strip $(BUILD_SNMP_LAYER_DEBUG)),)
790 export SNMP_LAYER_DEBUG=1
791 endif
792 endif
793
794 snmp:
795 ifneq ($(strip $(BRCM_SNMP)),)
796 ##      $(MAKE) -C $(BROADCOM_DIR)/snmp $(BUILD_SNMP)
797 else
798         cd $(OPENSOURCE_DIR);   (tar xkfj net-snmp.tar.bz2 2> /dev/null || true)
799         $(MAKE) -C $(OPENSOURCE_DIR)/net-snmp $(BUILD_SNMP)
800 endif
801 else
802 snmp:
803 endif
804
805 ifneq ($(strip $(BUILD_4_LEVEL_QOS)),)
806 export BUILD_4_LEVEL_QOS=y
807 endif
808
809 ifneq ($(strip $(BUILD_ILMI)),)
810 ilmi:
811         cd $(OPENSOURCE_DIR);   (tar xkfj net-snmp.tar.bz2 2> /dev/null || true)
812         $(MAKE) -C $(BROADCOM_DIR)/ilmi $(BUILD_ILMI)
813 else
814 ilmi:
815 endif
816
817 ifneq ($(strip $(BUILD_VODSL)),)
818 vodsl:
819         $(MAKE) -C $(BROADCOM_DIR)/vodsl $(BUILD_VODSL)
820 else
821 vodsl:
822 endif
823
824 # Leave it for the future when soap server is decoupled from cfm
825 ifneq ($(strip $(BUILD_SOAP)),)
826 ifeq ($(strip $(BUILD_SOAP_VER)),2)
827 soapserver:
828         $(MAKE) -C $(BROADCOM_DIR)/SoapToolkit/SoapServer $(BUILD_SOAP)
829 else
830 soap:
831         $(MAKE) -C $(BROADCOM_DIR)/soap $(BUILD_SOAP)
832 endif
833 else
834 soap:
835 endif
836
837 ifneq ($(strip $(BUILD_NAS)),)
838 export WIRELESS=1
839 nas:
840         if [ -e $(BRCMDRIVERS_DIR)/broadcom/net/wl/impl$(WLAN_IMPL)/nas ]; then \
841           rm -rf $(BROADCOM_DIR)/nas/*; \
842           cp -pRdf $(BRCMDRIVERS_DIR)/broadcom/net/wl/impl$(WLAN_IMPL)/nas/* $(BROADCOM_DIR)/nas; \
843         fi
844         $(MAKE) -C $(BROADCOM_DIR)/nas $(BUILD_NAS)
845
846 #add hotplug here, for nas use only
847 hotplug:
848         $(MAKE) -C $(BROADCOM_DIR)/hotplug $(BUILD_NAS)
849
850 else
851 export WIRELESS=0
852 nas:
853 #add hotplug here, for nas use only
854 hotplug:
855 endif
856
857 ifneq ($(strip $(BUILD_WLCTL)),)
858 export WIRELESS=1
859 wlctl:
860         if [ -e $(BRCMDRIVERS_DIR)/broadcom/net/wl/impl$(WLAN_IMPL)/wlctl ]; then \
861           rm -rf $(BROADCOM_DIR)/wlctl/*; \
862           cp -pRdf $(BRCMDRIVERS_DIR)/broadcom/net/wl/impl$(WLAN_IMPL)/wlctl/* $(BROADCOM_DIR)/wlctl; \
863         fi
864         $(MAKE) -C $(BROADCOM_DIR)/wlctl $(BUILD_WLCTL)
865 else
866 export WIRELESS=0
867 wlctl:
868 endif
869
870 ifneq ($(strip $(BUILD_EPITTCP)),)
871 epittcp:
872         $(MAKE) -C $(BROADCOM_DIR)/epittcp $(BUILD_EPITTCP)
873 else
874 epittcp:
875 endif
876
877 ifneq ($(strip $(BUILD_SES)),)
878 ses:
879         if [ -e $(BRCMDRIVERS_DIR)/broadcom/net/wl/impl$(WLAN_IMPL)/ses ]; then \
880           rm -rf $(BROADCOM_DIR)/ses/*; \
881           cp -pRdf $(BRCMDRIVERS_DIR)/broadcom/net/wl/impl$(WLAN_IMPL)/ses/* $(BROADCOM_DIR)/ses; \
882         fi
883         $(MAKE) -C $(BROADCOM_DIR)/ses $(BUILD_SES)
884 else
885 ses:
886 endif
887
888 ifneq ($(strip $(BUILD_NVRAM)),)
889 nvram:
890         $(MAKE) -C $(BROADCOM_DIR)/nvram $(BUILD_NVRAM)
891 else
892 nvram:
893 endif
894
895 #Always compile Ethernet control utility
896 ethctl:
897         $(MAKE) -C $(BROADCOM_DIR)/ethctl dynamic
898
899 ifneq ($(strip $(BUILD_DNSPROBE)),)
900 dnsprobe:
901         $(MAKE) -C $(BROADCOM_DIR)/dnsprobe $(BUILD_DNSPROBE)
902 else
903 dnsprobe:
904 endif
905
906 ifneq ($(strip $(BUILD_IGMP)),)
907 igmp:
908         $(MAKE) -C $(BROADCOM_DIR)/igmp $(BUILD_IGMP)
909 else
910 igmp:
911 endif
912
913 ifneq ($(strip $(BUILD_DHCPR)),)
914 dhcpr:
915         $(MAKE) -C $(BROADCOM_DIR)/dhcpr $(BUILD_DHCPR)
916 else
917 dhcpr:
918 endif
919
920 ifneq ($(strip $(BUILD_ZEBRA)),)
921 zebra:
922         cd $(OPENSOURCE_DIR);   (tar xkfj zebra.tar.bz2 2> /dev/null || true)
923         $(MAKE) -C $(OPENSOURCE_DIR)/zebra $(BUILD_ZEBRA)
924 else
925 zebra:
926 endif
927
928 ifneq ($(strip $(BUILD_ATMCTL)),)
929 atmctl:
930         $(MAKE) -C $(BROADCOM_DIR)/atmctl $(BUILD_ATMCTL)
931 else
932 atmctl:
933 endif
934
935 ifneq ($(strip $(BUILD_ADSLCTL)),)
936 adslctl:
937         $(MAKE) -C $(BROADCOM_DIR)/adslctl $(BUILD_ADSLCTL)
938 else
939 adslctl:
940 endif
941
942 ifeq ($(strip $(BUILD_CFM_CLI)),y)
943 ifneq ($(strip $(BUILD_NETCTL)),)
944 netctl:
945         $(MAKE) -C $(BROADCOM_DIR)/netctl $(BUILD_NETCTL)
946 else
947 netctl:
948 endif
949 else
950 netctl:
951 endif
952
953 ifneq ($(strip $(BUILD_BUSYBOX)),)
954 busybox:
955         cd $(OPENSOURCE_DIR); (tar xkfj busybox.tar.bz2 2> /dev/null || true)
956 #       $(MAKE) -C $(OPENSOURCE_DIR)/busybox $(BUILD_BUSYBOX)
957         cd $(OPENSOURCE_DIR)/busybox; cp -f brcm.config .config
958         $(MAKE) -C $(OPENSOURCE_DIR)/busybox install
959 else
960 busybox:
961 endif
962
963 ifneq ($(strip $(BUILD_LIBCREDUCTION)),)
964 libcreduction:
965         $(MAKE) -C $(OPENSOURCE_DIR)/libcreduction install
966 else
967 libcreduction:
968 endif
969
970 ifneq ($(strip $(BUILD_DIAGAPP)),)
971 diagapp:
972         $(MAKE) -C $(BROADCOM_DIR)/diagapp $(BUILD_DIAGAPP)
973 else
974 diagapp:
975 endif
976
977 ifneq ($(strip $(BUILD_FTPD)),)
978 bftpd:
979         cd $(OPENSOURCE_DIR);   (tar xkfj ftpd.tar.bz2 2> /dev/null || true)
980         $(MAKE) -C $(OPENSOURCE_DIR)/ftpd $(BUILD_FTPD)
981 else
982 bftpd:
983 endif
984
985 ifneq ($(strip $(BUILD_DDNSD)),)
986 ddnsd:
987         $(MAKE) -C $(BROADCOM_DIR)/ddnsd $(BUILD_DDNSD)
988 else
989 ddnsd:
990 endif
991
992 ifneq ($(strip $(BUILD_SNTP)),)
993 sntp:
994         $(MAKE) -C $(BROADCOM_DIR)/sntp $(BUILD_SNTP)
995 else
996 sntp:
997 endif
998
999 ifneq ($(strip $(BUILD_IPPD)),)
1000 ippd:
1001         $(MAKE) -C $(BROADCOM_DIR)/ippd $(BUILD_IPPD)
1002 else
1003 ippd:
1004 endif
1005
1006 ifneq ($(strip $(BUILD_PORT_MIRRORING)),)
1007 export BUILD_PORT_MIRRORING=1
1008 else
1009 export BUILD_PORT_MIRRORING=0
1010 endif
1011
1012 ifneq ($(strip $(BUILD_HOSTMGR)),)
1013 hmi2proxy: vdsl_processing
1014         $(MAKE) -C $(BROADCOM_DIR)/hostCode/hostMgr $(BUILD_HOSTMGR) TARGET=$@ PHY=memap6348
1015 else
1016 hmi2proxy:
1017 endif
1018
1019 ifneq ($(strip $(BUILD_RELAYCONTROL)),)
1020 relayctl:
1021         $(MAKE) -C $(BROADCOM_DIR)/relayCtl/relay6348 $(BUILD_RELAYCONTROL) TARGET=$@
1022 else
1023 relayctl:
1024 endif
1025
1026 ifneq ($(strip $(BUILD_VDSLCTL)),)
1027 vdslctl:
1028         $(MAKE) -C $(BROADCOM_DIR)/vdslctl/vdslctl $(BUILD_VDSLCTL) TARGET=$@
1029 else
1030 vdslctl:
1031 endif
1032
1033 hosttools:
1034         $(MAKE) -C $(HOSTTOOLS_DIR)
1035
1036 vdsl_processing: add_6510_support vdsl_modem vdsl_modem_file
1037
1038 vdsl_modem_file:
1039         @echo "************* VDSL Housekeeping **************************************"
1040         @echo   "VCOPE_BOARD=$(VCOPE_BOARD) HMI_VERSION=$(HMI_VERSION)"
1041         @echo "VCOPE_TYPE=$(VCOPE_TYPE) VCOPE_LINE_NUMBER=$(VCOPE_LINE_NUMBER)"
1042         @echo "**********************************************************************"
1043   
1044 vdsl_modem:
1045         - cmp -s $(FSSRC_DIR)/images/modem.bin $(6510_REF_CODE)/images/$(VMODEM_BIN); \
1046         if [ ! $$? -eq 0 ]; then \
1047                 echo "VCOPE: different type - need clean up"; \
1048                 find userapps/broadcom/hostCode/ -name *.[oa]   | xargs rm; \
1049                 find userapps/broadcom/hostCode/ -name *.depend | xargs rm; \
1050                 find userapps/broadcom/relayCtl/ -name *.[oa]   | xargs rm; \
1051                 find userapps/broadcom/relayCtl/ -name *.depend | xargs rm; \
1052                 find userapps/broadcom/vdslctl/  -name *.[oa]   | xargs rm; \
1053                 find userapps/broadcom/vdslctl/  -name *.depend | xargs rm; \
1054         fi
1055         @echo "$(FSSRC_DIR)/images/: Creating \"modem.bin\" out of $(VMODEM_BIN)" 
1056         cp -f $(6510_REF_CODE)/images/$(VMODEM_BIN) $(FSSRC_DIR)/images/modem.bin;
1057         cp -f $(6510_REF_CODE)/images/$(VBOOT_BIN) $(FSSRC_DIR)/images/boot.bin;
1058
1059 buildimage: $(KERNEL_DIR)/vmlinux
1060         su --command="cd $(TARGETS_DIR); ./buildFS"
1061 ifeq ($(strip $(BRCM_KERNEL_ROOTFS)),squashfs)
1062         #$(HOSTTOOLS_DIR)/mksquashfs $(TARGET_FS) $(PROFILE_DIR)/rootfs.img -noappend -be -always-use-fragments -gzip
1063         $(HOSTTOOLS_DIR)/mksquashfs $(TARGET_FS) $(PROFILE_DIR)/rootfs.img -noappend -be -lzma -no-fragments -noI
1064 else
1065  ifeq ($(strip $(BRCM_KERNEL_ROOTFS)),cramfs)
1066 #       $(HOSTTOOLS_DIR)/mkcramfs -r -g $(TARGET_FS) $(PROFILE_DIR)/rootfs.img
1067         $(HOSTTOOLS_DIR)/mkcramfs -r $(TARGET_FS) $(PROFILE_DIR)/rootfs.img
1068  else
1069   ifeq ($(strip $(BRCM_KERNEL_ROOTFS)),jffs2)
1070         $(HOSTTOOLS_DIR)/mkfs.jffs2 -b -p -e $(BRCM_FLASHBLK_SIZE) -r $(TARGET_FS) -o $(PROFILE_DIR)/rootfs.img
1071   endif
1072  endif
1073 endif
1074
1075 ifneq ($(strip $(BRCM_KERNEL_ROOTFS)),nfs)
1076         cd $(PROFILE_DIR); \
1077         cp $(KERNEL_DIR)/vmlinux . ; \
1078         $(STRIP) --remove-section=.note --remove-section=.comment vmlinux; \
1079         $(OBJCOPY) -O binary vmlinux vmlinux.bin; \
1080         $(HOSTTOOLS_DIR)/cmplzma -k -2 vmlinux vmlinux.bin vmlinux.lz;\
1081         $(HOSTTOOLS_DIR)/bcmImageBuilder --output $(FS_KERNEL_IMAGE_NAME) --chip $(BRCM_CHIP) --board $(BRCM_BOARD_ID) --blocksize $(BRCM_FLASHBLK_SIZE) --cfefile $(CFE_FILE) --rootfsfile rootfs.img --kernelfile vmlinux.lz; \
1082         $(HOSTTOOLS_DIR)/bcmImageBuilder --output $(CFE_FS_KERNEL_IMAGE_NAME) --chip $(BRCM_CHIP) --board $(BRCM_BOARD_ID) --blocksize $(BRCM_FLASHBLK_SIZE) --cfefile $(CFE_FILE) --rootfsfile rootfs.img --kernelfile vmlinux.lz --include-cfe; \
1083         $(HOSTTOOLS_DIR)/createimg -b $(BRCM_BOARD_ID) -n $(BRCM_NUM_MAC_ADDRESSES) -m $(BRCM_BASE_MAC_ADDRESS) -i $(CFE_FS_KERNEL_IMAGE_NAME) -o $(FLASH_IMAGE_NAME); \
1084         $(HOSTTOOLS_DIR)/addvtoken $(FLASH_IMAGE_NAME) $(FLASH_IMAGE_NAME).w
1085         @mkdir -p $(IMAGES_DIR)
1086         @cp $(PROFILE_DIR)/$(FS_KERNEL_IMAGE_NAME) $(IMAGES_DIR)/$(FS_KERNEL_IMAGE_NAME)_$(BRCM_RELEASETAG)-$(shell date '+%y%m%d_%H%M')
1087         @echo
1088         @echo -e "Done! Image $(PROFILE) has been built in $(IMAGES_DIR)."
1089 else
1090         cd $(PROFILE_DIR); \
1091         cp $(KERNEL_DIR)/vmlinux . ; \
1092         $(STRIP) --remove-section=.note --remove-section=.comment vmlinux
1093         @echo
1094         @echo -e "\t=== Following the below steps to start your NFS root file system on host ==="
1095         @echo -e "Step 1: Copy $(PROFILE_DIR)/vmlinux to your TFTP server boot directory, such as /tftpboot"
1096         @echo -e "Step 2: Add \"$(PROFILE_DIR)/fs *(rw,no_root_squash)\" to /etc/exports"
1097         @echo -e "Step 3: Become root and restart your nfs server, such as \"service nfs restart\""
1098         @echo -e "Step 4: Reboot your board and break into CFE bootloader, choose h on \"Run from flash/host\" and vmlinux on \"Default host run file name\""
1099 endif
1100
1101
1102 ###########################################
1103 #
1104 # System code clean-up
1105 #
1106 ###########################################
1107
1108 subdirs: $(patsubst %, _dir_%, $(SUBDIRS))
1109
1110 $(patsubst %, _dir_%, $(SUBDIRS)) :
1111         $(MAKE) -C $(patsubst _dir_%, %, $@) $(TGT)
1112
1113 clean: target_clean app_clean kernel_clean hosttools_clean  remove_6510_support
1114         rm -f .tmpconfig*
1115
1116 fssrc_clean:
1117         rm -fr $(INSTALL_DIR)/bin
1118         rm -fr $(INSTALL_DIR)/sbin
1119         rm -fr $(INSTALL_DIR)/lib
1120         rm -fr $(INSTALL_DIR)/upnp
1121         rm -fr $(INSTALL_DIR)/docs
1122         rm -fr $(INSTALL_DIR)/webs
1123         rm -fr $(INSTALL_DIR)/usr
1124         rm -fr $(INSTALL_DIR)/linuxrc
1125
1126 kernel_clean: sanity_check
1127         $(MAKE) -C $(KERNEL_DIR) mrproper
1128         rm -f $(KERNEL_DIR)/arch/mips/defconfig
1129         rm -f $(HOSTTOOLS_DIR)/lzma/decompress/*.o
1130         rm -rf $(XCHANGE_DIR)/dslx/lib/LinuxKernel
1131         rm -rf $(XCHANGE_DIR)/dslx/obj/LinuxKernel
1132
1133 app_clean: sanity_check fssrc_clean
1134         $(MAKE) subdirs TGT=clean
1135         rm -rf $(XCHANGE_DIR)/dslx/lib/LinuxUser
1136         rm -rf $(XCHANGE_DIR)/dslx/obj/LinuxUser
1137
1138 target_clean: sanity_check
1139         rm -f $(PROFILE_DIR)/rootfs.img
1140         rm -f $(PROFILE_DIR)/vmlinux
1141         rm -f $(PROFILE_DIR)/vmlinux.bin
1142         rm -f $(PROFILE_DIR)/vmlinux.lz
1143         rm -f $(PROFILE_DIR)/$(FS_KERNEL_IMAGE_NAME)
1144         rm -f $(PROFILE_DIR)/$(CFE_FS_KERNEL_IMAGE_NAME)
1145         rm -f $(PROFILE_DIR)/$(FLASH_IMAGE_NAME)
1146         rm -f $(PROFILE_DIR)/$(FLASH_IMAGE_NAME).w
1147         rm -fr $(PROFILE_DIR)/modules
1148         find targets -name vmlinux -print -exec rm -f "{}" ";"
1149         su --command="rm -fr $(TARGET_FS)"
1150
1151 hosttools_clean:
1152         $(MAKE) -C $(HOSTTOOLS_DIR) clean
1153
1154 add_6510_support: 
1155         $(6510_REF_CODE)/add6510support DYMMY_HMI_VERSON $(6510_REF_CODE)
1156         
1157 remove_6510_support:
1158         rm -fr $(BROADCOM_DIR)/hostCode
1159         rm -fr $(BROADCOM_DIR)/relayCtl
1160         rm -fr $(BROADCOM_DIR)/vdslctl
1161
1162 clean_6510:
1163         rm -f `find userapps/broadcom/hostCode/ -name *.[oa]`
1164         rm -f `find userapps/broadcom/hostCode/ -name *.depend`
1165         rm -f `find userapps/broadcom/relayCtl/ -name *.[oa]`
1166         rm -f `find userapps/broadcom/relayCtl/ -name *.depend`
1167         rm -f `find userapps/broadcom/vdslctl/  -name *.[oa]`
1168         rm -f `find userapps/broadcom/vdslctl/  -name *.depend`
1169         rm -f `find userapps/broadcom/cfm/      -name *.[oa]`
1170         rm -f `find userapps/broadcom/cfm/      -name *.depend`
1171
1172 voice_clean:
1173         find bcmdrivers/broadcom/char/endpoint -name '*.o' -exec rm -f "{}" ";"
1174         find userapps/broadcom/cfm -name '*.o' -exec rm -f "{}" ";"
1175         find userapps/broadcom/vodsl -name '*.o' -exec rm -f "{}" ";"
1176         rm -rf $(XCHANGE_DIR)/dslx/lib/LinuxKernel
1177         rm -rf $(XCHANGE_DIR)/dslx/obj/LinuxUser
1178
1179 ###########################################
1180 #
1181 # System-wide exported variables
1182 # (in alphabetical order)
1183 #
1184 ###########################################
1185
1186 export \
1187 AR                         \
1188 AS                         \
1189 BRCM_APP_PHONE             \
1190 BRCMAPPS                   \
1191 BRCM_BOARD                 \
1192 BRCM_DRIVER_PCI            \
1193 BRCMDRIVERS_DIR            \
1194 BRCM_DSP_APM_FXO           \
1195 BRCM_DSP_APM_FXO_EXT       \
1196 BRCM_DSP_CODEC_G711        \
1197 BRCM_DSP_CODEC_G723        \
1198 BRCM_DSP_CODEC_G726        \
1199 BRCM_DSP_CODEC_G729        \
1200 BRCM_DSP_CODEC_G7xx        \
1201 BRCM_DSP_CODEC_T38_EXT     \
1202 BRCM_DSP_CODEC_T38_INT     \
1203 BRCM_DSP_HAL               \
1204 BRCM_DSP_HAL_EXTENSION     \
1205 BRCM_DSP_PCM               \
1206 BRCM_DSP_PCM_G726          \
1207 BRCM_DSP_PCM_T38_EXT       \
1208 BRCM_EXTRAVERSION          \
1209 BRCM_KERNEL_NETQOS         \
1210 BRCM_KERNEL_ROOTFS         \
1211 BRCM_LDX_APP               \
1212 BRCM_MIPS_ONLY_BUILD       \
1213 BRCM_MIPS_ONLY_BUILD       \
1214 BRCM_PSI_VERSION           \
1215 BRCM_PTHREADS              \
1216 BRCM_RELEASE               \
1217 BRCM_RELEASETAG            \
1218 BRCM_SNMP                  \
1219 BRCM_UCLIBC                \
1220 BRCM_VERSION               \
1221 BRCM_VODSL_DUAL_3341       \
1222 BRCM_VOICE_COUNTRY_JAPAN   \
1223 BRCM_VOICE_GLOBAL_CFLAGS   \
1224 BROADCOM_CFM_DIR           \
1225 BUILD_ADSLCTL              \
1226 BUILD_ATMCTL               \
1227 BUILD_BR2684CTL            \
1228 BUILD_BRCM_VLAN            \
1229 BUILD_BRCTL                \
1230 BUILD_BUSYBOX              \
1231 BUILD_CERT                 \
1232 BUILD_CFM                  \
1233 BUILD_CFM_CLI              \
1234 BUILD_CFM_SSHD             \
1235 BUILD_CFM_TELNETD          \
1236 BUILD_DDNSD                \
1237 BUILD_DHCPR                \
1238 BUILD_DIAGAPP              \
1239 BUILD_DIR                  \
1240 BUILD_DNSPROBE             \
1241 BUILD_EBTABLES             \
1242 BUILD_EPITTCP              \
1243 BUILD_ETHWAN               \
1244 BUILD_FTPD                 \
1245 BUILD_GDBSERVER            \
1246 BUILD_IGMP                 \
1247 BUILD_IPPD                 \
1248 BUILD_IPSEC_TOOLS          \
1249 BUILD_IPTABLES             \
1250 BUILD_NAS                  \
1251 BUILD_NETCTL               \
1252 BUILD_NVRAM                \
1253 BUILD_PORT_MIRRORING                     \
1254 BUILD_PPPD                 \
1255 BUILD_PVC2684CTL           \
1256 BUILD_REAIM                \
1257 BUILD_RT2684D              \
1258 BUILD_SES                  \
1259 BUILD_SIPROXD              \
1260 BUILD_SLACTEST             \
1261 BUILD_SNMP                 \
1262 BUILD_SNTP                 \
1263 BUILD_SOAP                 \
1264 BUILD_SOAP_VER             \
1265 BUILD_SSHD_MIPS_GENKEY     \
1266 BUILD_TOD                  \
1267 BUILD_TR69C                \
1268 BUILD_TR69C_SSL            \
1269 BUILD_UDHCP                \
1270 BUILD_UPNP                 \
1271 BUILD_VCONFIG              \
1272 BUILD_VCONFIG              \
1273 BUILD_VODSL                \
1274 BUILD_WLCTL                \
1275 BUILD_ZEBRA                \
1276 BUSYBOX_DIR                \
1277 CC                         \
1278 CROSS_COMPILE              \
1279 CXX                        \
1280 DEFAULTCFG_DIR             \
1281 FSSRC_DIR                  \
1282 HOSTTOOLS_DIR              \
1283 INC_ADSLDRV_PATH           \
1284 INC_BRCMBOARDPARMS_PATH    \
1285 INC_BRCMCFM_PATH           \
1286 INC_BRCMDRIVER_PRIV_PATH   \
1287 INC_BRCMDRIVER_PUB_PATH    \
1288 INC_BRCMSHARED_PRIV_PATH   \
1289 INC_BRCMSHARED_PUB_PATH    \
1290 INC_FLASH_PATH             \
1291 INC_ENDPOINT_PATH          \
1292 INC_KERNEL_BASE            \
1293 INSTALL_DIR                \
1294 JTAG_KERNEL_DEBUG          \
1295 KERNEL_DIR                 \
1296 LD                         \
1297 LIBCDIR                    \
1298 LIBDIR                     \
1299 LIB_PATH                   \
1300 LINUXDIR                   \
1301 NM                         \
1302 OBJCOPY                    \
1303 OBJDUMP                    \
1304 PROFILE_DIR                \
1305 RANLIB                     \
1306 RUN_NOISE                  \
1307 SSTRIP                     \
1308 STRIP                      \
1309 TARGETS_DIR                \
1310 TOOLCHAIN                  \
1311 USERAPPS_DIR               \
1312 WEB_POPUP                  \
1313 XCHANGE_DIR                \
1314 XCHANGE_DSP_APP_EXTENSION  \
1315 VCOPE_TYPE                 \
1316 VCOPE_BOARD                \
1317 VCOPE_LINE_NUMBER          \
1318