xref: /rk3399_rockchip-uboot/Makefile (revision a9da2b41079d230db3a5641625311983f85ce1fb)
1#
2# (C) Copyright 2000-2008
3# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4#
5# See file CREDITS for list of people who contributed to this
6# project.
7#
8# This program is free software; you can redistribute it and/or
9# modify it under the terms of the GNU General Public License as
10# published by the Free Software Foundatio; either version 2 of
11# the License, or (at your option) any later version.
12#
13# This program is distributed in the hope that it will be useful,
14# but WITHOUT ANY WARRANTY; without even the implied warranty of
15# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	See the
16# GNU General Public License for more details.
17#
18# You should have received a copy of the GNU General Public License
19# along with this program; if not, write to the Free Software
20# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21# MA 02111-1307 USA
22#
23
24VERSION = 1
25PATCHLEVEL = 3
26SUBLEVEL = 2
27EXTRAVERSION =
28U_BOOT_VERSION = $(VERSION).$(PATCHLEVEL).$(SUBLEVEL)$(EXTRAVERSION)
29VERSION_FILE = $(obj)include/version_autogenerated.h
30
31HOSTARCH := $(shell uname -m | \
32	sed -e s/i.86/i386/ \
33	    -e s/sun4u/sparc64/ \
34	    -e s/arm.*/arm/ \
35	    -e s/sa110/arm/ \
36	    -e s/powerpc/ppc/ \
37	    -e s/ppc64/ppc/ \
38	    -e s/macppc/ppc/)
39
40HOSTOS := $(shell uname -s | tr '[:upper:]' '[:lower:]' | \
41	    sed -e 's/\(cygwin\).*/cygwin/')
42
43export	HOSTARCH HOSTOS
44
45# Deal with colliding definitions from tcsh etc.
46VENDOR=
47
48#########################################################################
49# Allow for silent builds
50ifeq (,$(findstring s,$(MAKEFLAGS)))
51XECHO = echo
52else
53XECHO = :
54endif
55
56#########################################################################
57#
58# U-boot build supports producing a object files to the separate external
59# directory. Two use cases are supported:
60#
61# 1) Add O= to the make command line
62# 'make O=/tmp/build all'
63#
64# 2) Set environement variable BUILD_DIR to point to the desired location
65# 'export BUILD_DIR=/tmp/build'
66# 'make'
67#
68# The second approach can also be used with a MAKEALL script
69# 'export BUILD_DIR=/tmp/build'
70# './MAKEALL'
71#
72# Command line 'O=' setting overrides BUILD_DIR environent variable.
73#
74# When none of the above methods is used the local build is performed and
75# the object files are placed in the source directory.
76#
77
78ifdef O
79ifeq ("$(origin O)", "command line")
80BUILD_DIR := $(O)
81endif
82endif
83
84ifneq ($(BUILD_DIR),)
85saved-output := $(BUILD_DIR)
86
87# Attempt to create a output directory.
88$(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR})
89
90# Verify if it was successful.
91BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd)
92$(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist))
93endif # ifneq ($(BUILD_DIR),)
94
95OBJTREE		:= $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR))
96SRCTREE		:= $(CURDIR)
97TOPDIR		:= $(SRCTREE)
98LNDIR		:= $(OBJTREE)
99export	TOPDIR SRCTREE OBJTREE
100
101MKCONFIG	:= $(SRCTREE)/mkconfig
102export MKCONFIG
103
104ifneq ($(OBJTREE),$(SRCTREE))
105REMOTE_BUILD	:= 1
106export REMOTE_BUILD
107endif
108
109# $(obj) and (src) are defined in config.mk but here in main Makefile
110# we also need them before config.mk is included which is the case for
111# some targets like unconfig, clean, clobber, distclean, etc.
112ifneq ($(OBJTREE),$(SRCTREE))
113obj := $(OBJTREE)/
114src := $(SRCTREE)/
115else
116obj :=
117src :=
118endif
119export obj src
120
121# Make sure CDPATH settings don't interfere
122unexport CDPATH
123
124#########################################################################
125
126ifeq ($(obj)include/config.mk,$(wildcard $(obj)include/config.mk))
127
128# load ARCH, BOARD, and CPU configuration
129include $(obj)include/config.mk
130export	ARCH CPU BOARD VENDOR SOC
131
132ifndef CROSS_COMPILE
133ifeq ($(HOSTARCH),$(ARCH))
134CROSS_COMPILE =
135else
136ifeq ($(ARCH),ppc)
137CROSS_COMPILE = ppc_8xx-
138endif
139ifeq ($(ARCH),arm)
140CROSS_COMPILE = arm-linux-
141endif
142ifeq ($(ARCH),i386)
143CROSS_COMPILE = i386-linux-
144endif
145ifeq ($(ARCH),mips)
146CROSS_COMPILE = mips_4KC-
147endif
148ifeq ($(ARCH),nios)
149CROSS_COMPILE = nios-elf-
150endif
151ifeq ($(ARCH),nios2)
152CROSS_COMPILE = nios2-elf-
153endif
154ifeq ($(ARCH),m68k)
155CROSS_COMPILE = m68k-elf-
156endif
157ifeq ($(ARCH),microblaze)
158CROSS_COMPILE = mb-
159endif
160ifeq ($(ARCH),blackfin)
161CROSS_COMPILE = bfin-uclinux-
162endif
163ifeq ($(ARCH),avr32)
164CROSS_COMPILE = avr32-linux-
165endif
166ifeq ($(ARCH),sh)
167CROSS_COMPILE = sh4-linux-
168endif
169ifeq ($(ARCH),sparc)
170CROSS_COMPILE = sparc-elf-
171endif	# sparc
172endif	# HOSTARCH,ARCH
173endif	# CROSS_COMPILE
174
175export	CROSS_COMPILE
176
177# load other configuration
178include $(TOPDIR)/config.mk
179
180#########################################################################
181# U-Boot objects....order is important (i.e. start must be first)
182
183OBJS  = cpu/$(CPU)/start.o
184ifeq ($(CPU),i386)
185OBJS += cpu/$(CPU)/start16.o
186OBJS += cpu/$(CPU)/reset.o
187endif
188ifeq ($(CPU),ppc4xx)
189OBJS += cpu/$(CPU)/resetvec.o
190endif
191ifeq ($(CPU),mpc85xx)
192OBJS += cpu/$(CPU)/resetvec.o
193endif
194
195OBJS := $(addprefix $(obj),$(OBJS))
196
197LIBS  = lib_generic/libgeneric.a
198LIBS += $(shell if [ -f board/$(VENDOR)/common/Makefile ]; then echo \
199	"board/$(VENDOR)/common/lib$(VENDOR).a"; fi)
200LIBS += board/$(BOARDDIR)/lib$(BOARD).a
201LIBS += cpu/$(CPU)/lib$(CPU).a
202ifdef SOC
203LIBS += cpu/$(CPU)/$(SOC)/lib$(SOC).a
204endif
205ifeq ($(CPU),ixp)
206LIBS += cpu/ixp/npe/libnpe.a
207endif
208LIBS += lib_$(ARCH)/lib$(ARCH).a
209LIBS += fs/cramfs/libcramfs.a fs/fat/libfat.a fs/fdos/libfdos.a fs/jffs2/libjffs2.a \
210	fs/reiserfs/libreiserfs.a fs/ext2/libext2fs.a
211LIBS += net/libnet.a
212LIBS += disk/libdisk.a
213LIBS += drivers/bios_emulator/libatibiosemu.a
214LIBS += drivers/block/libblock.a
215LIBS += drivers/dma/libdma.a
216LIBS += drivers/hwmon/libhwmon.a
217LIBS += drivers/i2c/libi2c.a
218LIBS += drivers/input/libinput.a
219LIBS += drivers/misc/libmisc.a
220LIBS += drivers/mtd/libmtd.a
221LIBS += drivers/mtd/nand/libnand.a
222LIBS += drivers/mtd/nand_legacy/libnand_legacy.a
223LIBS += drivers/mtd/onenand/libonenand.a
224LIBS += drivers/net/libnet.a
225LIBS += drivers/net/sk98lin/libsk98lin.a
226LIBS += drivers/pci/libpci.a
227LIBS += drivers/pcmcia/libpcmcia.a
228LIBS += drivers/spi/libspi.a
229ifeq ($(CPU),mpc83xx)
230LIBS += drivers/qe/qe.a
231endif
232ifeq ($(CPU),mpc85xx)
233LIBS += drivers/qe/qe.a
234endif
235LIBS += drivers/rtc/librtc.a
236LIBS += drivers/serial/libserial.a
237LIBS += drivers/usb/libusb.a
238LIBS += drivers/video/libvideo.a
239LIBS += post/libpost.a post/drivers/libpostdrivers.a
240LIBS += $(shell if [ -d post/lib_$(ARCH) ]; then echo \
241	"post/lib_$(ARCH)/libpost$(ARCH).a"; fi)
242LIBS += $(shell if [ -d post/lib_$(ARCH)/fpu ]; then echo \
243	"post/lib_$(ARCH)/fpu/libpost$(ARCH)fpu.a"; fi)
244LIBS += $(shell if [ -d post/cpu/$(CPU) ]; then echo \
245	"post/cpu/$(CPU)/libpost$(CPU).a"; fi)
246LIBS += $(shell if [ -d post/board/$(BOARDDIR) ]; then echo \
247	"post/board/$(BOARDDIR)/libpost$(BOARD).a"; fi)
248LIBS += common/libcommon.a
249LIBS += libfdt/libfdt.a
250LIBS += api/libapi.a
251
252LIBS := $(addprefix $(obj),$(LIBS))
253.PHONY : $(LIBS) $(VERSION_FILE)
254
255# Add GCC lib
256PLATFORM_LIBS += -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc
257
258# The "tools" are needed early, so put this first
259# Don't include stuff already done in $(LIBS)
260SUBDIRS	= tools \
261	  examples \
262	  api_examples
263
264.PHONY : $(SUBDIRS)
265
266ifeq ($(CONFIG_NAND_U_BOOT),y)
267NAND_SPL = nand_spl
268U_BOOT_NAND = $(obj)u-boot-nand.bin
269endif
270
271ifeq ($(CONFIG_ONENAND_U_BOOT),y)
272ONENAND_IPL = onenand_ipl
273U_BOOT_ONENAND = $(obj)u-boot-onenand.bin
274endif
275
276__OBJS := $(subst $(obj),,$(OBJS))
277__LIBS := $(subst $(obj),,$(LIBS))
278
279#########################################################################
280#########################################################################
281
282ALL += $(obj)u-boot.srec $(obj)u-boot.bin $(obj)System.map $(U_BOOT_NAND) $(U_BOOT_ONENAND)
283ifeq ($(ARCH),blackfin)
284ALL += $(obj)u-boot.ldr
285endif
286
287all:		$(ALL)
288
289$(obj)u-boot.hex:	$(obj)u-boot
290		$(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@
291
292$(obj)u-boot.srec:	$(obj)u-boot
293		$(OBJCOPY) ${OBJCFLAGS} -O srec $< $@
294
295$(obj)u-boot.bin:	$(obj)u-boot
296		$(OBJCOPY) ${OBJCFLAGS} -O binary $< $@
297
298$(obj)u-boot.ldr:	$(obj)u-boot
299		$(LDR) -T $(CONFIG_BFIN_CPU) -f -c $@ $< $(LDR_FLAGS)
300
301$(obj)u-boot.ldr.hex:	$(obj)u-boot.ldr
302		$(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@ -I binary
303
304$(obj)u-boot.ldr.srec:	$(obj)u-boot.ldr
305		$(OBJCOPY) ${OBJCFLAGS} -O srec $< $@ -I binary
306
307$(obj)u-boot.img:	$(obj)u-boot.bin
308		./tools/mkimage -A $(ARCH) -T firmware -C none \
309		-a $(TEXT_BASE) -e 0 \
310		-n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' $(VERSION_FILE) | \
311			sed -e 's/"[	 ]*$$/ for $(BOARD) board"/') \
312		-d $< $@
313
314$(obj)u-boot.sha1:	$(obj)u-boot.bin
315		$(obj)tools/ubsha1 $(obj)u-boot.bin
316
317$(obj)u-boot.dis:	$(obj)u-boot
318		$(OBJDUMP) -d $< > $@
319
320$(obj)u-boot:		depend $(SUBDIRS) $(OBJS) $(LIBS) $(LDSCRIPT)
321		UNDEF_SYM=`$(OBJDUMP) -x $(LIBS) |sed  -n -e 's/.*\($(SYM_PREFIX)__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\
322		cd $(LNDIR) && $(LD) $(LDFLAGS) $$UNDEF_SYM $(__OBJS) \
323			--start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \
324			-Map u-boot.map -o u-boot
325
326$(OBJS):	depend $(obj)include/autoconf.mk
327		$(MAKE) -C cpu/$(CPU) $(if $(REMOTE_BUILD),$@,$(notdir $@))
328
329$(LIBS):	depend $(obj)include/autoconf.mk
330		$(MAKE) -C $(dir $(subst $(obj),,$@))
331
332$(SUBDIRS):	depend $(obj)include/autoconf.mk
333		$(MAKE) -C $@ all
334
335$(LDSCRIPT):	depend $(obj)include/autoconf.mk
336		$(MAKE) -C $(dir $@) $(notdir $@)
337
338$(NAND_SPL):	$(VERSION_FILE)	$(obj)include/autoconf.mk
339		$(MAKE) -C nand_spl/board/$(BOARDDIR) all
340
341$(U_BOOT_NAND):	$(NAND_SPL) $(obj)u-boot.bin $(obj)include/autoconf.mk
342		cat $(obj)nand_spl/u-boot-spl-16k.bin $(obj)u-boot.bin > $(obj)u-boot-nand.bin
343
344$(ONENAND_IPL):	$(VERSION_FILE)	$(obj)include/autoconf.mk
345		$(MAKE) -C $(obj)onenand_ipl/board/$(BOARDDIR) all
346
347$(U_BOOT_ONENAND):	$(ONENAND_IPL) $(obj)u-boot.bin $(obj)include/autoconf.mk
348		$(MAKE) -C $(obj)onenand_ipl/board/$(BOARDDIR) all
349		cat $(obj)onenand_ipl/onenand-ipl-2k.bin $(obj)u-boot.bin > $(obj)u-boot-onenand.bin
350		cat $(obj)onenand_ipl/onenand-ipl-4k.bin $(obj)u-boot.bin > $(obj)u-boot-flexonenand.bin
351
352$(VERSION_FILE):
353		@( echo -n "#define U_BOOT_VERSION \"U-Boot " ; \
354		echo -n "$(U_BOOT_VERSION)" ; \
355		echo -n $(shell $(CONFIG_SHELL) $(TOPDIR)/tools/setlocalversion \
356			 $(TOPDIR)) ; \
357		echo "\"" ) > $@.tmp
358		@cmp -s $@ $@.tmp && rm -f $@.tmp || mv -f $@.tmp $@
359
360gdbtools:
361		$(MAKE) -C tools/gdb all || exit 1
362
363updater:
364		$(MAKE) -C tools/updater all || exit 1
365
366env:
367		$(MAKE) -C tools/env all MTD_VERSION=${MTD_VERSION} || exit 1
368
369depend dep:	$(VERSION_FILE)
370		for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir _depend ; done
371
372TAG_SUBDIRS += include
373TAG_SUBDIRS += lib_generic board/$(BOARDDIR)
374TAG_SUBDIRS += cpu/$(CPU)
375TAG_SUBDIRS += lib_$(ARCH)
376TAG_SUBDIRS += fs/cramfs
377TAG_SUBDIRS += fs/fat
378TAG_SUBDIRS += fs/fdos
379TAG_SUBDIRS += fs/jffs2
380TAG_SUBDIRS += net
381TAG_SUBDIRS += disk
382TAG_SUBDIRS += common
383TAG_SUBDIRS += drivers/bios_emulator
384TAG_SUBDIRS += drivers/block
385TAG_SUBDIRS += drivers/hwmon
386TAG_SUBDIRS += drivers/i2c
387TAG_SUBDIRS += drivers/input
388TAG_SUBDIRS += drivers/misc
389TAG_SUBDIRS += drivers/mtd
390TAG_SUBDIRS += drivers/mtd/nand
391TAG_SUBDIRS += drivers/mtd/nand_legacy
392TAG_SUBDIRS += drivers/mtd/onenand
393TAG_SUBDIRS += drivers/net
394TAG_SUBDIRS += drivers/net/sk98lin
395TAG_SUBDIRS += drivers/pci
396TAG_SUBDIRS += drivers/pcmcia
397TAG_SUBDIRS += drivers/qe
398TAG_SUBDIRS += drivers/rtc
399TAG_SUBDIRS += drivers/serial
400TAG_SUBDIRS += drivers/spi
401TAG_SUBDIRS += drivers/usb
402TAG_SUBDIRS += drivers/video
403
404tags ctags:
405		ctags -w -o $(obj)ctags `find $(SUBDIRS) $(TAG_SUBDIRS) \
406						-name '*.[ch]' -print`
407
408etags:
409		etags -a -o $(obj)etags `find $(SUBDIRS) $(TAG_SUBDIRS) \
410						-name '*.[ch]' -print`
411cscope:
412		find $(SUBDIRS) $(TAG_SUBDIRS) -name '*.[ch]' -print \
413						> cscope.files
414		cscope -b -q -k
415
416$(obj)System.map:	$(obj)u-boot
417		@$(NM) $< | \
418		grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \
419		sort > $(obj)System.map
420
421#
422# Auto-generate the autoconf.mk file (which is included by all makefiles)
423#
424# This target actually generates 2 files; autoconf.mk and autoconf.mk.dep.
425# the dep file is only include in this top level makefile to determine when
426# to regenerate the autoconf.mk file.
427$(obj)include/autoconf.mk: $(obj)include/config.h $(VERSION_FILE)
428	@$(XECHO) Generating include/autoconf.mk ; \
429	set -e ; \
430	: Generate the dependancies ; \
431	$(CC) -M $(HOST_CFLAGS) $(CPPFLAGS) -MQ $@ include/common.h > $@.dep ; \
432	: Extract the config macros ; \
433	$(CPP) $(CFLAGS) -dM include/common.h | sed -n -f tools/scripts/define2mk.sed > $@
434
435sinclude $(obj)include/autoconf.mk.dep
436
437#########################################################################
438else	# !config.mk
439all $(obj)u-boot.hex $(obj)u-boot.srec $(obj)u-boot.bin \
440$(obj)u-boot.img $(obj)u-boot.dis $(obj)u-boot \
441$(SUBDIRS) $(VERSION_FILE) gdbtools updater env depend \
442dep tags ctags etags cscope $(obj)System.map:
443	@echo "System not configured - see README" >&2
444	@ exit 1
445endif	# config.mk
446
447.PHONY : CHANGELOG
448CHANGELOG:
449	git log --no-merges U-Boot-1_1_5.. | \
450	unexpand -a | sed -e 's/\s\s*$$//' > $@
451
452#########################################################################
453
454unconfig:
455	@rm -f $(obj)include/config.h $(obj)include/config.mk \
456		$(obj)board/*/config.tmp $(obj)board/*/*/config.tmp \
457		$(obj)include/autoconf.mk $(obj)include/autoconf.mk.dep
458
459#========================================================================
460# PowerPC
461#========================================================================
462
463#########################################################################
464## MPC5xx Systems
465#########################################################################
466
467canmb_config:	unconfig
468	@$(MKCONFIG) -a canmb ppc mpc5xxx canmb
469
470cmi_mpc5xx_config:	unconfig
471	@$(MKCONFIG) $(@:_config=) ppc mpc5xx cmi
472
473PATI_config:		unconfig
474	@$(MKCONFIG) $(@:_config=) ppc mpc5xx pati mpl
475
476#########################################################################
477## MPC5xxx Systems
478#########################################################################
479
480aev_config: unconfig
481	@$(MKCONFIG) -a aev ppc mpc5xxx tqm5200
482
483BC3450_config:	unconfig
484	@$(MKCONFIG) -a BC3450 ppc mpc5xxx bc3450
485
486cpci5200_config:  unconfig
487	@$(MKCONFIG) -a cpci5200  ppc mpc5xxx cpci5200 esd
488
489hmi1001_config:	unconfig
490	@$(MKCONFIG) hmi1001 ppc mpc5xxx hmi1001
491
492Lite5200_config				\
493Lite5200_LOWBOOT_config			\
494Lite5200_LOWBOOT08_config		\
495icecube_5200_config			\
496icecube_5200_LOWBOOT_config		\
497icecube_5200_LOWBOOT08_config		\
498icecube_5200_DDR_config			\
499icecube_5200_DDR_LOWBOOT_config		\
500icecube_5200_DDR_LOWBOOT08_config	\
501icecube_5100_config:			unconfig
502	@mkdir -p $(obj)include
503	@mkdir -p $(obj)board/icecube
504	@[ -z "$(findstring LOWBOOT_,$@)" ] || \
505		{ if [ "$(findstring DDR,$@)" ] ; \
506			then echo "TEXT_BASE = 0xFF800000" >$(obj)board/icecube/config.tmp ; \
507			else echo "TEXT_BASE = 0xFF000000" >$(obj)board/icecube/config.tmp ; \
508		  fi ; \
509		  $(XECHO) "... with LOWBOOT configuration" ; \
510		}
511	@[ -z "$(findstring LOWBOOT08,$@)" ] || \
512		{ echo "TEXT_BASE = 0xFF800000" >$(obj)board/icecube/config.tmp ; \
513		  echo "... with 8 MB flash only" ; \
514		  $(XECHO) "... with LOWBOOT configuration" ; \
515		}
516	@[ -z "$(findstring DDR,$@)" ] || \
517		{ echo "#define CONFIG_MPC5200_DDR"	>>$(obj)include/config.h ; \
518		  $(XECHO) "... DDR memory revision" ; \
519		}
520	@[ -z "$(findstring 5200,$@)" ] || \
521		{ echo "#define CONFIG_MPC5200"		>>$(obj)include/config.h ; \
522		  $(XECHO) "... with MPC5200 processor" ; \
523		}
524	@[ -z "$(findstring 5100,$@)" ] || \
525		{ echo "#define CONFIG_MGT5100"		>>$(obj)include/config.h ; \
526		  $(XECHO) "... with MGT5100 processor" ; \
527		}
528	@$(MKCONFIG) -a IceCube ppc mpc5xxx icecube
529
530jupiter_config:	unconfig
531	@$(MKCONFIG) jupiter ppc mpc5xxx jupiter
532
533v38b_config: unconfig
534	@$(MKCONFIG) -a v38b ppc mpc5xxx v38b
535
536inka4x0_config:	unconfig
537	@$(MKCONFIG) inka4x0 ppc mpc5xxx inka4x0
538
539lite5200b_config	\
540lite5200b_PM_config	\
541lite5200b_LOWBOOT_config:	unconfig
542	@mkdir -p $(obj)include
543	@mkdir -p $(obj)board/icecube
544	@ echo "#define CONFIG_MPC5200_DDR"	>>$(obj)include/config.h
545	@ $(XECHO) "... DDR memory revision"
546	@ echo "#define CONFIG_MPC5200"		>>$(obj)include/config.h
547	@ echo "#define CONFIG_LITE5200B"	>>$(obj)include/config.h
548	@[ -z "$(findstring _PM_,$@)" ] || \
549		{ echo "#define CONFIG_LITE5200B_PM"	>>$(obj)include/config.h ; \
550		  $(XECHO) "... with power management (low-power mode) support" ; \
551		}
552	@[ -z "$(findstring LOWBOOT_,$@)" ] || \
553		{ echo "TEXT_BASE = 0xFF000000" >$(obj)board/icecube/config.tmp ; \
554		  $(XECHO) "... with LOWBOOT configuration" ; \
555		}
556	@ $(XECHO) "... with MPC5200B processor"
557	@$(MKCONFIG) -a IceCube  ppc mpc5xxx icecube
558
559mcc200_config	\
560mcc200_SDRAM_config	\
561mcc200_highboot_config	\
562mcc200_COM12_config	\
563mcc200_COM12_SDRAM_config	\
564mcc200_COM12_highboot_config	\
565mcc200_COM12_highboot_SDRAM_config	\
566mcc200_highboot_SDRAM_config	\
567prs200_config	\
568prs200_DDR_config	\
569prs200_highboot_config	\
570prs200_highboot_DDR_config:	unconfig
571	@mkdir -p $(obj)include
572	@mkdir -p $(obj)board/mcc200
573	@[ -n "$(findstring highboot,$@)" ] || \
574		{ $(XECHO) "... with lowboot configuration" ; \
575		}
576	@[ -z "$(findstring highboot,$@)" ] || \
577		{ echo "TEXT_BASE = 0xFFF00000" >$(obj)board/mcc200/config.tmp ; \
578		  $(XECHO) "... with highboot configuration" ; \
579		}
580	@[ -n "$(findstring _SDRAM,$@)" ] || \
581		{ if [ -n "$(findstring mcc200,$@)" ]; \
582		  then \
583			$(XECHO) "... with DDR" ; \
584		  else \
585			if [ -n "$(findstring _DDR,$@)" ];\
586			then \
587				$(XECHO) "... with DDR" ; \
588			else \
589				echo "#define CONFIG_MCC200_SDRAM" >>$(obj)include/config.h ;\
590				$(XECHO) "... with SDRAM" ; \
591			fi; \
592		  fi; \
593		}
594	@[ -z "$(findstring _SDRAM,$@)" ] || \
595		{ echo "#define CONFIG_MCC200_SDRAM"	>>$(obj)include/config.h ; \
596		  $(XECHO) "... with SDRAM" ; \
597		}
598	@[ -z "$(findstring COM12,$@)" ] || \
599		{ echo "#define CONFIG_CONSOLE_COM12"	>>$(obj)include/config.h ; \
600		  $(XECHO) "... with console on COM12" ; \
601		}
602	@[ -z "$(findstring prs200,$@)" ] || \
603		{ echo "#define CONFIG_PRS200"	>>$(obj)include/config.h ;\
604		}
605	@$(MKCONFIG) -n $@ -a mcc200 ppc mpc5xxx mcc200
606
607mecp5200_config:  unconfig
608	@$(MKCONFIG) mecp5200  ppc mpc5xxx mecp5200 esd
609
610munices_config:	unconfig
611	@$(MKCONFIG) munices ppc mpc5xxx munices
612
613o2dnt_config:	unconfig
614	@$(MKCONFIG) o2dnt ppc mpc5xxx o2dnt
615
616pf5200_config:	unconfig
617	@$(MKCONFIG) pf5200  ppc mpc5xxx pf5200 esd
618
619PM520_config \
620PM520_DDR_config \
621PM520_ROMBOOT_config \
622PM520_ROMBOOT_DDR_config:	unconfig
623	@mkdir -p $(obj)include
624	@[ -z "$(findstring DDR,$@)" ] || \
625		{ echo "#define CONFIG_MPC5200_DDR"	>>$(obj)include/config.h ; \
626		  $(XECHO) "... DDR memory revision" ; \
627		}
628	@[ -z "$(findstring ROMBOOT,$@)" ] || \
629		{ echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
630		  $(XECHO) "... booting from 8-bit flash" ; \
631		}
632	@$(MKCONFIG) -a PM520 ppc mpc5xxx pm520
633
634smmaco4_config: unconfig
635	@$(MKCONFIG) -a smmaco4 ppc mpc5xxx tqm5200
636
637cm5200_config:	unconfig
638	@$(MKCONFIG) -a cm5200 ppc mpc5xxx cm5200
639
640spieval_config:	unconfig
641	@$(MKCONFIG) -a spieval ppc mpc5xxx tqm5200
642
643TB5200_B_config \
644TB5200_config:	unconfig
645	@mkdir -p $(obj)include
646	@[ -z "$(findstring _B,$@)" ] || \
647		{ echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
648		  $(XECHO) "... with MPC5200B processor" ; \
649		}
650	@$(MKCONFIG) -n $@ -a TB5200 ppc mpc5xxx tqm5200
651
652MINI5200_config	\
653EVAL5200_config	\
654TOP5200_config:	unconfig
655	@mkdir -p $(obj)include
656	@ echo "#define CONFIG_$(@:_config=) 1"	>$(obj)include/config.h
657	@$(MKCONFIG) -n $@ -a TOP5200 ppc mpc5xxx top5200 emk
658
659Total5100_config		\
660Total5200_config		\
661Total5200_lowboot_config	\
662Total5200_Rev2_config		\
663Total5200_Rev2_lowboot_config:	unconfig
664	@mkdir -p $(obj)include
665	@mkdir -p $(obj)board/total5200
666	@[ -z "$(findstring 5100,$@)" ] || \
667		{ echo "#define CONFIG_MGT5100"		>>$(obj)include/config.h ; \
668		  $(XECHO) "... with MGT5100 processor" ; \
669		}
670	@[ -z "$(findstring 5200,$@)" ] || \
671		{ echo "#define CONFIG_MPC5200"		>>$(obj)include/config.h ; \
672		  $(XECHO) "... with MPC5200 processor" ; \
673		}
674	@[ -n "$(findstring Rev,$@)" ] || \
675		{ echo "#define CONFIG_TOTAL5200_REV 1"	>>$(obj)include/config.h ; \
676		  $(XECHO) "... revision 1 board" ; \
677		}
678	@[ -z "$(findstring Rev2_,$@)" ] || \
679		{ echo "#define CONFIG_TOTAL5200_REV 2"	>>$(obj)include/config.h ; \
680		  $(XECHO) "... revision 2 board" ; \
681		}
682	@[ -z "$(findstring lowboot_,$@)" ] || \
683		{ echo "TEXT_BASE = 0xFE000000" >$(obj)board/total5200/config.tmp ; \
684		  $(XECHO) "... with lowboot configuration" ; \
685		}
686	@$(MKCONFIG) -a Total5200 ppc mpc5xxx total5200
687
688cam5200_config \
689cam5200_niosflash_config \
690fo300_config \
691MiniFAP_config \
692TQM5200S_config \
693TQM5200S_HIGHBOOT_config \
694TQM5200_B_config \
695TQM5200_B_HIGHBOOT_config \
696TQM5200_config	\
697TQM5200_STK100_config:	unconfig
698	@mkdir -p $(obj)include
699	@mkdir -p $(obj)board/tqm5200
700	@[ -z "$(findstring cam5200,$@)" ] || \
701		{ echo "#define CONFIG_CAM5200"	>>$(obj)include/config.h ; \
702		  echo "#define CONFIG_TQM5200S"	>>$(obj)include/config.h ; \
703		  echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
704		  $(XECHO) "... TQM5200S on Cam5200" ; \
705		}
706	@[ -z "$(findstring niosflash,$@)" ] || \
707		{ echo "#define CONFIG_CAM5200_NIOSFLASH"	>>$(obj)include/config.h ; \
708		  $(XECHO) "... with NIOS flash driver" ; \
709		}
710	@[ -z "$(findstring fo300,$@)" ] || \
711		{ echo "#define CONFIG_FO300"	>>$(obj)include/config.h ; \
712		  $(XECHO) "... TQM5200 on FO300" ; \
713		}
714	@[ -z "$(findstring MiniFAP,$@)" ] || \
715		{ echo "#define CONFIG_MINIFAP"	>>$(obj)include/config.h ; \
716		  $(XECHO) "... TQM5200_AC on MiniFAP" ; \
717		}
718	@[ -z "$(findstring STK100,$@)" ] || \
719		{ echo "#define CONFIG_STK52XX_REV100"	>>$(obj)include/config.h ; \
720		  $(XECHO) "... on a STK52XX.100 base board" ; \
721		}
722	@[ -z "$(findstring TQM5200_B,$@)" ] || \
723		{ echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
724		}
725	@[ -z "$(findstring TQM5200S,$@)" ] || \
726		{ echo "#define CONFIG_TQM5200S"	>>$(obj)include/config.h ; \
727		  echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
728		}
729	@[ -z "$(findstring HIGHBOOT,$@)" ] || \
730		{ echo "TEXT_BASE = 0xFFF00000" >$(obj)board/tqm5200/config.tmp ; \
731		}
732	@$(MKCONFIG) -n $@ -a TQM5200 ppc mpc5xxx tqm5200
733uc101_config:		unconfig
734	@$(MKCONFIG) uc101 ppc mpc5xxx uc101
735motionpro_config:	unconfig
736	@$(MKCONFIG) motionpro ppc mpc5xxx motionpro
737
738
739#########################################################################
740## MPC512x Systems
741#########################################################################
742ads5121_config \
743ads5121_PCI_config \
744	:		 unconfig
745	@mkdir -p $(obj)include
746	@if [ "$(findstring _PCI_,$@)" ] ; then \
747		echo "#define CONFIG_PCI"  >>$(obj)include/config.h ; \
748		$(XECHO) "... with PCI enabled" ; \
749	fi
750	@$(MKCONFIG) -a ads5121 ppc mpc512x ads5121
751
752
753#########################################################################
754## MPC8xx Systems
755#########################################################################
756
757Adder_config	\
758Adder87x_config \
759AdderII_config	\
760	:		unconfig
761	@mkdir -p $(obj)include
762	$(if $(findstring AdderII,$@), \
763	@echo "#define CONFIG_MPC852T" > $(obj)include/config.h)
764	@$(MKCONFIG) -a Adder ppc mpc8xx adder
765
766AdderUSB_config:	unconfig
767	@$(MKCONFIG) -a AdderUSB ppc mpc8xx adder
768
769ADS860_config	  \
770FADS823_config	  \
771FADS850SAR_config \
772MPC86xADS_config  \
773MPC885ADS_config  \
774FADS860T_config:	unconfig
775	@$(MKCONFIG) $(@:_config=) ppc mpc8xx fads
776
777AMX860_config	:	unconfig
778	@$(MKCONFIG) $(@:_config=) ppc mpc8xx amx860 westel
779
780c2mon_config:		unconfig
781	@$(MKCONFIG) $(@:_config=) ppc mpc8xx c2mon
782
783CCM_config:		unconfig
784	@$(MKCONFIG) $(@:_config=) ppc mpc8xx CCM siemens
785
786cogent_mpc8xx_config:	unconfig
787	@$(MKCONFIG) $(@:_config=) ppc mpc8xx cogent
788
789ELPT860_config:		unconfig
790	@$(MKCONFIG) $(@:_config=) ppc mpc8xx elpt860 LEOX
791
792EP88x_config:		unconfig
793	@$(MKCONFIG) $(@:_config=) ppc mpc8xx ep88x
794
795ESTEEM192E_config:	unconfig
796	@$(MKCONFIG) $(@:_config=) ppc mpc8xx esteem192e
797
798ETX094_config	:	unconfig
799	@$(MKCONFIG) $(@:_config=) ppc mpc8xx etx094
800
801FLAGADM_config:	unconfig
802	@$(MKCONFIG) $(@:_config=) ppc mpc8xx flagadm
803
804xtract_GEN860T = $(subst _SC,,$(subst _config,,$1))
805
806GEN860T_SC_config	\
807GEN860T_config: unconfig
808	@mkdir -p $(obj)include
809	@[ -z "$(findstring _SC,$@)" ] || \
810		{ echo "#define CONFIG_SC" >>$(obj)include/config.h ; \
811		  $(XECHO) "With reduced H/W feature set (SC)..." ; \
812		}
813	@$(MKCONFIG) -a $(call xtract_GEN860T,$@) ppc mpc8xx gen860t
814
815GENIETV_config:	unconfig
816	@$(MKCONFIG) $(@:_config=) ppc mpc8xx genietv
817
818GTH_config:	unconfig
819	@$(MKCONFIG) $(@:_config=) ppc mpc8xx gth
820
821hermes_config	:	unconfig
822	@$(MKCONFIG) $(@:_config=) ppc mpc8xx hermes
823
824HMI10_config	:	unconfig
825	@$(MKCONFIG) $(@:_config=) ppc mpc8xx tqm8xx
826
827IAD210_config: unconfig
828	@$(MKCONFIG) $(@:_config=) ppc mpc8xx IAD210 siemens
829
830xtract_ICU862 = $(subst _100MHz,,$(subst _config,,$1))
831
832ICU862_100MHz_config	\
833ICU862_config: unconfig
834	@mkdir -p $(obj)include
835	@[ -z "$(findstring _100MHz,$@)" ] || \
836		{ echo "#define CONFIG_100MHz"	>>$(obj)include/config.h ; \
837		  $(XECHO) "... with 100MHz system clock" ; \
838		}
839	@$(MKCONFIG) -a $(call xtract_ICU862,$@) ppc mpc8xx icu862
840
841IP860_config	:	unconfig
842	@$(MKCONFIG) $(@:_config=) ppc mpc8xx ip860
843
844IVML24_256_config \
845IVML24_128_config \
846IVML24_config:	unconfig
847	@mkdir -p $(obj)include
848	@[ -z "$(findstring IVML24_config,$@)" ] || \
849		 { echo "#define CONFIG_IVML24_16M"	>>$(obj)include/config.h ; \
850		 }
851	@[ -z "$(findstring IVML24_128_config,$@)" ] || \
852		 { echo "#define CONFIG_IVML24_32M"	>>$(obj)include/config.h ; \
853		 }
854	@[ -z "$(findstring IVML24_256_config,$@)" ] || \
855		 { echo "#define CONFIG_IVML24_64M"	>>$(obj)include/config.h ; \
856		 }
857	@$(MKCONFIG) -a IVML24 ppc mpc8xx ivm
858
859IVMS8_256_config \
860IVMS8_128_config \
861IVMS8_config:	unconfig
862	@mkdir -p $(obj)include
863	@[ -z "$(findstring IVMS8_config,$@)" ] || \
864		 { echo "#define CONFIG_IVMS8_16M"	>>$(obj)include/config.h ; \
865		 }
866	@[ -z "$(findstring IVMS8_128_config,$@)" ] || \
867		 { echo "#define CONFIG_IVMS8_32M"	>>$(obj)include/config.h ; \
868		 }
869	@[ -z "$(findstring IVMS8_256_config,$@)" ] || \
870		 { echo "#define CONFIG_IVMS8_64M"	>>$(obj)include/config.h ; \
871		 }
872	@$(MKCONFIG) -a IVMS8 ppc mpc8xx ivm
873
874KUP4K_config	:	unconfig
875	@$(MKCONFIG) $(@:_config=) ppc mpc8xx kup4k kup
876
877KUP4X_config	:	unconfig
878	@$(MKCONFIG) $(@:_config=) ppc mpc8xx kup4x kup
879
880LANTEC_config	:	unconfig
881	@$(MKCONFIG) $(@:_config=) ppc mpc8xx lantec
882
883lwmon_config:		unconfig
884	@$(MKCONFIG) $(@:_config=) ppc mpc8xx lwmon
885
886MBX_config	\
887MBX860T_config:	unconfig
888	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mbx8xx
889
890mgsuvd_config:		unconfig
891	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mgsuvd
892
893MHPC_config:		unconfig
894	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mhpc eltec
895
896MVS1_config :		unconfig
897	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mvs1
898
899xtract_NETVIA = $(subst _V2,,$(subst _config,,$1))
900
901NETVIA_V2_config \
902NETVIA_config:		unconfig
903	@mkdir -p $(obj)include
904	@[ -z "$(findstring NETVIA_config,$@)" ] || \
905		 { echo "#define CONFIG_NETVIA_VERSION 1" >>$(obj)include/config.h ; \
906		  $(XECHO) "... Version 1" ; \
907		 }
908	@[ -z "$(findstring NETVIA_V2_config,$@)" ] || \
909		 { echo "#define CONFIG_NETVIA_VERSION 2" >>$(obj)include/config.h ; \
910		  $(XECHO) "... Version 2" ; \
911		 }
912	@$(MKCONFIG) -a $(call xtract_NETVIA,$@) ppc mpc8xx netvia
913
914xtract_NETPHONE = $(subst _V2,,$(subst _config,,$1))
915
916NETPHONE_V2_config \
917NETPHONE_config:	unconfig
918	@mkdir -p $(obj)include
919	@[ -z "$(findstring NETPHONE_config,$@)" ] || \
920		 { echo "#define CONFIG_NETPHONE_VERSION 1" >>$(obj)include/config.h ; \
921		 }
922	@[ -z "$(findstring NETPHONE_V2_config,$@)" ] || \
923		 { echo "#define CONFIG_NETPHONE_VERSION 2" >>$(obj)include/config.h ; \
924		 }
925	@$(MKCONFIG) -a $(call xtract_NETPHONE,$@) ppc mpc8xx netphone
926
927xtract_NETTA = $(subst _SWAPHOOK,,$(subst _6412,,$(subst _ISDN,,$(subst _config,,$1))))
928
929NETTA_ISDN_6412_SWAPHOOK_config \
930NETTA_ISDN_SWAPHOOK_config \
931NETTA_6412_SWAPHOOK_config \
932NETTA_SWAPHOOK_config \
933NETTA_ISDN_6412_config \
934NETTA_ISDN_config \
935NETTA_6412_config \
936NETTA_config:		unconfig
937	@mkdir -p $(obj)include
938	@[ -z "$(findstring ISDN_,$@)" ] || \
939		 { echo "#define CONFIG_NETTA_ISDN 1" >>$(obj)include/config.h ; \
940		 }
941	@[ -n "$(findstring ISDN_,$@)" ] || \
942		 { echo "#undef CONFIG_NETTA_ISDN" >>$(obj)include/config.h ; \
943		 }
944	@[ -z "$(findstring 6412_,$@)" ] || \
945		 { echo "#define CONFIG_NETTA_6412 1" >>$(obj)include/config.h ; \
946		 }
947	@[ -n "$(findstring 6412_,$@)" ] || \
948		 { echo "#undef CONFIG_NETTA_6412" >>$(obj)include/config.h ; \
949		 }
950	@[ -z "$(findstring SWAPHOOK_,$@)" ] || \
951		 { echo "#define CONFIG_NETTA_SWAPHOOK 1" >>$(obj)include/config.h ; \
952		 }
953	@[ -n "$(findstring SWAPHOOK_,$@)" ] || \
954		 { echo "#undef CONFIG_NETTA_SWAPHOOK" >>$(obj)include/config.h ; \
955		 }
956	@$(MKCONFIG) -a $(call xtract_NETTA,$@) ppc mpc8xx netta
957
958xtract_NETTA2 = $(subst _V2,,$(subst _config,,$1))
959
960NETTA2_V2_config \
961NETTA2_config:		unconfig
962	@mkdir -p $(obj)include
963	@[ -z "$(findstring NETTA2_config,$@)" ] || \
964		 { echo "#define CONFIG_NETTA2_VERSION 1" >>$(obj)include/config.h ; \
965		 }
966	@[ -z "$(findstring NETTA2_V2_config,$@)" ] || \
967		 { echo "#define CONFIG_NETTA2_VERSION 2" >>$(obj)include/config.h ; \
968		 }
969	@$(MKCONFIG) -a $(call xtract_NETTA2,$@) ppc mpc8xx netta2
970
971NC650_Rev1_config \
972NC650_Rev2_config \
973CP850_config:	unconfig
974	@mkdir -p $(obj)include
975	@[ -z "$(findstring CP850,$@)" ] || \
976		 { echo "#define CONFIG_CP850 1" >>$(obj)include/config.h ; \
977		   echo "#define CONFIG_IDS852_REV2 1" >>$(obj)include/config.h ; \
978		 }
979	@[ -z "$(findstring Rev1,$@)" ] || \
980		 { echo "#define CONFIG_IDS852_REV1 1" >>$(obj)include/config.h ; \
981		 }
982	@[ -z "$(findstring Rev2,$@)" ] || \
983		 { echo "#define CONFIG_IDS852_REV2 1" >>$(obj)include/config.h ; \
984		 }
985	@$(MKCONFIG) -a NC650 ppc mpc8xx nc650
986
987NX823_config:		unconfig
988	@$(MKCONFIG) $(@:_config=) ppc mpc8xx nx823
989
990pcu_e_config:		unconfig
991	@$(MKCONFIG) $(@:_config=) ppc mpc8xx pcu_e siemens
992
993QS850_config:	unconfig
994	@$(MKCONFIG) $(@:_config=) ppc mpc8xx qs850 snmc
995
996QS823_config:	unconfig
997	@$(MKCONFIG) $(@:_config=) ppc mpc8xx qs850 snmc
998
999QS860T_config:	unconfig
1000	@$(MKCONFIG) $(@:_config=) ppc mpc8xx qs860t snmc
1001
1002quantum_config:	unconfig
1003	@$(MKCONFIG) $(@:_config=) ppc mpc8xx quantum
1004
1005R360MPI_config:	unconfig
1006	@$(MKCONFIG) $(@:_config=) ppc mpc8xx r360mpi
1007
1008RBC823_config:	unconfig
1009	@$(MKCONFIG) $(@:_config=) ppc mpc8xx rbc823
1010
1011RPXClassic_config:	unconfig
1012	@$(MKCONFIG) $(@:_config=) ppc mpc8xx RPXClassic
1013
1014RPXlite_config:		unconfig
1015	@$(MKCONFIG) $(@:_config=) ppc mpc8xx RPXlite
1016
1017RPXlite_DW_64_config		\
1018RPXlite_DW_LCD_config		\
1019RPXlite_DW_64_LCD_config	\
1020RPXlite_DW_NVRAM_config		\
1021RPXlite_DW_NVRAM_64_config	\
1022RPXlite_DW_NVRAM_LCD_config	\
1023RPXlite_DW_NVRAM_64_LCD_config	\
1024RPXlite_DW_config:	unconfig
1025	@mkdir -p $(obj)include
1026	@[ -z "$(findstring _64,$@)" ] || \
1027		{ echo "#define RPXlite_64MHz"		>>$(obj)include/config.h ; \
1028		  $(XECHO) "... with 64MHz system clock ..."; \
1029		}
1030	@[ -z "$(findstring _LCD,$@)" ] || \
1031		{ echo "#define CONFIG_LCD"		>>$(obj)include/config.h ; \
1032		  echo "#define CONFIG_NEC_NL6448BC20"	>>$(obj)include/config.h ; \
1033		  $(XECHO) "... with LCD display ..."; \
1034		}
1035	@[ -z "$(findstring _NVRAM,$@)" ] || \
1036		{ echo "#define  CFG_ENV_IS_IN_NVRAM"	>>$(obj)include/config.h ; \
1037		  $(XECHO) "... with ENV in NVRAM ..."; \
1038		}
1039	@$(MKCONFIG) -a RPXlite_DW ppc mpc8xx RPXlite_dw
1040
1041rmu_config:	unconfig
1042	@$(MKCONFIG) $(@:_config=) ppc mpc8xx rmu
1043
1044RRvision_config:	unconfig
1045	@$(MKCONFIG) $(@:_config=) ppc mpc8xx RRvision
1046
1047RRvision_LCD_config:	unconfig
1048	@mkdir -p $(obj)include
1049	@echo "#define CONFIG_LCD" >$(obj)include/config.h
1050	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>$(obj)include/config.h
1051	@$(MKCONFIG) -a RRvision ppc mpc8xx RRvision
1052
1053SM850_config	:	unconfig
1054	@$(MKCONFIG) $(@:_config=) ppc mpc8xx tqm8xx
1055
1056spc1920_config:		unconfig
1057	@$(MKCONFIG) $(@:_config=) ppc mpc8xx spc1920
1058
1059SPD823TS_config:	unconfig
1060	@$(MKCONFIG) $(@:_config=) ppc mpc8xx spd8xx
1061
1062stxxtc_config:	unconfig
1063	@$(MKCONFIG) $(@:_config=) ppc mpc8xx stxxtc
1064
1065svm_sc8xx_config:	unconfig
1066	@$(MKCONFIG) $(@:_config=) ppc mpc8xx svm_sc8xx
1067
1068SXNI855T_config:	unconfig
1069	@$(MKCONFIG) $(@:_config=) ppc mpc8xx sixnet
1070
1071# EMK MPC8xx based modules
1072TOP860_config:		unconfig
1073	@$(MKCONFIG) $(@:_config=) ppc mpc8xx top860 emk
1074
1075# Play some tricks for configuration selection
1076# Only 855 and 860 boards may come with FEC
1077# and only 823 boards may have LCD support
1078xtract_8xx = $(subst _LCD,,$(subst _config,,$1))
1079
1080FPS850L_config		\
1081FPS860L_config		\
1082NSCU_config		\
1083TQM823L_config		\
1084TQM823L_LCD_config	\
1085TQM850L_config		\
1086TQM855L_config		\
1087TQM860L_config		\
1088TQM862L_config		\
1089TQM823M_config		\
1090TQM850M_config		\
1091TQM855M_config		\
1092TQM860M_config		\
1093TQM862M_config		\
1094TQM866M_config		\
1095TQM885D_config		\
1096TK885D_config		\
1097virtlab2_config:	unconfig
1098	@mkdir -p $(obj)include
1099	@[ -z "$(findstring _LCD,$@)" ] || \
1100		{ echo "#define CONFIG_LCD"		>>$(obj)include/config.h ; \
1101		  echo "#define CONFIG_NEC_NL6448BC20"	>>$(obj)include/config.h ; \
1102		  $(XECHO) "... with LCD display" ; \
1103		}
1104	@$(MKCONFIG) -a $(call xtract_8xx,$@) ppc mpc8xx tqm8xx
1105
1106TTTech_config:	unconfig
1107	@mkdir -p $(obj)include
1108	@echo "#define CONFIG_LCD" >$(obj)include/config.h
1109	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>$(obj)include/config.h
1110	@$(MKCONFIG) -a TQM823L ppc mpc8xx tqm8xx
1111
1112uc100_config	:	unconfig
1113	@$(MKCONFIG) $(@:_config=) ppc mpc8xx uc100
1114
1115v37_config:	unconfig
1116	@mkdir -p $(obj)include
1117	@echo "#define CONFIG_LCD" >$(obj)include/config.h
1118	@echo "#define CONFIG_SHARP_LQ084V1DG21" >>$(obj)include/config.h
1119	@$(MKCONFIG) $(@:_config=) ppc mpc8xx v37
1120
1121wtk_config:	unconfig
1122	@mkdir -p $(obj)include
1123	@echo "#define CONFIG_LCD" >$(obj)include/config.h
1124	@echo "#define CONFIG_SHARP_LQ065T9DR51U" >>$(obj)include/config.h
1125	@$(MKCONFIG) -a TQM823L ppc mpc8xx tqm8xx
1126
1127#########################################################################
1128## PPC4xx Systems
1129#########################################################################
1130xtract_4xx = $(subst _25,,$(subst _33,,$(subst _BA,,$(subst _ME,,$(subst _HI,,$(subst _config,,$1))))))
1131
1132acadia_config:	unconfig
1133	@$(MKCONFIG) $(@:_config=) ppc ppc4xx acadia amcc
1134
1135acadia_nand_config:	unconfig
1136	@mkdir -p $(obj)include $(obj)board/amcc/acadia
1137	@mkdir -p $(obj)nand_spl/board/amcc/acadia
1138	@echo "#define CONFIG_NAND_U_BOOT" > $(obj)include/config.h
1139	@$(MKCONFIG) -n $@ -a acadia ppc ppc4xx acadia amcc
1140	@echo "TEXT_BASE = 0x01000000" > $(obj)board/amcc/acadia/config.tmp
1141	@echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
1142
1143ADCIOP_config:	unconfig
1144	@$(MKCONFIG) $(@:_config=) ppc ppc4xx adciop esd
1145
1146alpr_config:	unconfig
1147	@$(MKCONFIG) $(@:_config=) ppc ppc4xx alpr prodrive
1148
1149AP1000_config:unconfig
1150	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ap1000 amirix
1151
1152APC405_config:	unconfig
1153	@$(MKCONFIG) $(@:_config=) ppc ppc4xx apc405 esd
1154
1155AR405_config:	unconfig
1156	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ar405 esd
1157
1158ASH405_config:	unconfig
1159	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ash405 esd
1160
1161bamboo_config:	unconfig
1162	@$(MKCONFIG) $(@:_config=) ppc ppc4xx bamboo amcc
1163
1164bamboo_nand_config:	unconfig
1165	@mkdir -p $(obj)include $(obj)board/amcc/bamboo
1166	@mkdir -p $(obj)nand_spl/board/amcc/bamboo
1167	@echo "#define CONFIG_NAND_U_BOOT" > $(obj)include/config.h
1168	@$(MKCONFIG) -n $@ -a bamboo ppc ppc4xx bamboo amcc
1169	@echo "TEXT_BASE = 0x01000000" > $(obj)board/amcc/bamboo/config.tmp
1170	@echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
1171
1172bubinga_config:	unconfig
1173	@$(MKCONFIG) $(@:_config=) ppc ppc4xx bubinga amcc
1174
1175CANBT_config:	unconfig
1176	@$(MKCONFIG) $(@:_config=) ppc ppc4xx canbt esd
1177
1178# Canyonlands & Glacier use different U-Boot images
1179canyonlands_config \
1180glacier_config:	unconfig
1181	@mkdir -p $(obj)include
1182	@echo "#define CONFIG_$$(echo $(subst ,,$(@:_config=)) | \
1183		tr '[:lower:]' '[:upper:]')" >$(obj)include/config.h
1184	@$(MKCONFIG) -n $@ -a canyonlands ppc ppc4xx canyonlands amcc
1185
1186canyonlands_nand_config:	unconfig
1187	@mkdir -p $(obj)include $(obj)board/amcc/canyonlands
1188	@mkdir -p $(obj)nand_spl/board/amcc/canyonlands
1189	@echo "#define CONFIG_NAND_U_BOOT" > $(obj)include/config.h
1190	@$(MKCONFIG) -n $@ -a canyonlands ppc ppc4xx canyonlands amcc
1191	@echo "TEXT_BASE = 0x01000000" > $(obj)board/amcc/canyonlands/config.tmp
1192	@echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
1193
1194CATcenter_config	\
1195CATcenter_25_config	\
1196CATcenter_33_config:	unconfig
1197	@mkdir -p $(obj)include
1198	@ echo "/* CATcenter uses PPChameleon Model ME */"  > $(obj)include/config.h
1199	@ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 1" >> $(obj)include/config.h
1200	@[ -z "$(findstring _25,$@)" ] || \
1201		{ echo "#define CONFIG_PPCHAMELEON_CLK_25" >> $(obj)include/config.h ; \
1202		  $(XECHO) "SysClk = 25MHz" ; \
1203		}
1204	@[ -z "$(findstring _33,$@)" ] || \
1205		{ echo "#define CONFIG_PPCHAMELEON_CLK_33" >> $(obj)include/config.h ; \
1206		  $(XECHO) "SysClk = 33MHz" ; \
1207		}
1208	@$(MKCONFIG) -a $(call xtract_4xx,$@) ppc ppc4xx PPChameleonEVB dave
1209
1210CPCI2DP_config:	unconfig
1211	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpci2dp esd
1212
1213CPCI405_config	\
1214CPCI4052_config	\
1215CPCI405DT_config	\
1216CPCI405AB_config:	unconfig
1217	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpci405 esd
1218	@echo "BOARD_REVISION = $(@:_config=)"	>> $(obj)include/config.mk
1219
1220CPCIISER4_config:	unconfig
1221	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpciiser4 esd
1222
1223CRAYL1_config:	unconfig
1224	@$(MKCONFIG) $(@:_config=) ppc ppc4xx L1 cray
1225
1226csb272_config:	unconfig
1227	@$(MKCONFIG) $(@:_config=) ppc ppc4xx csb272
1228
1229csb472_config:	unconfig
1230	@$(MKCONFIG) $(@:_config=) ppc ppc4xx csb472
1231
1232DASA_SIM_config: unconfig
1233	@$(MKCONFIG) $(@:_config=) ppc ppc4xx dasa_sim esd
1234
1235DP405_config:	unconfig
1236	@$(MKCONFIG) $(@:_config=) ppc ppc4xx dp405 esd
1237
1238DU405_config:	unconfig
1239	@$(MKCONFIG) $(@:_config=) ppc ppc4xx du405 esd
1240
1241DU440_config:	unconfig
1242	@$(MKCONFIG) $(@:_config=) ppc ppc4xx du440 esd
1243
1244ebony_config:	unconfig
1245	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ebony amcc
1246
1247ERIC_config:	unconfig
1248	@$(MKCONFIG) $(@:_config=) ppc ppc4xx eric
1249
1250EXBITGEN_config:	unconfig
1251	@$(MKCONFIG) $(@:_config=) ppc ppc4xx exbitgen
1252
1253G2000_config:	unconfig
1254	@$(MKCONFIG) $(@:_config=) ppc ppc4xx g2000
1255
1256hcu4_config:	unconfig
1257	@mkdir -p $(obj)board/netstal/common
1258	@$(MKCONFIG) $(@:_config=) ppc ppc4xx hcu4 netstal
1259
1260hcu5_config:	unconfig
1261	@mkdir -p $(obj)board/netstal/common
1262	@$(MKCONFIG) $(@:_config=) ppc ppc4xx hcu5 netstal
1263
1264HH405_config:	unconfig
1265	@$(MKCONFIG) $(@:_config=) ppc ppc4xx hh405 esd
1266
1267HUB405_config:	unconfig
1268	@$(MKCONFIG) $(@:_config=) ppc ppc4xx hub405 esd
1269
1270JSE_config:	unconfig
1271	@$(MKCONFIG) $(@:_config=) ppc ppc4xx jse
1272
1273KAREF_config: unconfig
1274	@$(MKCONFIG) $(@:_config=) ppc ppc4xx karef sandburst
1275
1276katmai_config:	unconfig
1277	@$(MKCONFIG) $(@:_config=) ppc ppc4xx katmai amcc
1278
1279# Kilauea & Haleakala images are identical (recognized via PVR)
1280kilauea_config \
1281haleakala_config: unconfig
1282	@$(MKCONFIG) -n $@ -a kilauea ppc ppc4xx kilauea amcc
1283
1284kilauea_nand_config \
1285haleakala_nand_config: unconfig
1286	@mkdir -p $(obj)include $(obj)board/amcc/kilauea
1287	@mkdir -p $(obj)nand_spl/board/amcc/kilauea
1288	@echo "#define CONFIG_NAND_U_BOOT" > $(obj)include/config.h
1289	@$(MKCONFIG) -n $@ -a kilauea ppc ppc4xx kilauea amcc
1290	@echo "TEXT_BASE = 0x01000000" > $(obj)board/amcc/kilauea/config.tmp
1291	@echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
1292
1293korat_config:	unconfig
1294	@$(MKCONFIG) $(@:_config=) ppc ppc4xx korat
1295
1296luan_config:	unconfig
1297	@$(MKCONFIG) $(@:_config=) ppc ppc4xx luan amcc
1298
1299lwmon5_config:	unconfig
1300	@$(MKCONFIG) $(@:_config=) ppc ppc4xx lwmon5
1301
1302makalu_config:	unconfig
1303	@$(MKCONFIG) $(@:_config=) ppc ppc4xx makalu amcc
1304
1305mcu25_config:  unconfig
1306	@mkdir -p $(obj)board/netstal/common
1307	@$(MKCONFIG) $(@:_config=) ppc ppc4xx mcu25 netstal
1308
1309METROBOX_config: unconfig
1310	@$(MKCONFIG) $(@:_config=) ppc ppc4xx metrobox sandburst
1311
1312MIP405_config:	unconfig
1313	@$(MKCONFIG) $(@:_config=) ppc ppc4xx mip405 mpl
1314
1315MIP405T_config:	unconfig
1316	@mkdir -p $(obj)include
1317	@echo "#define CONFIG_MIP405T" >$(obj)include/config.h
1318	@$(XECHO) "Enable subset config for MIP405T"
1319	@$(MKCONFIG) -a MIP405 ppc ppc4xx mip405 mpl
1320
1321ML2_config:	unconfig
1322	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ml2
1323
1324ml300_config:	unconfig
1325	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ml300 xilinx
1326
1327ocotea_config:	unconfig
1328	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ocotea amcc
1329
1330OCRTC_config		\
1331ORSG_config:	unconfig
1332	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ocrtc esd
1333
1334p3p440_config:	unconfig
1335	@$(MKCONFIG) $(@:_config=) ppc ppc4xx p3p440 prodrive
1336
1337PCI405_config:	unconfig
1338	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pci405 esd
1339
1340pcs440ep_config:	unconfig
1341	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pcs440ep
1342
1343PIP405_config:	unconfig
1344	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pip405 mpl
1345
1346PLU405_config:	unconfig
1347	@$(MKCONFIG) $(@:_config=) ppc ppc4xx plu405 esd
1348
1349PMC405_config:	unconfig
1350	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pmc405 esd
1351
1352PMC440_config:	unconfig
1353	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pmc440 esd
1354
1355PPChameleonEVB_config		\
1356PPChameleonEVB_BA_25_config	\
1357PPChameleonEVB_ME_25_config	\
1358PPChameleonEVB_HI_25_config	\
1359PPChameleonEVB_BA_33_config	\
1360PPChameleonEVB_ME_33_config	\
1361PPChameleonEVB_HI_33_config:	unconfig
1362	@mkdir -p $(obj)include
1363	@[ -z "$(findstring EVB_BA,$@)" ] || \
1364		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 0" >>$(obj)include/config.h ; \
1365		  $(XECHO) "... BASIC model" ; \
1366		}
1367	@[ -z "$(findstring EVB_ME,$@)" ] || \
1368		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 1" >>$(obj)include/config.h ; \
1369		  $(XECHO) "... MEDIUM model" ; \
1370		}
1371	@[ -z "$(findstring EVB_HI,$@)" ] || \
1372		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 2" >>$(obj)include/config.h ; \
1373		  $(XECHO) "... HIGH-END model" ; \
1374		}
1375	@[ -z "$(findstring _25,$@)" ] || \
1376		{ echo "#define CONFIG_PPCHAMELEON_CLK_25" >>$(obj)include/config.h ; \
1377		  $(XECHO) "SysClk = 25MHz" ; \
1378		}
1379	@[ -z "$(findstring _33,$@)" ] || \
1380		{ echo "#define CONFIG_PPCHAMELEON_CLK_33" >>$(obj)include/config.h ; \
1381		  $(XECHO) "SysClk = 33MHz" ; \
1382		}
1383	@$(MKCONFIG) -a $(call xtract_4xx,$@) ppc ppc4xx PPChameleonEVB dave
1384
1385sbc405_config:	unconfig
1386	@$(MKCONFIG) $(@:_config=) ppc ppc4xx sbc405
1387
1388sequoia_config \
1389rainier_config: unconfig
1390	@mkdir -p $(obj)include
1391	@echo "#define CONFIG_$$(echo $(subst ,,$(@:_config=)) | \
1392		tr '[:lower:]' '[:upper:]')" >$(obj)include/config.h
1393	@$(MKCONFIG) -n $@ -a sequoia ppc ppc4xx sequoia amcc
1394
1395sequoia_nand_config \
1396rainier_nand_config: unconfig
1397	@mkdir -p $(obj)include $(obj)board/amcc/sequoia
1398	@mkdir -p $(obj)nand_spl/board/amcc/sequoia
1399	@echo "#define CONFIG_NAND_U_BOOT" > $(obj)include/config.h
1400	@echo "#define CONFIG_$$(echo $(subst ,,$(@:_config=)) | \
1401		tr '[:lower:]' '[:upper:]')" >> $(obj)include/config.h
1402	@$(MKCONFIG) -n $@ -a sequoia ppc ppc4xx sequoia amcc
1403	@echo "TEXT_BASE = 0x01000000" > $(obj)board/amcc/sequoia/config.tmp
1404	@echo "CONFIG_NAND_U_BOOT = y" >> $(obj)include/config.mk
1405
1406sc3_config:unconfig
1407	@$(MKCONFIG) $(@:_config=) ppc ppc4xx sc3
1408
1409taihu_config:	unconfig
1410	@$(MKCONFIG) $(@:_config=) ppc ppc4xx taihu amcc
1411
1412taishan_config:	unconfig
1413	@$(MKCONFIG) $(@:_config=) ppc ppc4xx taishan amcc
1414
1415VOH405_config:	unconfig
1416	@$(MKCONFIG) $(@:_config=) ppc ppc4xx voh405 esd
1417
1418VOM405_config:	unconfig
1419	@$(MKCONFIG) $(@:_config=) ppc ppc4xx vom405 esd
1420
1421CMS700_config:	unconfig
1422	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cms700 esd
1423
1424W7OLMC_config	\
1425W7OLMG_config: unconfig
1426	@$(MKCONFIG) $(@:_config=) ppc ppc4xx w7o
1427
1428# Walnut & Sycamore images are identical (recognized via PVR)
1429walnut_config \
1430sycamore_config: unconfig
1431	@$(MKCONFIG) -n $@ -a walnut ppc ppc4xx walnut amcc
1432
1433WUH405_config:	unconfig
1434	@$(MKCONFIG) $(@:_config=) ppc ppc4xx wuh405 esd
1435
1436XPEDITE1K_config:	unconfig
1437	@$(MKCONFIG) $(@:_config=) ppc ppc4xx xpedite1k
1438
1439yosemite_config \
1440yellowstone_config: unconfig
1441	@mkdir -p $(obj)include
1442	@echo "#define CONFIG_$$(echo $(subst ,,$(@:_config=)) | \
1443		tr '[:lower:]' '[:upper:]')" >$(obj)include/config.h
1444	@$(MKCONFIG) -n $@ -a yosemite ppc ppc4xx yosemite amcc
1445
1446yucca_config:	unconfig
1447	@$(MKCONFIG) $(@:_config=) ppc ppc4xx yucca amcc
1448
1449zeus_config:	unconfig
1450	@$(MKCONFIG) $(@:_config=) ppc ppc4xx zeus
1451
1452#########################################################################
1453## MPC8220 Systems
1454#########################################################################
1455
1456Alaska8220_config	\
1457Yukon8220_config:	unconfig
1458	@$(MKCONFIG) $(@:_config=) ppc mpc8220 alaska
1459
1460sorcery_config:		unconfig
1461	@$(MKCONFIG) $(@:_config=) ppc mpc8220 sorcery
1462
1463#########################################################################
1464## MPC824x Systems
1465#########################################################################
1466xtract_82xx = $(subst _BIGFLASH,,$(subst _ROMBOOT,,$(subst _L2,,$(subst _266MHz,,$(subst _300MHz,,$(subst _config,,$1))))))
1467
1468A3000_config: unconfig
1469	@$(MKCONFIG) $(@:_config=) ppc mpc824x a3000
1470
1471barco_config: unconfig
1472	@$(MKCONFIG) $(@:_config=) ppc mpc824x barco
1473
1474BMW_config: unconfig
1475	@$(MKCONFIG) $(@:_config=) ppc mpc824x bmw
1476
1477CPC45_config	\
1478CPC45_ROMBOOT_config:	unconfig
1479	@$(MKCONFIG) $(call xtract_82xx,$@) ppc mpc824x cpc45
1480	@cd $(obj)include ;				\
1481	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1482		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
1483		$(XECHO) "... booting from 8-bit flash" ; \
1484	else \
1485		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
1486		$(XECHO) "... booting from 64-bit flash" ; \
1487	fi; \
1488	echo "export CONFIG_BOOT_ROM" >> config.mk;
1489
1490CU824_config: unconfig
1491	@$(MKCONFIG) $(@:_config=) ppc mpc824x cu824
1492
1493debris_config: unconfig
1494	@$(MKCONFIG) $(@:_config=) ppc mpc824x debris etin
1495
1496eXalion_config: unconfig
1497	@$(MKCONFIG) $(@:_config=) ppc mpc824x eXalion
1498
1499HIDDEN_DRAGON_config: unconfig
1500	@$(MKCONFIG) $(@:_config=) ppc mpc824x hidden_dragon
1501
1502kvme080_config: unconfig
1503	@$(MKCONFIG) $(@:_config=) ppc mpc824x kvme080 etin
1504
1505# HDLAN is broken ATM. Should be fixed as soon as hardware is available and as
1506# time permits.
1507#linkstation_HDLAN_config \
1508# Remove this line when HDLAN is fixed
1509linkstation_HGLAN_config: unconfig
1510	@mkdir -p $(obj)include
1511	@case $@ in \
1512		*HGLAN*) echo "#define CONFIG_HGLAN 1" >$(obj)include/config.h; ;; \
1513		*HDLAN*) echo "#define CONFIG_HLAN 1" >$(obj)include/config.h; ;; \
1514	esac
1515	@$(MKCONFIG) -n $@ -a linkstation ppc mpc824x linkstation
1516
1517MOUSSE_config: unconfig
1518	@$(MKCONFIG) $(@:_config=) ppc mpc824x mousse
1519
1520MUSENKI_config: unconfig
1521	@$(MKCONFIG) $(@:_config=) ppc mpc824x musenki
1522
1523MVBLUE_config:	unconfig
1524	@$(MKCONFIG) $(@:_config=) ppc mpc824x mvblue
1525
1526OXC_config: unconfig
1527	@$(MKCONFIG) $(@:_config=) ppc mpc824x oxc
1528
1529PN62_config: unconfig
1530	@$(MKCONFIG) $(@:_config=) ppc mpc824x pn62
1531
1532Sandpoint8240_config: unconfig
1533	@$(MKCONFIG) $(@:_config=) ppc mpc824x sandpoint
1534
1535Sandpoint8245_config: unconfig
1536	@$(MKCONFIG) $(@:_config=) ppc mpc824x sandpoint
1537
1538sbc8240_config: unconfig
1539	@$(MKCONFIG) $(@:_config=) ppc mpc824x sbc8240
1540
1541SL8245_config: unconfig
1542	@$(MKCONFIG) $(@:_config=) ppc mpc824x sl8245
1543
1544utx8245_config: unconfig
1545	@$(MKCONFIG) $(@:_config=) ppc mpc824x utx8245
1546
1547#########################################################################
1548## MPC8260 Systems
1549#########################################################################
1550
1551atc_config:	unconfig
1552	@$(MKCONFIG) $(@:_config=) ppc mpc8260 atc
1553
1554cogent_mpc8260_config:	unconfig
1555	@$(MKCONFIG) $(@:_config=) ppc mpc8260 cogent
1556
1557CPU86_config	\
1558CPU86_ROMBOOT_config: unconfig
1559	@$(MKCONFIG) $(call xtract_82xx,$@) ppc mpc8260 cpu86
1560	@cd $(obj)include ;				\
1561	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1562		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
1563		$(XECHO) "... booting from 8-bit flash" ; \
1564	else \
1565		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
1566		$(XECHO) "... booting from 64-bit flash" ; \
1567	fi; \
1568	echo "export CONFIG_BOOT_ROM" >> config.mk;
1569
1570CPU87_config	\
1571CPU87_ROMBOOT_config: unconfig
1572	@$(MKCONFIG) $(call xtract_82xx,$@) ppc mpc8260 cpu87
1573	@cd $(obj)include ;				\
1574	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1575		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
1576		$(XECHO) "... booting from 8-bit flash" ; \
1577	else \
1578		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
1579		$(XECHO) "... booting from 64-bit flash" ; \
1580	fi; \
1581	echo "export CONFIG_BOOT_ROM" >> config.mk;
1582
1583ep8248_config	\
1584ep8248E_config	:	unconfig
1585	@$(MKCONFIG) ep8248 ppc mpc8260 ep8248
1586
1587ep8260_config:	unconfig
1588	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ep8260
1589
1590ep82xxm_config:	unconfig
1591	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ep82xxm
1592
1593gw8260_config:	unconfig
1594	@$(MKCONFIG) $(@:_config=) ppc mpc8260 gw8260
1595
1596hymod_config:	unconfig
1597	@$(MKCONFIG) $(@:_config=) ppc mpc8260 hymod
1598
1599IDS8247_config:	unconfig
1600	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ids8247
1601
1602IPHASE4539_config:	unconfig
1603	@$(MKCONFIG) $(@:_config=) ppc mpc8260 iphase4539
1604
1605ISPAN_config		\
1606ISPAN_REVB_config:	unconfig
1607	@mkdir -p $(obj)include
1608	@if [ "$(findstring _REVB_,$@)" ] ; then \
1609		echo "#define CFG_REV_B" > $(obj)include/config.h ; \
1610	fi
1611	@$(MKCONFIG) -a ISPAN ppc mpc8260 ispan
1612
1613mgcoge_config	:	unconfig
1614	@$(MKCONFIG) mgcoge ppc mpc8260 mgcoge
1615
1616MPC8260ADS_config	\
1617MPC8260ADS_lowboot_config	\
1618MPC8260ADS_33MHz_config	\
1619MPC8260ADS_33MHz_lowboot_config	\
1620MPC8260ADS_40MHz_config	\
1621MPC8260ADS_40MHz_lowboot_config	\
1622MPC8272ADS_config	\
1623MPC8272ADS_lowboot_config	\
1624PQ2FADS_config		\
1625PQ2FADS_lowboot_config		\
1626PQ2FADS-VR_config	\
1627PQ2FADS-VR_lowboot_config	\
1628PQ2FADS-ZU_config	\
1629PQ2FADS-ZU_lowboot_config	\
1630PQ2FADS-ZU_66MHz_config	\
1631PQ2FADS-ZU_66MHz_lowboot_config	\
1632	:		unconfig
1633	@mkdir -p $(obj)include
1634	@mkdir -p $(obj)board/freescale/mpc8260ads
1635	$(if $(findstring PQ2FADS,$@), \
1636	@echo "#define CONFIG_ADSTYPE CFG_PQ2FADS" > $(obj)include/config.h, \
1637	@echo "#define CONFIG_ADSTYPE CFG_"$(subst MPC,,$(word 1,$(subst _, ,$@))) > $(obj)include/config.h)
1638	$(if $(findstring MHz,$@), \
1639	@echo "#define CONFIG_8260_CLKIN" $(subst MHz,,$(word 2,$(subst _, ,$@)))"000000" >> $(obj)include/config.h, \
1640	$(if $(findstring VR,$@), \
1641	@echo "#define CONFIG_8260_CLKIN 66000000" >> $(obj)include/config.h))
1642	@[ -z "$(findstring lowboot_,$@)" ] || \
1643		{ echo "TEXT_BASE = 0xFF800000" >$(obj)board/freescale/mpc8260ads/config.tmp ; \
1644		  $(XECHO) "... with lowboot configuration" ; \
1645		}
1646	@$(MKCONFIG) -a MPC8260ADS ppc mpc8260 mpc8260ads freescale
1647
1648MPC8266ADS_config:	unconfig
1649	@$(MKCONFIG) $(@:_config=) ppc mpc8260 mpc8266ads freescale
1650
1651# PM825/PM826 default configuration:  small (= 8 MB) Flash / boot from 64-bit flash
1652PM825_config	\
1653PM825_ROMBOOT_config	\
1654PM825_BIGFLASH_config	\
1655PM825_ROMBOOT_BIGFLASH_config	\
1656PM826_config	\
1657PM826_ROMBOOT_config	\
1658PM826_BIGFLASH_config	\
1659PM826_ROMBOOT_BIGFLASH_config:	unconfig
1660	@mkdir -p $(obj)include
1661	@mkdir -p $(obj)board/pm826
1662	@if [ "$(findstring PM825_,$@)" ] ; then \
1663		echo "#define CONFIG_PCI"	>$(obj)include/config.h ; \
1664	else \
1665		>$(obj)include/config.h ; \
1666	fi
1667	@if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1668		$(XECHO) "... booting from 8-bit flash" ; \
1669		echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
1670		echo "TEXT_BASE = 0xFF800000" >$(obj)board/pm826/config.tmp ; \
1671		if [ "$(findstring _BIGFLASH_,$@)" ] ; then \
1672			$(XECHO) "... with 32 MB Flash" ; \
1673			echo "#define CONFIG_FLASH_32MB" >>$(obj)include/config.h ; \
1674		fi; \
1675	else \
1676		$(XECHO) "... booting from 64-bit flash" ; \
1677		if [ "$(findstring _BIGFLASH_,$@)" ] ; then \
1678			$(XECHO) "... with 32 MB Flash" ; \
1679			echo "#define CONFIG_FLASH_32MB" >>$(obj)include/config.h ; \
1680			echo "TEXT_BASE = 0x40000000" >$(obj)board/pm826/config.tmp ; \
1681		else \
1682			echo "TEXT_BASE = 0xFF000000" >$(obj)board/pm826/config.tmp ; \
1683		fi; \
1684	fi
1685	@$(MKCONFIG) -a PM826 ppc mpc8260 pm826
1686
1687PM828_config	\
1688PM828_PCI_config	\
1689PM828_ROMBOOT_config	\
1690PM828_ROMBOOT_PCI_config:	unconfig
1691	@mkdir -p $(obj)include
1692	@mkdir -p $(obj)board/pm826
1693	@if [ "$(findstring _PCI_,$@)" ] ; then \
1694		echo "#define CONFIG_PCI"  >>$(obj)include/config.h ; \
1695		$(XECHO) "... with PCI enabled" ; \
1696	fi
1697	@if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1698		$(XECHO) "... booting from 8-bit flash" ; \
1699		echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
1700		echo "TEXT_BASE = 0xFF800000" >$(obj)board/pm826/config.tmp ; \
1701	fi
1702	@$(MKCONFIG) -a PM828 ppc mpc8260 pm828
1703
1704ppmc8260_config:	unconfig
1705	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ppmc8260
1706
1707Rattler8248_config	\
1708Rattler_config:		unconfig
1709	@mkdir -p $(obj)include
1710	$(if $(findstring 8248,$@), \
1711	@echo "#define CONFIG_MPC8248" > $(obj)include/config.h)
1712	@$(MKCONFIG) -a Rattler ppc mpc8260 rattler
1713
1714RPXsuper_config:	unconfig
1715	@$(MKCONFIG) $(@:_config=) ppc mpc8260 rpxsuper
1716
1717rsdproto_config:	unconfig
1718	@$(MKCONFIG) $(@:_config=) ppc mpc8260 rsdproto
1719
1720sacsng_config:	unconfig
1721	@$(MKCONFIG) $(@:_config=) ppc mpc8260 sacsng
1722
1723sbc8260_config:	unconfig
1724	@$(MKCONFIG) $(@:_config=) ppc mpc8260 sbc8260
1725
1726SCM_config:		unconfig
1727	@$(MKCONFIG) $(@:_config=) ppc mpc8260 SCM siemens
1728
1729TQM8255_AA_config \
1730TQM8260_AA_config \
1731TQM8260_AB_config \
1732TQM8260_AC_config \
1733TQM8260_AD_config \
1734TQM8260_AE_config \
1735TQM8260_AF_config \
1736TQM8260_AG_config \
1737TQM8260_AH_config \
1738TQM8260_AI_config \
1739TQM8265_AA_config:  unconfig
1740	@mkdir -p $(obj)include
1741	@case "$@" in \
1742	TQM8255_AA_config) CTYPE=MPC8255; CFREQ=300; CACHE=no;	BMODE=8260;;  \
1743	TQM8260_AA_config) CTYPE=MPC8260; CFREQ=200; CACHE=no;	BMODE=8260;; \
1744	TQM8260_AB_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes;	BMODE=60x;;  \
1745	TQM8260_AC_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes;	BMODE=60x;;  \
1746	TQM8260_AD_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1747	TQM8260_AE_config) CTYPE=MPC8260; CFREQ=266; CACHE=no;	BMODE=8260;; \
1748	TQM8260_AF_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1749	TQM8260_AG_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=8260;; \
1750	TQM8260_AH_config) CTYPE=MPC8260; CFREQ=300; CACHE=yes;	BMODE=60x;;  \
1751	TQM8260_AI_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1752	TQM8265_AA_config) CTYPE=MPC8265; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1753	esac; \
1754	if [ "$${CTYPE}" != "MPC8260" ] ; then \
1755		echo "#define CONFIG_$${CTYPE}"	>>$(obj)include/config.h ; \
1756	fi; \
1757	echo "#define CONFIG_$${CFREQ}MHz"	>>$(obj)include/config.h ; \
1758	echo "... with $${CFREQ}MHz system clock" ; \
1759	if [ "$${CACHE}" = "yes" ] ; then \
1760		echo "#define CONFIG_L2_CACHE"	>>$(obj)include/config.h ; \
1761		$(XECHO) "... with L2 Cache support" ; \
1762	else \
1763		echo "#undef CONFIG_L2_CACHE"	>>$(obj)include/config.h ; \
1764		$(XECHO) "... without L2 Cache support" ; \
1765	fi; \
1766	if [ "$${BMODE}" = "60x" ] ; then \
1767		echo "#define CONFIG_BUSMODE_60x" >>$(obj)include/config.h ; \
1768		$(XECHO) "... with 60x Bus Mode" ; \
1769	else \
1770		echo "#undef CONFIG_BUSMODE_60x"  >>$(obj)include/config.h ; \
1771		$(XECHO) "... without 60x Bus Mode" ; \
1772	fi
1773	@$(MKCONFIG) -a TQM8260 ppc mpc8260 tqm8260
1774
1775TQM8272_config: unconfig
1776	@$(MKCONFIG) TQM8272 ppc mpc8260 tqm8272
1777
1778VoVPN-GW_66MHz_config	\
1779VoVPN-GW_100MHz_config:		unconfig
1780	@mkdir -p $(obj)include
1781	@echo "#define CONFIG_CLKIN_$(word 2,$(subst _, ,$@))" > $(obj)include/config.h
1782	@$(MKCONFIG) -a VoVPN-GW ppc mpc8260 vovpn-gw funkwerk
1783
1784ZPC1900_config: unconfig
1785	@$(MKCONFIG) $(@:_config=) ppc mpc8260 zpc1900
1786
1787#########################################################################
1788## Coldfire
1789#########################################################################
1790
1791M52277EVB_config:	unconfig
1792	@$(MKCONFIG) -a M52277EVB m68k mcf5227x m52277evb freescale
1793
1794M5235EVB_config \
1795M5235EVB_Flash16_config \
1796M5235EVB_Flash32_config:	unconfig
1797	@case "$@" in \
1798	M5235EVB_config)		FLASH=16;; \
1799	M5235EVB_Flash16_config)	FLASH=16;; \
1800	M5235EVB_Flash32_config)	FLASH=32;; \
1801	esac; \
1802	if [ "$${FLASH}" != "16" ] ; then \
1803		echo "#define NORFLASH_PS32BIT	1" >> $(obj)include/config.h ; \
1804		echo "TEXT_BASE = 0xFFC00000" > $(obj)board/freescale/m5235evb/config.tmp ; \
1805		cp $(obj)board/freescale/m5235evb/u-boot.32 $(obj)board/freescale/m5235evb/u-boot.lds ; \
1806	else \
1807		echo "TEXT_BASE = 0xFFE00000" > $(obj)board/freescale/m5235evb/config.tmp ; \
1808		cp $(obj)board/freescale/m5235evb/u-boot.16 $(obj)board/freescale/m5235evb/u-boot.lds ; \
1809	fi
1810	@$(MKCONFIG) -a M5235EVB m68k mcf523x m5235evb freescale
1811
1812M5249EVB_config :		unconfig
1813	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5249evb freescale
1814
1815M5253EVBE_config :		unconfig
1816	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5253evbe freescale
1817
1818cobra5272_config :		unconfig
1819	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 cobra5272
1820
1821EB+MCF-EV123_config :		unconfig
1822	@mkdir -p $(obj)include
1823	@mkdir -p $(obj)board/BuS/EB+MCF-EV123
1824	@echo "TEXT_BASE = 0xFFE00000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
1825	@$(MKCONFIG) EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
1826
1827EB+MCF-EV123_internal_config :	unconfig
1828	@mkdir -p $(obj)include
1829	@mkdir -p $(obj)board/BuS/EB+MCF-EV123
1830	@echo "TEXT_BASE = 0xF0000000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
1831	@$(MKCONFIG) EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
1832
1833idmr_config :			unconfig
1834	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 idmr
1835
1836M5271EVB_config :		unconfig
1837	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5271evb
1838
1839M5272C3_config :		unconfig
1840	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5272c3
1841
1842M5275EVB_config :		unconfig
1843	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5275evb freescale
1844
1845M5282EVB_config :		unconfig
1846	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5282evb
1847
1848TASREG_config :		unconfig
1849	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 tasreg esd
1850
1851M5329AFEE_config \
1852M5329BFEE_config :	unconfig
1853	@case "$@" in \
1854	M5329AFEE_config)	NAND=0;; \
1855	M5329BFEE_config)	NAND=16;; \
1856	esac; \
1857	if [ "$${NAND}" != "0" ] ; then \
1858		echo "#define NANDFLASH_SIZE	$${NAND}" > $(obj)include/config.h ; \
1859	fi
1860	@$(MKCONFIG) -a M5329EVB m68k mcf532x m5329evb freescale
1861
1862M5373EVB_config :	unconfig
1863	@case "$@" in \
1864	M5373EVB_config)	NAND=16;; \
1865	esac; \
1866	if [ "$${NAND}" != "0" ] ; then \
1867		echo "#define NANDFLASH_SIZE	$${NAND}" > $(obj)include/config.h ; \
1868	fi
1869	@$(MKCONFIG) -a M5373EVB m68k mcf532x m5373evb freescale
1870
1871M54455EVB_config \
1872M54455EVB_atmel_config \
1873M54455EVB_intel_config \
1874M54455EVB_a33_config \
1875M54455EVB_a66_config \
1876M54455EVB_i33_config \
1877M54455EVB_i66_config :	unconfig
1878	@case "$@" in \
1879	M54455EVB_config)		FLASH=ATMEL; FREQ=33333333;; \
1880	M54455EVB_atmel_config)		FLASH=ATMEL; FREQ=33333333;; \
1881	M54455EVB_intel_config)		FLASH=INTEL; FREQ=33333333;; \
1882	M54455EVB_a33_config)		FLASH=ATMEL; FREQ=33333333;; \
1883	M54455EVB_a66_config)		FLASH=ATMEL; FREQ=66666666;; \
1884	M54455EVB_i33_config)		FLASH=INTEL; FREQ=33333333;; \
1885	M54455EVB_i66_config)		FLASH=INTEL; FREQ=66666666;; \
1886	esac; \
1887	if [ "$${FLASH}" = "INTEL" ] ; then \
1888		echo "#undef CFG_ATMEL_BOOT" >> $(obj)include/config.h ; \
1889		echo "TEXT_BASE = 0x00000000" > $(obj)board/freescale/m54455evb/config.tmp ; \
1890		cp $(obj)board/freescale/m54455evb/u-boot.int $(obj)board/freescale/m54455evb/u-boot.lds ; \
1891		$(XECHO) "... with INTEL boot..." ; \
1892	else \
1893		echo "#define CFG_ATMEL_BOOT"	>> $(obj)include/config.h ; \
1894		echo "TEXT_BASE = 0x04000000" > $(obj)board/freescale/m54455evb/config.tmp ; \
1895		cp $(obj)board/freescale/m54455evb/u-boot.atm $(obj)board/freescale/m54455evb/u-boot.lds ; \
1896		$(XECHO) "... with ATMEL boot..." ; \
1897	fi; \
1898	echo "#define CFG_INPUT_CLKSRC $${FREQ}" >> $(obj)include/config.h ; \
1899	$(XECHO) "... with $${FREQ}Hz input clock"
1900	@$(MKCONFIG) -a M54455EVB m68k mcf5445x m54455evb freescale
1901
1902M5475AFE_config \
1903M5475BFE_config \
1904M5475CFE_config \
1905M5475DFE_config \
1906M5475EFE_config \
1907M5475FFE_config \
1908M5475GFE_config :	unconfig
1909	@case "$@" in \
1910	M5475AFE_config)	BOOT=2;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
1911	M5475BFE_config)	BOOT=2;CODE=16;VID=0;USB=0;RAM=64;RAM1=0;; \
1912	M5475CFE_config)	BOOT=2;CODE=16;VID=1;USB=1;RAM=64;RAM1=0;; \
1913	M5475DFE_config)	BOOT=2;CODE=0;VID=0;USB=1;RAM=64;RAM1=0;; \
1914	M5475EFE_config)	BOOT=2;CODE=0;VID=1;USB=1;RAM=64;RAM1=0;; \
1915	M5475FFE_config)	BOOT=2;CODE=32;VID=1;USB=1;RAM=64;RAM1=64;; \
1916	M5475GFE_config)	BOOT=4;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
1917	esac; \
1918	echo "#define CFG_BUSCLK	133333333" > $(obj)include/config.h ; \
1919	echo "#define CFG_BOOTSZ	$${BOOT}" >> $(obj)include/config.h ; \
1920	echo "#define CFG_DRAMSZ	$${RAM}" >> $(obj)include/config.h ; \
1921	if [ "$${RAM1}" != "0" ] ; then \
1922		echo "#define CFG_DRAMSZ1	$${RAM1}" >> $(obj)include/config.h ; \
1923	fi; \
1924	if [ "$${CODE}" != "0" ] ; then \
1925		echo "#define CFG_NOR1SZ	$${CODE}" >> $(obj)include/config.h ; \
1926	fi; \
1927	if [ "$${VID}" == "1" ] ; then \
1928		echo "#define CFG_VIDEO" >> $(obj)include/config.h ; \
1929	fi; \
1930	if [ "$${USB}" == "1" ] ; then \
1931		echo "#define CFG_USBCTRL" >> $(obj)include/config.h ; \
1932	fi
1933	@$(MKCONFIG) -a M5475EVB m68k mcf547x_8x m547xevb freescale
1934
1935M5485AFE_config \
1936M5485BFE_config \
1937M5485CFE_config \
1938M5485DFE_config \
1939M5485EFE_config \
1940M5485FFE_config \
1941M5485GFE_config \
1942M5485HFE_config :	unconfig
1943	@case "$@" in \
1944	M5485AFE_config)	BOOT=2;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
1945	M5485BFE_config)	BOOT=2;CODE=16;VID=0;USB=0;RAM=64;RAM1=0;; \
1946	M5485CFE_config)	BOOT=2;CODE=16;VID=1;USB=1;RAM=64;RAM1=0;; \
1947	M5485DFE_config)	BOOT=2;CODE=0;VID=0;USB=1;RAM=64;RAM1=0;; \
1948	M5485EFE_config)	BOOT=2;CODE=0;VID=1;USB=1;RAM=64;RAM1=0;; \
1949	M5485FFE_config)	BOOT=2;CODE=32;VID=1;USB=1;RAM=64;RAM1=64;; \
1950	M5485GFE_config)	BOOT=4;CODE=0;VID=0;USB=0;RAM=64;RAM1=0;; \
1951	M5485HFE_config)	BOOT=2;CODE=16;VID=1;USB=0;RAM=64;RAM1=0;; \
1952	esac; \
1953	echo "#define CFG_BUSCLK	100000000" > $(obj)include/config.h ; \
1954	echo "#define CFG_BOOTSZ	$${BOOT}" >> $(obj)include/config.h ; \
1955	echo "#define CFG_DRAMSZ	$${RAM}" >> $(obj)include/config.h ; \
1956	if [ "$${RAM1}" != "0" ] ; then \
1957		echo "#define CFG_DRAMSZ1	$${RAM1}" >> $(obj)include/config.h ; \
1958	fi; \
1959	if [ "$${CODE}" != "0" ] ; then \
1960		echo "#define CFG_NOR1SZ	$${CODE}" >> $(obj)include/config.h ; \
1961	fi; \
1962	if [ "$${VID}" == "1" ] ; then \
1963		echo "#define CFG_VIDEO" >> $(obj)include/config.h ; \
1964	fi; \
1965	if [ "$${USB}" == "1" ] ; then \
1966		echo "#define CFG_USBCTRL" >> $(obj)include/config.h ; \
1967	fi
1968	@$(MKCONFIG) -a M5485EVB m68k mcf547x_8x m548xevb freescale
1969
1970#########################################################################
1971## MPC83xx Systems
1972#########################################################################
1973
1974MPC8313ERDB_33_config \
1975MPC8313ERDB_66_config: unconfig
1976	@mkdir -p $(obj)include
1977	@if [ "$(findstring _33_,$@)" ] ; then \
1978		$(XECHO) -n "...33M ..." ; \
1979		echo "#define CFG_33MHZ" >>$(obj)include/config.h ; \
1980	fi ; \
1981	if [ "$(findstring _66_,$@)" ] ; then \
1982		$(XECHO) -n "...66M..." ; \
1983		echo "#define CFG_66MHZ" >>$(obj)include/config.h ; \
1984	fi ;
1985	@$(MKCONFIG) -a MPC8313ERDB ppc mpc83xx mpc8313erdb freescale
1986
1987MPC8315ERDB_config: unconfig
1988	@$(MKCONFIG) -a MPC8315ERDB ppc mpc83xx mpc8315erdb freescale
1989
1990MPC8323ERDB_config:	unconfig
1991	@$(MKCONFIG) -a MPC8323ERDB ppc mpc83xx mpc8323erdb freescale
1992
1993MPC832XEMDS_config \
1994MPC832XEMDS_HOST_33_config \
1995MPC832XEMDS_HOST_66_config \
1996MPC832XEMDS_SLAVE_config \
1997MPC832XEMDS_ATM_config:	unconfig
1998	@mkdir -p $(obj)include
1999	@if [ "$(findstring _HOST_,$@)" ] ; then \
2000		$(XECHO) -n "... PCI HOST " ; \
2001		echo "#define CONFIG_PCI" >>$(obj)include/config.h ; \
2002	fi ; \
2003	if [ "$(findstring _SLAVE_,$@)" ] ; then \
2004		$(XECHO) "...PCI SLAVE 66M"  ; \
2005		echo "#define CONFIG_PCI" >>$(obj)include/config.h ; \
2006		echo "#define CONFIG_PCISLAVE" >>$(obj)include/config.h ; \
2007	fi ; \
2008	if [ "$(findstring _33_,$@)" ] ; then \
2009		$(XECHO) -n "...33M ..." ; \
2010		echo "#define PCI_33M" >>$(obj)include/config.h ; \
2011		echo "#define CONFIG_PQ_MDS_PIB 1" >>$(obj)include/config.h ; \
2012	fi ; \
2013	if [ "$(findstring _66_,$@)" ] ; then \
2014		$(XECHO) -n "...66M..." ; \
2015		echo "#define PCI_66M" >>$(obj)include/config.h ; \
2016		echo "#define CONFIG_PQ_MDS_PIB 1" >>$(obj)include/config.h ; \
2017	fi ; \
2018	if [ "$(findstring _ATM_,$@)" ] ; then \
2019		$(XECHO) -n "...ATM..." ; \
2020		echo "#define CONFIG_PQ_MDS_PIB 1" >>$(obj)include/config.h ; \
2021		echo "#define CONFIG_PQ_MDS_PIB_ATM	1" >>$(obj)include/config.h ; \
2022	fi ;
2023	@$(MKCONFIG) -a MPC832XEMDS ppc mpc83xx mpc832xemds freescale
2024
2025MPC8349EMDS_config:	unconfig
2026	@$(MKCONFIG) $(@:_config=) ppc mpc83xx mpc8349emds freescale
2027
2028MPC8349ITX_config \
2029MPC8349ITX_LOWBOOT_config \
2030MPC8349ITXGP_config:	unconfig
2031	@mkdir -p $(obj)include
2032	@mkdir -p $(obj)board/freescale/mpc8349itx
2033	@echo "#define CONFIG_$(subst _LOWBOOT,,$(@:_config=))" >> $(obj)include/config.h
2034	@if [ "$(findstring GP,$@)" ] ; then \
2035		echo "TEXT_BASE = 0xFE000000" >$(obj)board/freescale/mpc8349itx/config.tmp ; \
2036	fi
2037	@if [ "$(findstring LOWBOOT,$@)" ] ; then \
2038		echo "TEXT_BASE = 0xFE000000" >$(obj)board/freescale/mpc8349itx/config.tmp ; \
2039	fi
2040	@$(MKCONFIG) -a -n $(@:_config=) MPC8349ITX ppc mpc83xx mpc8349itx freescale
2041
2042MPC8360EMDS_config \
2043MPC8360EMDS_HOST_33_config \
2044MPC8360EMDS_HOST_66_config \
2045MPC8360EMDS_SLAVE_config \
2046MPC8360EMDS_ATM_config: unconfig
2047	@mkdir -p $(obj)include
2048	@if [ "$(findstring _HOST_,$@)" ] ; then \
2049		$(XECHO) -n "... PCI HOST " ; \
2050		echo "#define CONFIG_PCI" >>$(obj)include/config.h ; \
2051	fi ; \
2052	if [ "$(findstring _SLAVE_,$@)" ] ; then \
2053		$(XECHO) "...PCI SLAVE 66M"  ; \
2054		echo "#define CONFIG_PCI" >>$(obj)include/config.h ; \
2055		echo "#define CONFIG_PCISLAVE" >>$(obj)include/config.h ; \
2056	fi ; \
2057	if [ "$(findstring _33_,$@)" ] ; then \
2058		$(XECHO) -n "...33M ..." ; \
2059		echo "#define PCI_33M" >>$(obj)include/config.h ; \
2060		echo "#define CONFIG_PQ_MDS_PIB 1" >>$(obj)include/config.h ; \
2061	fi ; \
2062	if [ "$(findstring _66_,$@)" ] ; then \
2063		$(XECHO) -n "...66M..." ; \
2064		echo "#define PCI_66M" >>$(obj)include/config.h ; \
2065		echo "#define CONFIG_PQ_MDS_PIB 1" >>$(obj)include/config.h ; \
2066	fi ; \
2067	if [ "$(findstring _ATM_,$@)" ] ; then \
2068		$(XECHO) -n "...ATM..." ; \
2069		echo "#define CONFIG_PQ_MDS_PIB 1" >>$(obj)include/config.h ; \
2070		echo "#define CONFIG_PQ_MDS_PIB_ATM	1" >>$(obj)include/config.h ; \
2071	fi ;
2072	@$(MKCONFIG) -a MPC8360EMDS ppc mpc83xx mpc8360emds freescale
2073
2074MPC8360ERDK_33_config \
2075MPC8360ERDK_66_config \
2076MPC8360ERDK_config:	unconfig
2077	@mkdir -p $(obj)include
2078	@if [ "$(findstring _33_,$@)" ] ; then \
2079		$(XECHO) -n "... CLKIN 33MHz " ; \
2080		echo "#define CONFIG_CLKIN_33MHZ" >>$(obj)include/config.h ;\
2081	fi ;
2082	@$(MKCONFIG) -a MPC8360ERDK ppc mpc83xx mpc8360erdk freescale
2083
2084MPC837XEMDS_config \
2085MPC837XEMDS_HOST_config:	unconfig
2086	@mkdir -p $(obj)include
2087	@if [ "$(findstring _HOST_,$@)" ] ; then \
2088		$(XECHO) -n "... PCI HOST " ; \
2089		echo "#define CONFIG_PCI" >>$(obj)include/config.h ; \
2090	fi ;
2091	@$(MKCONFIG) -a MPC837XEMDS ppc mpc83xx mpc837xemds freescale
2092
2093MPC837XERDB_config:	unconfig
2094	@$(MKCONFIG) -a MPC837XERDB ppc mpc83xx mpc837xerdb freescale
2095
2096sbc8349_config:		unconfig
2097	@$(MKCONFIG) $(@:_config=) ppc mpc83xx sbc8349
2098
2099TQM834x_config:	unconfig
2100	@$(MKCONFIG) $(@:_config=) ppc mpc83xx tqm834x
2101
2102
2103#########################################################################
2104## MPC85xx Systems
2105#########################################################################
2106
2107ATUM8548_config:	unconfig
2108	@$(MKCONFIG) $(@:_config=) ppc mpc85xx atum8548
2109
2110MPC8540ADS_config:	unconfig
2111	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8540ads freescale
2112
2113MPC8540EVAL_config \
2114MPC8540EVAL_33_config \
2115MPC8540EVAL_66_config \
2116MPC8540EVAL_33_slave_config \
2117MPC8540EVAL_66_slave_config:	  unconfig
2118	@mkdir -p $(obj)include
2119	@if [ "$(findstring _33_,$@)" ] ; then \
2120		$(XECHO) "... 33 MHz PCI" ; \
2121	else \
2122		echo "#define CONFIG_SYSCLK_66M" >>$(obj)include/config.h ; \
2123		$(XECHO) "... 66 MHz PCI" ; \
2124	fi ; \
2125	if [ "$(findstring _slave_,$@)" ] ; then \
2126		echo "#define CONFIG_PCI_SLAVE" >>$(obj)include/config.h ; \
2127		$(XECHO) " slave" ; \
2128	else \
2129		$(XECHO) " host" ; \
2130	fi
2131	@$(MKCONFIG) -a MPC8540EVAL ppc mpc85xx mpc8540eval
2132
2133MPC8560ADS_config:	unconfig
2134	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8560ads freescale
2135
2136MPC8541CDS_legacy_config \
2137MPC8541CDS_config:	unconfig
2138	@mkdir -p $(obj)include
2139	@if [ "$(findstring _legacy_,$@)" ] ; then \
2140		echo "#define CONFIG_LEGACY" >>$(obj)include/config.h ; \
2141		$(XECHO) "... legacy" ; \
2142	fi
2143	@$(MKCONFIG) -a MPC8541CDS ppc mpc85xx mpc8541cds freescale
2144
2145MPC8544DS_config:	unconfig
2146	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8544ds freescale
2147
2148MPC8548CDS_legacy_config \
2149MPC8548CDS_config:	unconfig
2150	@mkdir -p $(obj)include
2151	@if [ "$(findstring _legacy_,$@)" ] ; then \
2152		echo "#define CONFIG_LEGACY" >>$(obj)include/config.h ; \
2153		$(XECHO) "... legacy" ; \
2154	fi
2155	@$(MKCONFIG) -a MPC8548CDS ppc mpc85xx mpc8548cds freescale
2156
2157MPC8555CDS_legacy_config \
2158MPC8555CDS_config:	unconfig
2159	@mkdir -p $(obj)include
2160	@if [ "$(findstring _legacy_,$@)" ] ; then \
2161		echo "#define CONFIG_LEGACY" >>$(obj)include/config.h ; \
2162		$(XECHO) "... legacy" ; \
2163	fi
2164	@$(MKCONFIG) -a MPC8555CDS ppc mpc85xx mpc8555cds freescale
2165
2166MPC8568MDS_config:	unconfig
2167	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8568mds freescale
2168
2169PM854_config:	unconfig
2170	@$(MKCONFIG) $(@:_config=) ppc mpc85xx pm854
2171
2172PM856_config:	unconfig
2173	@$(MKCONFIG) $(@:_config=) ppc mpc85xx pm856
2174
2175sbc8540_config \
2176sbc8540_33_config \
2177sbc8540_66_config:	unconfig
2178	@mkdir -p $(obj)include
2179	@if [ "$(findstring _66_,$@)" ] ; then \
2180		echo "#define CONFIG_PCI_66"	>>$(obj)include/config.h ; \
2181		$(XECHO) "... 66 MHz PCI" ; \
2182	else \
2183		$(XECHO) "... 33 MHz PCI" ; \
2184	fi
2185	@$(MKCONFIG) -a SBC8540 ppc mpc85xx sbc8560
2186
2187sbc8548_config:		unconfig
2188	@$(MKCONFIG) $(@:_config=) ppc mpc85xx sbc8548
2189
2190sbc8560_config \
2191sbc8560_33_config \
2192sbc8560_66_config:	unconfig
2193	@mkdir -p $(obj)include
2194	@if [ "$(findstring _66_,$@)" ] ; then \
2195		echo "#define CONFIG_PCI_66"	>>$(obj)include/config.h ; \
2196		$(XECHO) "... 66 MHz PCI" ; \
2197	else \
2198		$(XECHO) "... 33 MHz PCI" ; \
2199	fi
2200	@$(MKCONFIG) -a sbc8560 ppc mpc85xx sbc8560
2201
2202stxgp3_config:		unconfig
2203	@$(MKCONFIG) $(@:_config=) ppc mpc85xx stxgp3
2204
2205stxssa_config		\
2206stxssa_4M_config:	unconfig
2207	@mkdir -p $(obj)include
2208	@if [ "$(findstring _4M_,$@)" ] ; then \
2209		echo "#define CONFIG_STXSSA_4M" >>$(obj)include/config.h ; \
2210		$(XECHO) "... with 4 MiB flash memory" ; \
2211	fi
2212	@$(MKCONFIG) -a stxssa ppc mpc85xx stxssa
2213
2214TQM8540_config		\
2215TQM8541_config		\
2216TQM8555_config		\
2217TQM8560_config:		unconfig
2218	@mkdir -p $(obj)include
2219	@CTYPE=$(subst TQM,,$(@:_config=)); \
2220	$(XECHO) "... TQM"$${CTYPE}; \
2221	echo "#define CONFIG_MPC$${CTYPE}">>$(obj)include/config.h; \
2222	echo "#define CONFIG_TQM$${CTYPE}">>$(obj)include/config.h; \
2223	echo "#define CONFIG_HOSTNAME tqm$${CTYPE}">>$(obj)include/config.h; \
2224	echo "#define CONFIG_BOARDNAME \"TQM$${CTYPE}\"">>$(obj)include/config.h; \
2225	echo "#define CFG_BOOTFILE_PATH \"/tftpboot/tqm$${CTYPE}/uImage\"">>$(obj)include/config.h
2226	@$(MKCONFIG) -a TQM85xx ppc mpc85xx tqm85xx
2227
2228#########################################################################
2229## MPC86xx Systems
2230#########################################################################
2231
2232MPC8610HPCD_config:	unconfig
2233	@$(MKCONFIG) $(@:_config=) ppc mpc86xx mpc8610hpcd freescale
2234
2235MPC8641HPCN_config:    unconfig
2236	@$(MKCONFIG) $(@:_config=) ppc mpc86xx mpc8641hpcn freescale
2237
2238sbc8641d_config:	unconfig
2239	@$(MKCONFIG) $(@:_config=) ppc mpc86xx sbc8641d
2240
2241#########################################################################
2242## 74xx/7xx Systems
2243#########################################################################
2244
2245AmigaOneG3SE_config:	unconfig
2246	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx AmigaOneG3SE MAI
2247
2248BAB7xx_config: unconfig
2249	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx bab7xx eltec
2250
2251CPCI750_config:	unconfig
2252	@$(MKCONFIG) CPCI750 ppc 74xx_7xx cpci750 esd
2253
2254DB64360_config:	unconfig
2255	@$(MKCONFIG) DB64360 ppc 74xx_7xx db64360 Marvell
2256
2257DB64460_config:	unconfig
2258	@$(MKCONFIG) DB64460 ppc 74xx_7xx db64460 Marvell
2259
2260ELPPC_config: unconfig
2261	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx elppc eltec
2262
2263EVB64260_config	\
2264EVB64260_750CX_config:	unconfig
2265	@$(MKCONFIG) EVB64260 ppc 74xx_7xx evb64260
2266
2267mpc7448hpc2_config:  unconfig
2268	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx mpc7448hpc2 freescale
2269
2270P3G4_config: unconfig
2271	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx evb64260
2272
2273p3m750_config	\
2274p3m7448_config:		unconfig
2275	@mkdir -p $(obj)include
2276	@if [ "$(findstring 750_,$@)" ] ; then \
2277		echo "#define CONFIG_P3M750" >>$(obj)include/config.h ; \
2278	else \
2279		echo "#define CONFIG_P3M7448" >>$(obj)include/config.h ; \
2280	fi
2281	@$(MKCONFIG) -a p3mx ppc 74xx_7xx p3mx prodrive
2282
2283PCIPPC2_config \
2284PCIPPC6_config: unconfig
2285	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx pcippc2
2286
2287ZUMA_config:	unconfig
2288	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx evb64260
2289
2290ppmc7xx_config: unconfig
2291	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx ppmc7xx
2292
2293#========================================================================
2294# ARM
2295#========================================================================
2296#########################################################################
2297## StrongARM Systems
2298#########################################################################
2299
2300assabet_config	:	unconfig
2301	@$(MKCONFIG) $(@:_config=) arm sa1100 assabet
2302
2303dnp1110_config	:	unconfig
2304	@$(MKCONFIG) $(@:_config=) arm sa1100 dnp1110
2305
2306gcplus_config	:	unconfig
2307	@$(MKCONFIG) $(@:_config=) arm sa1100 gcplus
2308
2309lart_config	:	unconfig
2310	@$(MKCONFIG) $(@:_config=) arm sa1100 lart
2311
2312shannon_config	:	unconfig
2313	@$(MKCONFIG) $(@:_config=) arm sa1100 shannon
2314
2315#########################################################################
2316## ARM92xT Systems
2317#########################################################################
2318
2319xtract_trab = $(subst _bigram,,$(subst _bigflash,,$(subst _old,,$(subst _config,,$1))))
2320
2321xtract_omap1610xxx = $(subst _cs0boot,,$(subst _cs3boot,,$(subst _cs_autoboot,,$(subst _config,,$1))))
2322
2323xtract_omap730p2 = $(subst _cs0boot,,$(subst _cs3boot,, $(subst _config,,$1)))
2324
2325at91cap9adk_config	:	unconfig
2326	@$(MKCONFIG) $(@:_config=) arm arm926ejs at91cap9adk atmel at91sam9
2327
2328at91rm9200dk_config	:	unconfig
2329	@$(MKCONFIG) $(@:_config=) arm arm920t at91rm9200dk atmel at91rm9200
2330
2331at91sam9260ek_config	:	unconfig
2332	@$(MKCONFIG) $(@:_config=) arm arm926ejs at91sam9260ek atmel at91sam9
2333
2334cmc_pu2_config	:	unconfig
2335	@$(MKCONFIG) $(@:_config=) arm arm920t cmc_pu2 NULL at91rm9200
2336
2337csb637_config	:	unconfig
2338	@$(MKCONFIG) $(@:_config=) arm arm920t csb637 NULL at91rm9200
2339
2340mp2usb_config	:	unconfig
2341	@$(MKCONFIG) $(@:_config=) arm arm920t mp2usb NULL at91rm9200
2342
2343m501sk_config	:	unconfig
2344	@$(MKCONFIG) $(@:_config=) arm arm920t m501sk NULL at91rm9200
2345
2346########################################################################
2347## ARM Integrator boards - see doc/README-integrator for more info.
2348integratorap_config	\
2349ap_config		\
2350ap966_config		\
2351ap922_config		\
2352ap922_XA10_config	\
2353ap7_config		\
2354ap720t_config		\
2355ap920t_config		\
2356ap926ejs_config		\
2357ap946es_config: unconfig
2358	@board/integratorap/split_by_variant.sh $@
2359
2360integratorcp_config	\
2361cp_config		\
2362cp920t_config		\
2363cp926ejs_config		\
2364cp946es_config		\
2365cp1136_config		\
2366cp966_config		\
2367cp922_config		\
2368cp922_XA10_config	\
2369cp1026_config: unconfig
2370	@board/integratorcp/split_by_variant.sh $@
2371
2372kb9202_config	:	unconfig
2373	@$(MKCONFIG) $(@:_config=) arm arm920t kb9202 NULL at91rm9200
2374
2375lpd7a400_config \
2376lpd7a404_config:	unconfig
2377	@$(MKCONFIG) $(@:_config=) arm lh7a40x lpd7a40x
2378
2379mx1ads_config	:	unconfig
2380	@$(MKCONFIG) $(@:_config=) arm arm920t mx1ads NULL imx
2381
2382mx1fs2_config	:	unconfig
2383	@$(MKCONFIG) $(@:_config=) arm arm920t mx1fs2 NULL imx
2384
2385netstar_config:		unconfig
2386	@$(MKCONFIG) $(@:_config=) arm arm925t netstar
2387
2388omap1510inn_config :	unconfig
2389	@$(MKCONFIG) $(@:_config=) arm arm925t omap1510inn
2390
2391omap5912osk_config :	unconfig
2392	@$(MKCONFIG) $(@:_config=) arm arm926ejs omap5912osk NULL omap
2393
2394davinci_dvevm_config :	unconfig
2395	@$(MKCONFIG) $(@:_config=) arm arm926ejs dv-evm davinci davinci
2396
2397davinci_schmoogie_config :	unconfig
2398	@$(MKCONFIG) $(@:_config=) arm arm926ejs schmoogie davinci davinci
2399
2400davinci_sonata_config :	unconfig
2401	@$(MKCONFIG) $(@:_config=) arm arm926ejs sonata davinci davinci
2402
2403omap1610inn_config \
2404omap1610inn_cs0boot_config \
2405omap1610inn_cs3boot_config \
2406omap1610inn_cs_autoboot_config \
2407omap1610h2_config \
2408omap1610h2_cs0boot_config \
2409omap1610h2_cs3boot_config \
2410omap1610h2_cs_autoboot_config:	unconfig
2411	@mkdir -p $(obj)include
2412	@if [ "$(findstring _cs0boot_, $@)" ] ; then \
2413		echo "#define CONFIG_CS0_BOOT" >> .$(obj)include/config.h ; \
2414		$(XECHO) "... configured for CS0 boot"; \
2415	elif [ "$(findstring _cs_autoboot_, $@)" ] ; then \
2416		echo "#define CONFIG_CS_AUTOBOOT" >> $(obj)include/config.h ; \
2417		$(XECHO) "... configured for CS_AUTO boot"; \
2418	else \
2419		echo "#define CONFIG_CS3_BOOT" >> $(obj)include/config.h ; \
2420		$(XECHO) "... configured for CS3 boot"; \
2421	fi;
2422	@$(MKCONFIG) -a $(call xtract_omap1610xxx,$@) arm arm926ejs omap1610inn NULL omap
2423
2424omap730p2_config \
2425omap730p2_cs0boot_config \
2426omap730p2_cs3boot_config :	unconfig
2427	@mkdir -p $(obj)include
2428	@if [ "$(findstring _cs0boot_, $@)" ] ; then \
2429		echo "#define CONFIG_CS0_BOOT" >> $(obj)include/config.h ; \
2430		$(XECHO) "... configured for CS0 boot"; \
2431	else \
2432		echo "#define CONFIG_CS3_BOOT" >> $(obj)include/config.h ; \
2433		$(XECHO) "... configured for CS3 boot"; \
2434	fi;
2435	@$(MKCONFIG) -a $(call xtract_omap730p2,$@) arm arm926ejs omap730p2 NULL omap
2436
2437sbc2410x_config: unconfig
2438	@$(MKCONFIG) $(@:_config=) arm arm920t sbc2410x NULL s3c24x0
2439
2440scb9328_config	:	unconfig
2441	@$(MKCONFIG) $(@:_config=) arm arm920t scb9328 NULL imx
2442
2443smdk2400_config	:	unconfig
2444	@$(MKCONFIG) $(@:_config=) arm arm920t smdk2400 NULL s3c24x0
2445
2446smdk2410_config	:	unconfig
2447	@$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0
2448
2449SX1_config :		unconfig
2450	@$(MKCONFIG) $(@:_config=) arm arm925t sx1
2451
2452# TRAB default configuration:	8 MB Flash, 32 MB RAM
2453trab_config \
2454trab_bigram_config \
2455trab_bigflash_config \
2456trab_old_config:	unconfig
2457	@mkdir -p $(obj)include
2458	@mkdir -p $(obj)board/trab
2459	@[ -z "$(findstring _bigram,$@)" ] || \
2460		{ echo "#define CONFIG_FLASH_8MB"  >>$(obj)include/config.h ; \
2461		  echo "#define CONFIG_RAM_32MB"   >>$(obj)include/config.h ; \
2462		  $(XECHO) "... with 8 MB Flash, 32 MB RAM" ; \
2463		}
2464	@[ -z "$(findstring _bigflash,$@)" ] || \
2465		{ echo "#define CONFIG_FLASH_16MB" >>$(obj)include/config.h ; \
2466		  echo "#define CONFIG_RAM_16MB"   >>$(obj)include/config.h ; \
2467		  $(XECHO) "... with 16 MB Flash, 16 MB RAM" ; \
2468		  echo "TEXT_BASE = 0x0CF40000" >$(obj)board/trab/config.tmp ; \
2469		}
2470	@[ -z "$(findstring _old,$@)" ] || \
2471		{ echo "#define CONFIG_FLASH_8MB"  >>$(obj)include/config.h ; \
2472		  echo "#define CONFIG_RAM_16MB"   >>$(obj)include/config.h ; \
2473		  $(XECHO) "... with 8 MB Flash, 16 MB RAM" ; \
2474		  echo "TEXT_BASE = 0x0CF40000" >$(obj)board/trab/config.tmp ; \
2475		}
2476	@$(MKCONFIG) -a $(call xtract_trab,$@) arm arm920t trab NULL s3c24x0
2477
2478VCMA9_config	:	unconfig
2479	@$(MKCONFIG) $(@:_config=) arm arm920t vcma9 mpl s3c24x0
2480
2481#========================================================================
2482# ARM supplied Versatile development boards
2483#========================================================================
2484versatile_config	\
2485versatileab_config	\
2486versatilepb_config :	unconfig
2487	@board/versatile/split_by_variant.sh $@
2488
2489voiceblue_config:	unconfig
2490	@$(MKCONFIG) $(@:_config=) arm arm925t voiceblue
2491
2492cm4008_config	:	unconfig
2493	@$(MKCONFIG) $(@:_config=) arm arm920t cm4008 NULL ks8695
2494
2495cm41xx_config	:	unconfig
2496	@$(MKCONFIG) $(@:_config=) arm arm920t cm41xx NULL ks8695
2497
2498#########################################################################
2499## S3C44B0 Systems
2500#########################################################################
2501
2502B2_config	:	unconfig
2503	@$(MKCONFIG) $(@:_config=) arm s3c44b0 B2 dave
2504
2505#########################################################################
2506## ARM720T Systems
2507#########################################################################
2508
2509armadillo_config:	unconfig
2510	@$(MKCONFIG) $(@:_config=) arm arm720t armadillo
2511
2512ep7312_config	:	unconfig
2513	@$(MKCONFIG) $(@:_config=) arm arm720t ep7312
2514
2515impa7_config	:	unconfig
2516	@$(MKCONFIG) $(@:_config=) arm arm720t impa7
2517
2518modnet50_config :	unconfig
2519	@$(MKCONFIG) $(@:_config=) arm arm720t modnet50
2520
2521evb4510_config :	unconfig
2522	@$(MKCONFIG) $(@:_config=) arm arm720t evb4510
2523
2524lpc2292sodimm_config:	unconfig
2525	@$(MKCONFIG) $(@:_config=) arm arm720t lpc2292sodimm NULL lpc2292
2526
2527SMN42_config	:	unconfig
2528	@$(MKCONFIG) $(@:_config=) arm arm720t SMN42 siemens lpc2292
2529
2530#########################################################################
2531## XScale Systems
2532#########################################################################
2533
2534actux1_config	:	unconfig
2535	@$(MKCONFIG) $(@:_config=) arm ixp actux1
2536
2537actux2_config	:	unconfig
2538	@$(MKCONFIG) $(@:_config=) arm ixp actux2
2539
2540actux3_config	:	unconfig
2541	@$(MKCONFIG) $(@:_config=) arm ixp actux3
2542
2543actux4_config	:	unconfig
2544	@$(MKCONFIG) $(@:_config=) arm ixp actux4
2545
2546adsvix_config	:	unconfig
2547	@$(MKCONFIG) $(@:_config=) arm pxa adsvix
2548
2549cerf250_config :	unconfig
2550	@$(MKCONFIG) $(@:_config=) arm pxa cerf250
2551
2552cradle_config	:	unconfig
2553	@$(MKCONFIG) $(@:_config=) arm pxa cradle
2554
2555csb226_config	:	unconfig
2556	@$(MKCONFIG) $(@:_config=) arm pxa csb226
2557
2558delta_config :	unconfig
2559	@$(MKCONFIG) $(@:_config=) arm pxa delta
2560
2561innokom_config	:	unconfig
2562	@$(MKCONFIG) $(@:_config=) arm pxa innokom
2563
2564ixdp425_config	:	unconfig
2565	@$(MKCONFIG) $(@:_config=) arm ixp ixdp425
2566
2567ixdpg425_config	:	unconfig
2568	@$(MKCONFIG) $(@:_config=) arm ixp ixdp425
2569
2570lubbock_config	:	unconfig
2571	@$(MKCONFIG) $(@:_config=) arm pxa lubbock
2572
2573pleb2_config	:	unconfig
2574	@$(MKCONFIG) $(@:_config=) arm pxa pleb2
2575
2576logodl_config	:	unconfig
2577	@$(MKCONFIG) $(@:_config=) arm pxa logodl
2578
2579pdnb3_config \
2580scpu_config:	unconfig
2581	@mkdir -p $(obj)include
2582	@if [ "$(findstring scpu_,$@)" ] ; then \
2583		echo "#define CONFIG_SCPU"	>>$(obj)include/config.h ; \
2584		$(XECHO) "... on SCPU board variant" ; \
2585	fi
2586	@$(MKCONFIG) -a pdnb3 arm ixp pdnb3 prodrive
2587
2588pxa255_idp_config:	unconfig
2589	@$(MKCONFIG) $(@:_config=) arm pxa pxa255_idp
2590
2591trizepsiv_config	:	unconfig
2592	@$(MKCONFIG) $(@:_config=) arm pxa trizepsiv
2593
2594wepep250_config	:	unconfig
2595	@$(MKCONFIG) $(@:_config=) arm pxa wepep250
2596
2597xaeniax_config	:	unconfig
2598	@$(MKCONFIG) $(@:_config=) arm pxa xaeniax
2599
2600xm250_config	:	unconfig
2601	@$(MKCONFIG) $(@:_config=) arm pxa xm250
2602
2603xsengine_config :	unconfig
2604	@$(MKCONFIG) $(@:_config=) arm pxa xsengine
2605
2606zylonite_config :
2607	@$(MKCONFIG) $(@:_config=) arm pxa zylonite
2608
2609#########################################################################
2610## ARM1136 Systems
2611#########################################################################
2612omap2420h4_config	: unconfig
2613	@$(MKCONFIG) $(@:_config=) arm arm1136 omap2420h4 NULL omap24xx
2614
2615apollon_config		: unconfig
2616	@mkdir -p $(obj)include
2617	@echo "#define CONFIG_ONENAND_U_BOOT" > $(obj)include/config.h
2618	@$(MKCONFIG) $(@:_config=) arm arm1136 apollon NULL omap24xx
2619	@echo "CONFIG_ONENAND_U_BOOT = y" >> $(obj)include/config.mk
2620
2621imx31_litekit_config	: unconfig
2622	@$(MKCONFIG) $(@:_config=) arm arm1136 imx31_litekit NULL mx31
2623
2624imx31_phycore_config	: unconfig
2625	@$(MKCONFIG) $(@:_config=) arm arm1136 imx31_phycore NULL mx31
2626
2627#========================================================================
2628# i386
2629#========================================================================
2630#########################################################################
2631## AMD SC520 CDP
2632#########################################################################
2633sc520_cdp_config	:	unconfig
2634	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_cdp
2635
2636sc520_spunk_config	:	unconfig
2637	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_spunk
2638
2639sc520_spunk_rel_config	:	unconfig
2640	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_spunk
2641
2642#========================================================================
2643# MIPS
2644#========================================================================
2645#########################################################################
2646## MIPS32 4Kc
2647#########################################################################
2648
2649xtract_incaip = $(subst _100MHz,,$(subst _133MHz,,$(subst _150MHz,,$(subst _config,,$1))))
2650
2651incaip_100MHz_config	\
2652incaip_133MHz_config	\
2653incaip_150MHz_config	\
2654incaip_config: unconfig
2655	@mkdir -p $(obj)include
2656	@[ -z "$(findstring _100MHz,$@)" ] || \
2657		{ echo "#define CPU_CLOCK_RATE 100000000" >>$(obj)include/config.h ; \
2658		  $(XECHO) "... with 100MHz system clock" ; \
2659		}
2660	@[ -z "$(findstring _133MHz,$@)" ] || \
2661		{ echo "#define CPU_CLOCK_RATE 133000000" >>$(obj)include/config.h ; \
2662		  $(XECHO) "... with 133MHz system clock" ; \
2663		}
2664	@[ -z "$(findstring _150MHz,$@)" ] || \
2665		{ echo "#define CPU_CLOCK_RATE 150000000" >>$(obj)include/config.h ; \
2666		  $(XECHO) "... with 150MHz system clock" ; \
2667		}
2668	@$(MKCONFIG) -a $(call xtract_incaip,$@) mips mips incaip
2669
2670tb0229_config: unconfig
2671	@$(MKCONFIG) $(@:_config=) mips mips tb0229
2672
2673#########################################################################
2674## MIPS32 AU1X00
2675#########################################################################
2676dbau1000_config		:	unconfig
2677	@mkdir -p $(obj)include
2678	@echo "#define CONFIG_DBAU1000 1" >$(obj)include/config.h
2679	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2680
2681dbau1100_config		:	unconfig
2682	@mkdir -p $(obj)include
2683	@echo "#define CONFIG_DBAU1100 1" >$(obj)include/config.h
2684	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2685
2686dbau1500_config		:	unconfig
2687	@mkdir -p $(obj)include
2688	@echo "#define CONFIG_DBAU1500 1" >$(obj)include/config.h
2689	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2690
2691dbau1550_config		:	unconfig
2692	@mkdir -p $(obj)include
2693	@echo "#define CONFIG_DBAU1550 1" >$(obj)include/config.h
2694	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2695
2696dbau1550_el_config	:	unconfig
2697	@mkdir -p $(obj)include
2698	@echo "#define CONFIG_DBAU1550 1" >$(obj)include/config.h
2699	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2700
2701pb1000_config		:	unconfig
2702	@mkdir -p $(obj)include
2703	@echo "#define CONFIG_PB1000 1" >$(obj)include/config.h
2704	@$(MKCONFIG) -a pb1x00 mips mips pb1x00
2705
2706gth2_config:	unconfig
2707	@mkdir -p $(obj)include
2708	@echo "#define CONFIG_GTH2 1" >$(obj)include/config.h
2709	@$(MKCONFIG) -a gth2 mips mips gth2
2710
2711qemu_mips_config: unconfig
2712	@mkdir -p $(obj)include
2713	@echo "#define CONFIG_QEMU_MIPS 1" >$(obj)include/config.h
2714	@$(MKCONFIG) -a qemu-mips mips mips qemu-mips
2715
2716#########################################################################
2717## MIPS64 5Kc
2718#########################################################################
2719
2720purple_config :		unconfig
2721	@$(MKCONFIG) $(@:_config=) mips mips purple
2722
2723#========================================================================
2724# Nios
2725#========================================================================
2726#########################################################################
2727## Nios32
2728#########################################################################
2729
2730DK1C20_safe_32_config		\
2731DK1C20_standard_32_config	\
2732DK1C20_config:	unconfig
2733	@mkdir -p $(obj)include
2734	@[ -z "$(findstring _safe_32,$@)" ] || \
2735		{ echo "#define CONFIG_NIOS_SAFE_32 1" >>$(obj)include/config.h ; \
2736		  $(XECHO) "... NIOS 'safe_32' configuration" ; \
2737		}
2738	@[ -z "$(findstring _standard_32,$@)" ] || \
2739		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2740		  $(XECHO) "... NIOS 'standard_32' configuration" ; \
2741		}
2742	@[ -z "$(findstring DK1C20_config,$@)" ] || \
2743		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2744		  $(XECHO) "... NIOS 'standard_32' configuration (DEFAULT)" ; \
2745		}
2746	@$(MKCONFIG) -a DK1C20 nios nios dk1c20 altera
2747
2748DK1S10_safe_32_config		\
2749DK1S10_standard_32_config	\
2750DK1S10_mtx_ldk_20_config	\
2751DK1S10_config:	unconfig
2752	@mkdir -p $(obj)include
2753	@[ -z "$(findstring _safe_32,$@)" ] || \
2754		{ echo "#define CONFIG_NIOS_SAFE_32 1" >>$(obj)include/config.h ; \
2755		  $(XECHO) "... NIOS 'safe_32' configuration" ; \
2756		}
2757	@[ -z "$(findstring _standard_32,$@)" ] || \
2758		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2759		  $(XECHO) "... NIOS 'standard_32' configuration" ; \
2760		}
2761	@[ -z "$(findstring _mtx_ldk_20,$@)" ] || \
2762		{ echo "#define CONFIG_NIOS_MTX_LDK_20 1" >>$(obj)include/config.h ; \
2763		  $(XECHO) "... NIOS 'mtx_ldk_20' configuration" ; \
2764		}
2765	@[ -z "$(findstring DK1S10_config,$@)" ] || \
2766		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2767		  $(XECHO) "... NIOS 'standard_32' configuration (DEFAULT)" ; \
2768		}
2769	@$(MKCONFIG) -a DK1S10 nios nios dk1s10 altera
2770
2771ADNPESC1_DNPEVA2_base_32_config	\
2772ADNPESC1_base_32_config		\
2773ADNPESC1_config: unconfig
2774	@mkdir -p $(obj)include
2775	@[ -z "$(findstring _DNPEVA2,$@)" ] || \
2776		{ echo "#define CONFIG_DNPEVA2 1" >>$(obj)include/config.h ; \
2777		  $(XECHO) "... DNP/EVA2 configuration" ; \
2778		}
2779	@[ -z "$(findstring _base_32,$@)" ] || \
2780		{ echo "#define CONFIG_NIOS_BASE_32 1" >>$(obj)include/config.h ; \
2781		  $(XECHO) "... NIOS 'base_32' configuration" ; \
2782		}
2783	@[ -z "$(findstring ADNPESC1_config,$@)" ] || \
2784		{ echo "#define CONFIG_NIOS_BASE_32 1" >>$(obj)include/config.h ; \
2785		  $(XECHO) "... NIOS 'base_32' configuration (DEFAULT)" ; \
2786		}
2787	@$(MKCONFIG) -a ADNPESC1 nios nios adnpesc1 ssv
2788
2789#########################################################################
2790## Nios-II
2791#########################################################################
2792
2793EP1C20_config : unconfig
2794	@$(MKCONFIG)  EP1C20 nios2 nios2 ep1c20 altera
2795
2796EP1S10_config : unconfig
2797	@$(MKCONFIG)  EP1S10 nios2 nios2 ep1s10 altera
2798
2799EP1S40_config : unconfig
2800	@$(MKCONFIG)  EP1S40 nios2 nios2 ep1s40 altera
2801
2802PK1C20_config : unconfig
2803	@$(MKCONFIG)  PK1C20 nios2 nios2 pk1c20 psyent
2804
2805PCI5441_config : unconfig
2806	@$(MKCONFIG)  PCI5441 nios2 nios2 pci5441 psyent
2807
2808#========================================================================
2809# MicroBlaze
2810#========================================================================
2811#########################################################################
2812## Microblaze
2813#########################################################################
2814suzaku_config:	unconfig
2815	@mkdir -p $(obj)include
2816	@echo "#define CONFIG_SUZAKU 1" > $(obj)include/config.h
2817	@$(MKCONFIG) -a $(@:_config=) microblaze microblaze suzaku AtmarkTechno
2818
2819ml401_config:	unconfig
2820	@mkdir -p $(obj)include
2821	@echo "#define CONFIG_ML401 1" > $(obj)include/config.h
2822	@$(MKCONFIG) -a $(@:_config=) microblaze microblaze ml401 xilinx
2823
2824xupv2p_config:	unconfig
2825	@mkdir -p $(obj)include
2826	@echo "#define CONFIG_XUPV2P 1" > $(obj)include/config.h
2827	@$(MKCONFIG) -a $(@:_config=) microblaze microblaze xupv2p xilinx
2828
2829#========================================================================
2830# Blackfin
2831#========================================================================
2832
2833# Analog Devices boards
2834BFIN_BOARDS = bf533-ezkit bf533-stamp bf537-stamp bf561-ezkit
2835
2836$(BFIN_BOARDS:%=%_config)	: unconfig
2837	@$(MKCONFIG) $(@:_config=) blackfin blackfin $(@:_config=)
2838
2839$(BFIN_BOARDS):
2840	$(MAKE) $@_config
2841	$(MAKE)
2842
2843#========================================================================
2844# AVR32
2845#========================================================================
2846#########################################################################
2847## AT32AP7xxx
2848#########################################################################
2849
2850atstk1002_config	:	unconfig
2851	@$(MKCONFIG) $(@:_config=) avr32 at32ap atstk1000 atmel at32ap700x
2852
2853atstk1003_config	:	unconfig
2854	@$(MKCONFIG) $(@:_config=) avr32 at32ap atstk1000 atmel at32ap700x
2855
2856atstk1004_config	:	unconfig
2857	@$(MKCONFIG) $(@:_config=) avr32 at32ap atstk1000 atmel at32ap700x
2858
2859atngw100_config	:	unconfig
2860	@$(MKCONFIG) $(@:_config=) avr32 at32ap atngw100 atmel at32ap700x
2861
2862#########################################################################
2863#########################################################################
2864#########################################################################
2865
2866#########################################################################
2867## sh3 (Renesas SuperH)
2868#########################################################################
2869mpr2_config: unconfig
2870	@ >include/config.h
2871	@echo "#define CONFIG_MPR2 1" >> include/config.h
2872	@$(MKCONFIG) -a $(@:_config=) sh sh3 mpr2
2873
2874ms7720se_config: unconfig
2875	@echo "#define CONFIG_MS7720SE 1" > include/config.h
2876	@$(MKCONFIG) -a $(@:_config=) sh sh3 ms7720se
2877
2878#########################################################################
2879## sh4 (Renesas SuperH)
2880#########################################################################
2881ms7750se_config: unconfig
2882	@echo "#define CONFIG_MS7750SE 1" > $(obj)include/config.h
2883	@$(MKCONFIG) -a $(@:_config=) sh sh4 ms7750se
2884
2885ms7722se_config :	unconfig
2886	@echo "#define CONFIG_MS7722SE 1" > $(obj)include/config.h
2887	@$(MKCONFIG) -a $(@:_config=) sh sh4 ms7722se
2888
2889MigoR_config :       unconfig
2890	@ >include/config.h
2891	@echo "#define CONFIG_MIGO_R 1" >> include/config.h
2892	@./mkconfig -a $(@:_config=) sh sh4 MigoR
2893
2894r7780mp_config: unconfig
2895	@ >include/config.h
2896	@echo "#define CONFIG_R7780MP 1" >> include/config.h
2897	@./mkconfig -a $(@:_config=) sh sh4 r7780mp
2898
2899r2dplus_config  :   unconfig
2900	@ >include/config.h
2901	@echo "#define CONFIG_R2DPLUS 1" >> include/config.h
2902	@./mkconfig -a $(@:_config=) sh sh4 r2dplus
2903
2904#========================================================================
2905# SPARC
2906#========================================================================
2907#########################################################################
2908## LEON3
2909#########################################################################
2910
2911# Gaisler GR-XC3S-1500 board
2912gr_xc3s_1500_config : unconfig
2913	@$(MKCONFIG) $(@:_config=) sparc leon3 gr_xc3s_1500 gaisler
2914
2915# Gaisler GR-CPCI-AX2000 board, a General purpose FPGA-AX system
2916gr_cpci_ax2000_config : unconfig
2917	@$(MKCONFIG) $(@:_config=) sparc leon3 gr_cpci_ax2000 gaisler
2918
2919# Gaisler GRLIB template design (GPL SPARC/LEON3) for Altera NIOS
2920# Development board Stratix II edition, FPGA Device EP2S60.
2921gr_ep2s60_config: unconfig
2922	@$(MKCONFIG) $(@:_config=) sparc leon3 gr_ep2s60 gaisler
2923
2924# Gaisler LEON3 GRSIM simulator
2925grsim_config : unconfig
2926	@$(MKCONFIG) $(@:_config=) sparc leon3 grsim gaisler
2927
2928#########################################################################
2929## LEON2
2930#########################################################################
2931
2932# Gaisler LEON2 GRSIM simulator
2933grsim_leon2_config : unconfig
2934	@$(MKCONFIG) $(@:_config=) sparc leon2 grsim_leon2 gaisler
2935
2936#########################################################################
2937#########################################################################
2938#########################################################################
2939
2940clean:
2941	@rm -f $(obj)examples/82559_eeprom $(obj)examples/eepro100_eeprom \
2942	       $(obj)examples/hello_world  $(obj)examples/interrupt	  \
2943	       $(obj)examples/mem_to_mem_idma2intr			  \
2944	       $(obj)examples/sched	   $(obj)examples/smc91111_eeprom \
2945	       $(obj)examples/test_burst   $(obj)examples/timer
2946	@rm -f $(obj)tools/bmp_logo	   $(obj)tools/easylogo/easylogo  \
2947	       $(obj)tools/env/{fw_printenv,fw_setenv}			  \
2948	       $(obj)tools/envcrc					  \
2949	       $(obj)tools/gdb/{astest,gdbcont,gdbsend}			  \
2950	       $(obj)tools/gen_eth_addr    $(obj)tools/img2srec		  \
2951	       $(obj)tools/mkimage	   $(obj)tools/mpc86x_clk	  \
2952	       $(obj)tools/ncb		   $(obj)tools/ubsha1
2953	@rm -f $(obj)board/cray/L1/{bootscript.c,bootscript.image}	  \
2954	       $(obj)board/netstar/{eeprom,crcek,crcit,*.srec,*.bin}	  \
2955	       $(obj)board/trab/trab_fkt   $(obj)board/voiceblue/eeprom   \
2956	       $(obj)board/{integratorap,integratorcp}/u-boot.lds	  \
2957	       $(obj)board/{bf533-ezkit,bf533-stamp,bf537-stamp,bf561-ezkit}/u-boot.lds \
2958	       $(obj)cpu/blackfin/bootrom-asm-offsets.[chs]
2959	@rm -f $(obj)include/bmp_logo.h $(obj)nand_spl/{u-boot-spl,u-boot-spl.map}
2960	@rm -f $(obj)onenand_ipl/onenand-{ipl,ipl.bin,ipl-2k.bin,ipl-4k.bin,ipl.map}
2961	@rm -f $(obj)api_examples/demo $(VERSION_FILE)
2962	@find $(OBJTREE) -type f \
2963		\( -name 'core' -o -name '*.bak' -o -name '*~' \
2964		-o -name '*.o'	-o -name '*.a'	\) -print \
2965		| xargs rm -f
2966
2967clobber:	clean
2968	@find $(OBJTREE) -type f \( -name .depend \
2969		-o -name '*.srec' -o -name '*.bin' -o -name u-boot.img \) \
2970		-print0 \
2971		| xargs -0 rm -f
2972	@rm -f $(OBJS) $(obj)*.bak $(obj)ctags $(obj)etags $(obj)TAGS \
2973		$(obj)cscope.* $(obj)*.*~
2974	@rm -f $(obj)u-boot $(obj)u-boot.map $(obj)u-boot.hex $(ALL)
2975	@rm -f $(obj)tools/{crc32.c,environment.c,env/crc32.c,md5.c,sha1.c,inca-swap-bytes}
2976	@rm -f $(obj)tools/{image.c,fdt.c,fdt_ro.c,fdt_rw.c,fdt_strerror.c}
2977	@rm -f $(obj)tools/{fdt_wip.c,libfdt_internal.h}
2978	@rm -f $(obj)cpu/mpc824x/bedbug_603e.c
2979	@rm -f $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm
2980	@[ ! -d $(obj)nand_spl ] || find $(obj)nand_spl -lname "*" -print | xargs rm -f
2981	@[ ! -d $(obj)onenand_ipl ] || find $(obj)onenand_ipl -lname "*" -print | xargs rm -f
2982	@[ ! -d $(obj)api_examples ] || find $(obj)api_examples -lname "*" -print | xargs rm -f
2983
2984ifeq ($(OBJTREE),$(SRCTREE))
2985mrproper \
2986distclean:	clobber unconfig
2987else
2988mrproper \
2989distclean:	clobber unconfig
2990	rm -rf $(obj)*
2991endif
2992
2993backup:
2994	F=`basename $(TOPDIR)` ; cd .. ; \
2995	gtar --force-local -zcvf `date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
2996
2997#########################################################################
2998