xref: /rk3399_rockchip-uboot/Makefile (revision 4707fb50cc9f815996be5f2e5a8660de852b2c37)
1#
2# (C) Copyright 2000-2006
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 = 1
26SUBLEVEL = 4
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/macppc/ppc/)
38
39HOSTOS := $(shell uname -s | tr '[:upper:]' '[:lower:]' | \
40	    sed -e 's/\(cygwin\).*/cygwin/')
41
42export	HOSTARCH HOSTOS
43
44# Deal with colliding definitions from tcsh etc.
45VENDOR=
46
47#########################################################################
48#
49# U-boot build supports producing a object files to the separate external
50# directory. Two use cases are supported:
51#
52# 1) Add O= to the make command line
53# 'make O=/tmp/build all'
54#
55# 2) Set environement variable BUILD_DIR to point to the desired location
56# 'export BUILD_DIR=/tmp/build'
57# 'make'
58#
59# The second approach can also be used with a MAKEALL script
60# 'export BUILD_DIR=/tmp/build'
61# './MAKEALL'
62#
63# Command line 'O=' setting overrides BUILD_DIR environent variable.
64#
65# When none of the above methods is used the local build is performed and
66# the object files are placed in the source directory.
67#
68
69ifdef O
70ifeq ("$(origin O)", "command line")
71BUILD_DIR := $(O)
72endif
73endif
74
75ifneq ($(BUILD_DIR),)
76saved-output := $(BUILD_DIR)
77
78# Attempt to create a output directory.
79$(shell [ -d ${BUILD_DIR} ] || mkdir -p ${BUILD_DIR})
80
81# Verify if it was successful.
82BUILD_DIR := $(shell cd $(BUILD_DIR) && /bin/pwd)
83$(if $(BUILD_DIR),,$(error output directory "$(saved-output)" does not exist))
84endif # ifneq ($(BUILD_DIR),)
85
86OBJTREE		:= $(if $(BUILD_DIR),$(BUILD_DIR),$(CURDIR))
87SRCTREE		:= $(CURDIR)
88TOPDIR		:= $(SRCTREE)
89LNDIR		:= $(OBJTREE)
90export	TOPDIR SRCTREE OBJTREE
91
92MKCONFIG	:= $(SRCTREE)/mkconfig
93export MKCONFIG
94
95ifneq ($(OBJTREE),$(SRCTREE))
96REMOTE_BUILD 	:= 1
97export REMOTE_BUILD
98endif
99
100# $(obj) and (src) are defined in config.mk but here in main Makefile
101# we also need them before config.mk is included which is the case for
102# some targets like unconfig, clean, clobber, distclean, etc.
103ifneq ($(OBJTREE),$(SRCTREE))
104obj := $(OBJTREE)/
105src := $(SRCTREE)/
106else
107obj :=
108src :=
109endif
110export obj src
111
112#########################################################################
113
114ifeq ($(OBJTREE)/include/config.mk,$(wildcard $(OBJTREE)/include/config.mk))
115
116# load ARCH, BOARD, and CPU configuration
117include $(OBJTREE)/include/config.mk
118export	ARCH CPU BOARD VENDOR SOC
119
120ifndef CROSS_COMPILE
121ifeq ($(HOSTARCH),ppc)
122CROSS_COMPILE =
123else
124ifeq ($(ARCH),ppc)
125CROSS_COMPILE = powerpc-linux-
126endif
127ifeq ($(ARCH),arm)
128CROSS_COMPILE = arm-linux-
129endif
130ifeq ($(ARCH),i386)
131ifeq ($(HOSTARCH),i386)
132CROSS_COMPILE =
133else
134CROSS_COMPILE = i386-linux-
135endif
136endif
137ifeq ($(ARCH),mips)
138CROSS_COMPILE = mips_4KC-
139endif
140ifeq ($(ARCH),nios)
141CROSS_COMPILE = nios-elf-
142endif
143ifeq ($(ARCH),nios2)
144CROSS_COMPILE = nios2-elf-
145endif
146ifeq ($(ARCH),m68k)
147CROSS_COMPILE = m68k-elf-
148endif
149ifeq ($(ARCH),microblaze)
150CROSS_COMPILE = mb-
151endif
152ifeq ($(ARCH),blackfin)
153CROSS_COMPILE = bfin-elf-
154endif
155endif
156endif
157
158export	CROSS_COMPILE
159
160# load other configuration
161include $(TOPDIR)/config.mk
162
163#########################################################################
164# U-Boot objects....order is important (i.e. start must be first)
165
166OBJS  = cpu/$(CPU)/start.o
167ifeq ($(CPU),i386)
168OBJS += cpu/$(CPU)/start16.o
169OBJS += cpu/$(CPU)/reset.o
170endif
171ifeq ($(CPU),ppc4xx)
172OBJS += cpu/$(CPU)/resetvec.o
173endif
174ifeq ($(CPU),mpc83xx)
175OBJS += cpu/$(CPU)/resetvec.o
176endif
177ifeq ($(CPU),mpc85xx)
178OBJS += cpu/$(CPU)/resetvec.o
179endif
180ifeq ($(CPU),bf533)
181OBJS += cpu/$(CPU)/start1.o	cpu/$(CPU)/interrupt.o	cpu/$(CPU)/cache.o
182OBJS += cpu/$(CPU)/cplbhdlr.o	cpu/$(CPU)/cplbmgr.o	cpu/$(CPU)/flush.o
183endif
184
185OBJS := $(addprefix $(obj),$(OBJS))
186
187LIBS  = lib_generic/libgeneric.a
188LIBS += board/$(BOARDDIR)/lib$(BOARD).a
189LIBS += cpu/$(CPU)/lib$(CPU).a
190ifdef SOC
191LIBS += cpu/$(CPU)/$(SOC)/lib$(SOC).a
192endif
193LIBS += lib_$(ARCH)/lib$(ARCH).a
194LIBS += fs/cramfs/libcramfs.a fs/fat/libfat.a fs/fdos/libfdos.a fs/jffs2/libjffs2.a \
195	fs/reiserfs/libreiserfs.a fs/ext2/libext2fs.a
196LIBS += net/libnet.a
197LIBS += disk/libdisk.a
198LIBS += rtc/librtc.a
199LIBS += dtt/libdtt.a
200LIBS += drivers/libdrivers.a
201LIBS += drivers/nand/libnand.a
202LIBS += drivers/nand_legacy/libnand_legacy.a
203LIBS += drivers/sk98lin/libsk98lin.a
204LIBS += post/libpost.a post/cpu/libcpu.a
205LIBS += common/libcommon.a
206LIBS += $(BOARDLIBS)
207
208LIBS := $(addprefix $(obj),$(LIBS))
209.PHONY : $(LIBS)
210
211# Add GCC lib
212PLATFORM_LIBS += -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc
213
214# The "tools" are needed early, so put this first
215# Don't include stuff already done in $(LIBS)
216SUBDIRS	= tools \
217	  examples \
218	  post \
219	  post/cpu
220.PHONY : $(SUBDIRS)
221
222ifeq ($(CONFIG_NAND_U_BOOT),y)
223NAND_SPL = nand_spl
224U_BOOT_NAND = $(obj)u-boot-nand.bin
225endif
226
227__OBJS := $(subst $(obj),,$(OBJS))
228__LIBS := $(subst $(obj),,$(LIBS))
229
230#########################################################################
231#########################################################################
232
233ALL = $(obj)u-boot.srec $(obj)u-boot.bin $(obj)System.map $(U_BOOT_NAND)
234
235all:		$(ALL)
236
237$(obj)u-boot.hex:	$(obj)u-boot
238		$(OBJCOPY) ${OBJCFLAGS} -O ihex $< $@
239
240$(obj)u-boot.srec:	$(obj)u-boot
241		$(OBJCOPY) ${OBJCFLAGS} -O srec $< $@
242
243$(obj)u-boot.bin:	$(obj)u-boot
244		$(OBJCOPY) ${OBJCFLAGS} -O binary $< $@
245
246$(obj)u-boot.img:	$(obj)u-boot.bin
247		./tools/mkimage -A $(ARCH) -T firmware -C none \
248		-a $(TEXT_BASE) -e 0 \
249		-n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' $(VERSION_FILE) | \
250			sed -e 's/"[	 ]*$$/ for $(BOARD) board"/') \
251		-d $< $@
252
253$(obj)u-boot.dis:	$(obj)u-boot
254		$(OBJDUMP) -d $< > $@
255
256$(obj)u-boot:		depend version $(SUBDIRS) $(OBJS) $(LIBS) $(LDSCRIPT)
257		UNDEF_SYM=`$(OBJDUMP) -x $(LIBS) |sed  -n -e 's/.*\(__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\
258		cd $(LNDIR) && $(LD) $(LDFLAGS) $$UNDEF_SYM $(__OBJS) \
259			--start-group $(__LIBS) --end-group $(PLATFORM_LIBS) \
260			-Map u-boot.map -o u-boot
261
262$(OBJS):
263		$(MAKE) -C cpu/$(CPU) $(if $(REMOTE_BUILD),$@,$(notdir $@))
264
265$(LIBS):
266		$(MAKE) -C $(dir $(subst $(obj),,$@))
267
268$(SUBDIRS):
269		$(MAKE) -C $@ all
270
271$(NAND_SPL):	version
272		$(MAKE) -C nand_spl all
273
274$(U_BOOT_NAND):	$(NAND_SPL) $(obj)u-boot.bin
275		cat nand_spl/u-boot-spl-16k.bin $(obj)u-boot.bin > $(obj)u-boot-nand.bin
276
277version:
278		@echo -n "#define U_BOOT_VERSION \"U-Boot " > $(VERSION_FILE); \
279		echo -n "$(U_BOOT_VERSION)" >> $(VERSION_FILE); \
280		echo -n $(shell $(CONFIG_SHELL) $(TOPDIR)/tools/setlocalversion \
281			 $(TOPDIR)) >> $(VERSION_FILE); \
282		echo "\"" >> $(VERSION_FILE)
283
284gdbtools:
285		$(MAKE) -C tools/gdb all || exit 1
286
287updater:
288		$(MAKE) -C tools/updater all || exit 1
289
290env:
291		$(MAKE) -C tools/env all || exit 1
292
293depend dep:
294		for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir _depend ; done
295
296tags ctags:
297		ctags -w -o $(OBJTREE)/ctags `find $(SUBDIRS) include \
298				lib_generic board/$(BOARDDIR) cpu/$(CPU) lib_$(ARCH) \
299				fs/cramfs fs/fat fs/fdos fs/jffs2 \
300				net disk rtc dtt drivers drivers/sk98lin common \
301			\( -name CVS -prune \) -o \( -name '*.[ch]' -print \)`
302
303etags:
304		etags -a -o $(OBJTREE)/etags `find $(SUBDIRS) include \
305				lib_generic board/$(BOARDDIR) cpu/$(CPU) lib_$(ARCH) \
306				fs/cramfs fs/fat fs/fdos fs/jffs2 \
307				net disk rtc dtt drivers drivers/sk98lin common \
308			\( -name CVS -prune \) -o \( -name '*.[ch]' -print \)`
309
310$(obj)System.map:	$(obj)u-boot
311		@$(NM) $< | \
312		grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \
313		sort > $(obj)System.map
314
315#########################################################################
316else
317all $(obj)u-boot.hex $(obj)u-boot.srec $(obj)u-boot.bin \
318$(obj)u-boot.img $(obj)u-boot.dis $(obj)u-boot \
319$(SUBDIRS) version gdbtools updater env depend \
320dep tags ctags etags $(obj)System.map:
321	@echo "System not configured - see README" >&2
322	@ exit 1
323endif
324
325#########################################################################
326
327unconfig:
328	@rm -f $(obj)include/config.h $(obj)include/config.mk \
329		$(obj)board/*/config.tmp $(obj)board/*/*/config.tmp
330
331#========================================================================
332# PowerPC
333#========================================================================
334
335#########################################################################
336## MPC5xx Systems
337#########################################################################
338
339canmb_config:	unconfig
340	@$(MKCONFIG) -a canmb ppc mpc5xxx canmb
341
342cmi_mpc5xx_config:	unconfig
343	@$(MKCONFIG) $(@:_config=) ppc mpc5xx cmi
344
345PATI_config:		unconfig
346	@$(MKCONFIG) $(@:_config=) ppc mpc5xx pati mpl
347
348#########################################################################
349## MPC5xxx Systems
350#########################################################################
351
352aev_config: unconfig
353	@$(MKCONFIG) -a aev ppc mpc5xxx tqm5200
354
355BC3450_config:	unconfig
356	@$(MKCONFIG) -a BC3450 ppc mpc5xxx bc3450
357
358cpci5200_config:  unconfig
359	@$(MKCONFIG) -a cpci5200  ppc mpc5xxx cpci5200 esd
360
361hmi1001_config:         unconfig
362	@$(MKCONFIG) hmi1001 ppc mpc5xxx hmi1001
363
364Lite5200_config				\
365Lite5200_LOWBOOT_config			\
366Lite5200_LOWBOOT08_config		\
367icecube_5200_config			\
368icecube_5200_LOWBOOT_config		\
369icecube_5200_LOWBOOT08_config		\
370icecube_5200_DDR_config 		\
371icecube_5200_DDR_LOWBOOT_config 	\
372icecube_5200_DDR_LOWBOOT08_config	\
373icecube_5100_config:			unconfig
374	@mkdir -p $(obj)include
375	@mkdir -p $(obj)board/icecube
376	@ >$(obj)include/config.h
377	@[ -z "$(findstring LOWBOOT_,$@)" ] || \
378		{ if [ "$(findstring DDR,$@)" ] ; \
379			then echo "TEXT_BASE = 0xFF800000" >$(obj)board/icecube/config.tmp ; \
380			else echo "TEXT_BASE = 0xFF000000" >$(obj)board/icecube/config.tmp ; \
381		  fi ; \
382		  echo "... with LOWBOOT configuration" ; \
383		}
384	@[ -z "$(findstring LOWBOOT08,$@)" ] || \
385		{ echo "TEXT_BASE = 0xFF800000" >$(obj)board/icecube/config.tmp ; \
386		  echo "... with 8 MB flash only" ; \
387		  echo "... with LOWBOOT configuration" ; \
388		}
389	@[ -z "$(findstring DDR,$@)" ] || \
390		{ echo "#define CONFIG_MPC5200_DDR"	>>$(obj)include/config.h ; \
391		  echo "... DDR memory revision" ; \
392		}
393	@[ -z "$(findstring 5200,$@)" ] || \
394		{ echo "#define CONFIG_MPC5200"		>>$(obj)include/config.h ; \
395		  echo "... with MPC5200 processor" ; \
396		}
397	@[ -z "$(findstring 5100,$@)" ] || \
398		{ echo "#define CONFIG_MGT5100"		>>$(obj)include/config.h ; \
399		  echo "... with MGT5100 processor" ; \
400		}
401	@$(MKCONFIG) -a IceCube ppc mpc5xxx icecube
402
403v38b_config: unconfig
404	@./mkconfig -a V38B ppc mpc5xxx v38b
405
406inka4x0_config:	unconfig
407	@$(MKCONFIG) inka4x0 ppc mpc5xxx inka4x0
408
409lite5200b_config	\
410lite5200b_LOWBOOT_config:	unconfig
411	@mkdir -p $(obj)include
412	@mkdir -p $(obj)board/icecube
413	@ >$(obj)include/config.h
414	@ echo "#define CONFIG_MPC5200_DDR"	>>$(obj)include/config.h
415	@ echo "... DDR memory revision"
416	@ echo "#define CONFIG_MPC5200"		>>$(obj)include/config.h
417	@ echo "#define CONFIG_LITE5200B"	>>$(obj)include/config.h
418	@[ -z "$(findstring LOWBOOT_,$@)" ] || \
419		{ echo "TEXT_BASE = 0xFF000000" >$(obj)board/icecube/config.tmp ; \
420		  echo "... with LOWBOOT configuration" ; \
421		}
422	@ echo "... with MPC5200B processor"
423	@$(MKCONFIG) -a IceCube  ppc mpc5xxx icecube
424
425mcc200_config	\
426mcc200_SDRAM_config	\
427mcc200_highboot_config	\
428mcc200_COM12_config	\
429mcc200_COM12_SDRAM_config	\
430mcc200_COM12_highboot_config	\
431mcc200_COM12_highboot_SDRAM_config	\
432mcc200_highboot_SDRAM_config	\
433prs200_config	\
434prs200_DDR_config	\
435prs200_highboot_config	\
436prs200_highboot_DDR_config:	unconfig
437	@mkdir -p $(obj)include
438	@mkdir -p $(obj)board/mcc200
439	@ >$(obj)include/config.h
440	@[ -n "$(findstring highboot,$@)" ] || \
441		{ echo "... with lowboot configuration" ; \
442		}
443	@[ -z "$(findstring highboot,$@)" ] || \
444		{ echo "TEXT_BASE = 0xFFF00000" >$(obj)board/mcc200/config.tmp ; \
445		  echo "... with highboot configuration" ; \
446		}
447	@[ -n "$(findstring _SDRAM,$@)" ] || \
448		{ if [ -n "$(findstring mcc200,$@)" ]; \
449		  then \
450		  	echo "... with DDR" ; \
451		  else \
452			if [ -n "$(findstring _DDR,$@)" ];\
453			then \
454				echo "... with DDR" ; \
455			else \
456				echo "#define CONFIG_MCC200_SDRAM" >>$(obj)include/config.h ;\
457				echo "... with SDRAM" ; \
458			fi; \
459		  fi; \
460		}
461	@[ -z "$(findstring _SDRAM,$@)" ] || \
462		{ echo "#define CONFIG_MCC200_SDRAM"	>>$(obj)include/config.h ; \
463		  echo "... with SDRAM" ; \
464		}
465	@[ -z "$(findstring COM12,$@)" ] || \
466		{ echo "#define CONFIG_CONSOLE_COM12"	>>$(obj)include/config.h ; \
467		  echo "... with console on COM12" ; \
468		}
469	@[ -z "$(findstring prs200,$@)" ] || \
470		{ echo "#define CONFIG_PRS200"  >>$(obj)include/config.h ;\
471		}
472	@$(MKCONFIG) -n $@ -a mcc200 ppc mpc5xxx mcc200
473
474o2dnt_config:
475	@$(MKCONFIG) o2dnt ppc mpc5xxx o2dnt
476
477pf5200_config:  unconfig
478	@$(MKCONFIG) pf5200  ppc mpc5xxx pf5200 esd
479
480PM520_config \
481PM520_DDR_config \
482PM520_ROMBOOT_config \
483PM520_ROMBOOT_DDR_config:	unconfig
484	@mkdir -p $(obj)include
485	@ >$(obj)include/config.h
486	@[ -z "$(findstring DDR,$@)" ] || \
487		{ echo "#define CONFIG_MPC5200_DDR"	>>$(obj)include/config.h ; \
488		  echo "... DDR memory revision" ; \
489		}
490	@[ -z "$(findstring ROMBOOT,$@)" ] || \
491		{ echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
492		  echo "... booting from 8-bit flash" ; \
493		}
494	@$(MKCONFIG) -a PM520 ppc mpc5xxx pm520
495
496smmaco4_config: unconfig
497	@$(MKCONFIG) -a smmaco4 ppc mpc5xxx tqm5200
498
499spieval_config:	unconfig
500	@$(MKCONFIG) -a spieval ppc mpc5xxx tqm5200
501
502TB5200_B_config \
503TB5200_config:	unconfig
504	@mkdir -p $(obj)include
505	@[ -z "$(findstring _B,$@)" ] || \
506		{ echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
507		  echo "... with MPC5200B processor" ; \
508		}
509	@$(MKCONFIG) -n $@ -a TB5200 ppc mpc5xxx tqm5200
510
511MINI5200_config	\
512EVAL5200_config	\
513TOP5200_config:	unconfig
514	@mkdir -p $(obj)include
515	@ echo "#define CONFIG_$(@:_config=) 1"	>$(obj)include/config.h
516	@$(MKCONFIG) -n $@ -a TOP5200 ppc mpc5xxx top5200 emk
517
518Total5100_config		\
519Total5200_config		\
520Total5200_lowboot_config	\
521Total5200_Rev2_config		\
522Total5200_Rev2_lowboot_config:	unconfig
523	@mkdir -p $(obj)include
524	@mkdir -p $(obj)board/total5200
525	@ >$(obj)include/config.h
526	@[ -z "$(findstring 5100,$@)" ] || \
527		{ echo "#define CONFIG_MGT5100"		>>$(obj)include/config.h ; \
528		  echo "... with MGT5100 processor" ; \
529		}
530	@[ -z "$(findstring 5200,$@)" ] || \
531		{ echo "#define CONFIG_MPC5200"		>>$(obj)include/config.h ; \
532		  echo "... with MPC5200 processor" ; \
533		}
534	@[ -n "$(findstring Rev,$@)" ] || \
535		{ echo "#define CONFIG_TOTAL5200_REV 1"	>>$(obj)include/config.h ; \
536		  echo "... revision 1 board" ; \
537		}
538	@[ -z "$(findstring Rev2_,$@)" ] || \
539		{ echo "#define CONFIG_TOTAL5200_REV 2"	>>$(obj)include/config.h ; \
540		  echo "... revision 2 board" ; \
541		}
542	@[ -z "$(findstring lowboot_,$@)" ] || \
543		{ echo "TEXT_BASE = 0xFE000000" >$(obj)board/total5200/config.tmp ; \
544		  echo "... with lowboot configuration" ; \
545		}
546	@$(MKCONFIG) -a Total5200 ppc mpc5xxx total5200
547
548cam5200_config \
549fo300_config \
550MiniFAP_config \
551TQM5200S_config \
552TQM5200S_HIGHBOOT_config \
553TQM5200_B_config \
554TQM5200_B_HIGHBOOT_config \
555TQM5200_config	\
556TQM5200_STK100_config:	unconfig
557	@mkdir -p $(obj)include
558	@mkdir -p $(obj)board/tqm5200
559	@ >$(obj)include/config.h
560	@[ -z "$(findstring cam5200,$@)" ] || \
561		{ echo "#define CONFIG_CAM5200"	>>$(obj)include/config.h ; \
562		  echo "#define CONFIG_TQM5200S"	>>$(obj)include/config.h ; \
563		  echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
564		  echo "... TQM5200S on Cam5200" ; \
565		}
566	@[ -z "$(findstring fo300,$@)" ] || \
567		{ echo "#define CONFIG_FO300"	>>$(obj)include/config.h ; \
568		  echo "... TQM5200 on FO300" ; \
569		}
570	@[ -z "$(findstring MiniFAP,$@)" ] || \
571		{ echo "#define CONFIG_MINIFAP"	>>$(obj)include/config.h ; \
572		  echo "... TQM5200_AC on MiniFAP" ; \
573		}
574	@[ -z "$(findstring STK100,$@)" ] || \
575		{ echo "#define CONFIG_STK52XX_REV100"	>>$(obj)include/config.h ; \
576		  echo "... on a STK52XX.100 base board" ; \
577		}
578	@[ -z "$(findstring TQM5200_B,$@)" ] || \
579		{ echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
580		}
581	@[ -z "$(findstring TQM5200S,$@)" ] || \
582		{ echo "#define CONFIG_TQM5200S"	>>$(obj)include/config.h ; \
583		  echo "#define CONFIG_TQM5200_B"	>>$(obj)include/config.h ; \
584		}
585	@[ -z "$(findstring HIGHBOOT,$@)" ] || \
586		{ echo "TEXT_BASE = 0xFFF00000" >$(obj)board/tqm5200/config.tmp ; \
587		}
588	@$(MKCONFIG) -n $@ -a TQM5200 ppc mpc5xxx tqm5200
589
590#########################################################################
591## MPC8xx Systems
592#########################################################################
593
594Adder_config    \
595Adder87x_config \
596AdderII_config  \
597	:		unconfig
598	@mkdir -p $(obj)include
599	$(if $(findstring AdderII,$@), \
600	@echo "#define CONFIG_MPC852T" > $(obj)include/config.h)
601	@$(MKCONFIG) -a Adder ppc mpc8xx adder
602
603ADS860_config     \
604FADS823_config    \
605FADS850SAR_config \
606MPC86xADS_config  \
607MPC885ADS_config  \
608FADS860T_config:	unconfig
609	@$(MKCONFIG) $(@:_config=) ppc mpc8xx fads
610
611AMX860_config	:	unconfig
612	@$(MKCONFIG) $(@:_config=) ppc mpc8xx amx860 westel
613
614c2mon_config:		unconfig
615	@$(MKCONFIG) $(@:_config=) ppc mpc8xx c2mon
616
617CCM_config:		unconfig
618	@$(MKCONFIG) $(@:_config=) ppc mpc8xx CCM siemens
619
620cogent_mpc8xx_config:	unconfig
621	@$(MKCONFIG) $(@:_config=) ppc mpc8xx cogent
622
623ELPT860_config:		unconfig
624	@$(MKCONFIG) $(@:_config=) ppc mpc8xx elpt860 LEOX
625
626EP88x_config:		unconfig
627	@$(MKCONFIG) $(@:_config=) ppc mpc8xx ep88x
628
629ESTEEM192E_config:	unconfig
630	@$(MKCONFIG) $(@:_config=) ppc mpc8xx esteem192e
631
632ETX094_config	:	unconfig
633	@$(MKCONFIG) $(@:_config=) ppc mpc8xx etx094
634
635FLAGADM_config:	unconfig
636	@$(MKCONFIG) $(@:_config=) ppc mpc8xx flagadm
637
638xtract_GEN860T = $(subst _SC,,$(subst _config,,$1))
639
640GEN860T_SC_config	\
641GEN860T_config: unconfig
642	@mkdir -p $(obj)include
643	@ >$(obj)include/config.h
644	@[ -z "$(findstring _SC,$@)" ] || \
645		{ echo "#define CONFIG_SC" >>$(obj)include/config.h ; \
646		  echo "With reduced H/W feature set (SC)..." ; \
647		}
648	@$(MKCONFIG) -a $(call xtract_GEN860T,$@) ppc mpc8xx gen860t
649
650GENIETV_config:	unconfig
651	@$(MKCONFIG) $(@:_config=) ppc mpc8xx genietv
652
653GTH_config:	unconfig
654	@$(MKCONFIG) $(@:_config=) ppc mpc8xx gth
655
656hermes_config	:	unconfig
657	@$(MKCONFIG) $(@:_config=) ppc mpc8xx hermes
658
659HMI10_config	:	unconfig
660	@$(MKCONFIG) $(@:_config=) ppc mpc8xx tqm8xx
661
662IAD210_config: unconfig
663	@$(MKCONFIG) $(@:_config=) ppc mpc8xx IAD210 siemens
664
665xtract_ICU862 = $(subst _100MHz,,$(subst _config,,$1))
666
667ICU862_100MHz_config	\
668ICU862_config: unconfig
669	@mkdir -p $(obj)include
670	@ >$(obj)include/config.h
671	@[ -z "$(findstring _100MHz,$@)" ] || \
672		{ echo "#define CONFIG_100MHz"	>>$(obj)include/config.h ; \
673		  echo "... with 100MHz system clock" ; \
674		}
675	@$(MKCONFIG) -a $(call xtract_ICU862,$@) ppc mpc8xx icu862
676
677IP860_config	:	unconfig
678	@$(MKCONFIG) $(@:_config=) ppc mpc8xx ip860
679
680IVML24_256_config \
681IVML24_128_config \
682IVML24_config:	unconfig
683	@mkdir -p $(obj)include
684	@ >$(obj)include/config.h
685	@[ -z "$(findstring IVML24_config,$@)" ] || \
686		 { echo "#define CONFIG_IVML24_16M"	>>$(obj)include/config.h ; \
687		 }
688	@[ -z "$(findstring IVML24_128_config,$@)" ] || \
689		 { echo "#define CONFIG_IVML24_32M"	>>$(obj)include/config.h ; \
690		 }
691	@[ -z "$(findstring IVML24_256_config,$@)" ] || \
692		 { echo "#define CONFIG_IVML24_64M"	>>$(obj)include/config.h ; \
693		 }
694	@$(MKCONFIG) -a IVML24 ppc mpc8xx ivm
695
696IVMS8_256_config \
697IVMS8_128_config \
698IVMS8_config:	unconfig
699	@mkdir -p $(obj)include
700	@ >$(obj)include/config.h
701	@[ -z "$(findstring IVMS8_config,$@)" ] || \
702		 { echo "#define CONFIG_IVMS8_16M"	>>$(obj)include/config.h ; \
703		 }
704	@[ -z "$(findstring IVMS8_128_config,$@)" ] || \
705		 { echo "#define CONFIG_IVMS8_32M"	>>$(obj)include/config.h ; \
706		 }
707	@[ -z "$(findstring IVMS8_256_config,$@)" ] || \
708		 { echo "#define CONFIG_IVMS8_64M"	>>$(obj)include/config.h ; \
709		 }
710	@$(MKCONFIG) -a IVMS8 ppc mpc8xx ivm
711
712KUP4K_config	:	unconfig
713	@$(MKCONFIG) $(@:_config=) ppc mpc8xx kup4k kup
714
715KUP4X_config    :       unconfig
716	@$(MKCONFIG) $(@:_config=) ppc mpc8xx kup4x kup
717
718LANTEC_config	:	unconfig
719	@$(MKCONFIG) $(@:_config=) ppc mpc8xx lantec
720
721lwmon_config:		unconfig
722	@$(MKCONFIG) $(@:_config=) ppc mpc8xx lwmon
723
724MBX_config	\
725MBX860T_config:	unconfig
726	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mbx8xx
727
728MHPC_config:		unconfig
729	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mhpc eltec
730
731MVS1_config :		unconfig
732	@$(MKCONFIG) $(@:_config=) ppc mpc8xx mvs1
733
734xtract_NETVIA = $(subst _V2,,$(subst _config,,$1))
735
736NETVIA_V2_config \
737NETVIA_config:		unconfig
738	@mkdir -p $(obj)include
739	@ >$(obj)include/config.h
740	@[ -z "$(findstring NETVIA_config,$@)" ] || \
741		 { echo "#define CONFIG_NETVIA_VERSION 1" >>$(obj)include/config.h ; \
742		  echo "... Version 1" ; \
743		 }
744	@[ -z "$(findstring NETVIA_V2_config,$@)" ] || \
745		 { echo "#define CONFIG_NETVIA_VERSION 2" >>$(obj)include/config.h ; \
746		  echo "... Version 2" ; \
747		 }
748	@$(MKCONFIG) -a $(call xtract_NETVIA,$@) ppc mpc8xx netvia
749
750xtract_NETPHONE = $(subst _V2,,$(subst _config,,$1))
751
752NETPHONE_V2_config \
753NETPHONE_config:	unconfig
754	@mkdir -p $(obj)include
755	@ >$(obj)include/config.h
756	@[ -z "$(findstring NETPHONE_config,$@)" ] || \
757		 { echo "#define CONFIG_NETPHONE_VERSION 1" >>$(obj)include/config.h ; \
758		 }
759	@[ -z "$(findstring NETPHONE_V2_config,$@)" ] || \
760		 { echo "#define CONFIG_NETPHONE_VERSION 2" >>$(obj)include/config.h ; \
761		 }
762	@$(MKCONFIG) -a $(call xtract_NETPHONE,$@) ppc mpc8xx netphone
763
764xtract_NETTA = $(subst _SWAPHOOK,,$(subst _6412,,$(subst _ISDN,,$(subst _config,,$1))))
765
766NETTA_ISDN_6412_SWAPHOOK_config \
767NETTA_ISDN_SWAPHOOK_config \
768NETTA_6412_SWAPHOOK_config \
769NETTA_SWAPHOOK_config \
770NETTA_ISDN_6412_config \
771NETTA_ISDN_config \
772NETTA_6412_config \
773NETTA_config:		unconfig
774	@mkdir -p $(obj)include
775	@ >$(obj)include/config.h
776	@[ -z "$(findstring ISDN_,$@)" ] || \
777		 { echo "#define CONFIG_NETTA_ISDN 1" >>$(obj)include/config.h ; \
778		 }
779	@[ -n "$(findstring ISDN_,$@)" ] || \
780		 { echo "#undef CONFIG_NETTA_ISDN" >>$(obj)include/config.h ; \
781		 }
782	@[ -z "$(findstring 6412_,$@)" ] || \
783		 { echo "#define CONFIG_NETTA_6412 1" >>$(obj)include/config.h ; \
784		 }
785	@[ -n "$(findstring 6412_,$@)" ] || \
786		 { echo "#undef CONFIG_NETTA_6412" >>$(obj)include/config.h ; \
787		 }
788	@[ -z "$(findstring SWAPHOOK_,$@)" ] || \
789		 { echo "#define CONFIG_NETTA_SWAPHOOK 1" >>$(obj)include/config.h ; \
790		 }
791	@[ -n "$(findstring SWAPHOOK_,$@)" ] || \
792		 { echo "#undef CONFIG_NETTA_SWAPHOOK" >>$(obj)include/config.h ; \
793		 }
794	@$(MKCONFIG) -a $(call xtract_NETTA,$@) ppc mpc8xx netta
795
796xtract_NETTA2 = $(subst _V2,,$(subst _config,,$1))
797
798NETTA2_V2_config \
799NETTA2_config:		unconfig
800	@mkdir -p $(obj)include
801	@ >$(obj)include/config.h
802	@[ -z "$(findstring NETTA2_config,$@)" ] || \
803		 { echo "#define CONFIG_NETTA2_VERSION 1" >>$(obj)include/config.h ; \
804		 }
805	@[ -z "$(findstring NETTA2_V2_config,$@)" ] || \
806		 { echo "#define CONFIG_NETTA2_VERSION 2" >>$(obj)include/config.h ; \
807		 }
808	@$(MKCONFIG) -a $(call xtract_NETTA2,$@) ppc mpc8xx netta2
809
810NC650_Rev1_config \
811NC650_Rev2_config \
812CP850_config:	unconfig
813	@mkdir -p $(obj)include
814	@ >$(obj)include/config.h
815	@[ -z "$(findstring CP850,$@)" ] || \
816		 { echo "#define CONFIG_CP850 1" >>$(obj)include/config.h ; \
817		   echo "#define CONFIG_IDS852_REV2 1" >>$(obj)include/config.h ; \
818		 }
819	@[ -z "$(findstring Rev1,$@)" ] || \
820		 { echo "#define CONFIG_IDS852_REV1 1" >>$(obj)include/config.h ; \
821		 }
822	@[ -z "$(findstring Rev2,$@)" ] || \
823		 { echo "#define CONFIG_IDS852_REV2 1" >>$(obj)include/config.h ; \
824		 }
825	@$(MKCONFIG) -a NC650 ppc mpc8xx nc650
826
827NX823_config:		unconfig
828	@$(MKCONFIG) $(@:_config=) ppc mpc8xx nx823
829
830pcu_e_config:		unconfig
831	@$(MKCONFIG) $(@:_config=) ppc mpc8xx pcu_e siemens
832
833QS850_config:	unconfig
834	@$(MKCONFIG) $(@:_config=) ppc mpc8xx qs850 snmc
835
836QS823_config:	unconfig
837	@$(MKCONFIG) $(@:_config=) ppc mpc8xx qs850 snmc
838
839QS860T_config:	unconfig
840	@$(MKCONFIG) $(@:_config=) ppc mpc8xx qs860t snmc
841
842quantum_config:	unconfig
843	@$(MKCONFIG) $(@:_config=) ppc mpc8xx quantum
844
845R360MPI_config:	unconfig
846	@$(MKCONFIG) $(@:_config=) ppc mpc8xx r360mpi
847
848RBC823_config:	unconfig
849	@$(MKCONFIG) $(@:_config=) ppc mpc8xx rbc823
850
851RPXClassic_config:	unconfig
852	@$(MKCONFIG) $(@:_config=) ppc mpc8xx RPXClassic
853
854RPXlite_config:		unconfig
855	@$(MKCONFIG) $(@:_config=) ppc mpc8xx RPXlite
856
857RPXlite_DW_64_config  		\
858RPXlite_DW_LCD_config 		\
859RPXlite_DW_64_LCD_config 	\
860RPXlite_DW_NVRAM_config		\
861RPXlite_DW_NVRAM_64_config      \
862RPXlite_DW_NVRAM_LCD_config	\
863RPXlite_DW_NVRAM_64_LCD_config  \
864RPXlite_DW_config:         unconfig
865	@mkdir -p $(obj)include
866	@ >$(obj)include/config.h
867	@[ -z "$(findstring _64,$@)" ] || \
868		{ echo "#define RPXlite_64MHz"		>>$(obj)include/config.h ; \
869		  echo "... with 64MHz system clock ..."; \
870		}
871	@[ -z "$(findstring _LCD,$@)" ] || \
872		{ echo "#define CONFIG_LCD"          	>>$(obj)include/config.h ; \
873		  echo "#define CONFIG_NEC_NL6448BC20"	>>$(obj)include/config.h ; \
874		  echo "... with LCD display ..."; \
875		}
876	@[ -z "$(findstring _NVRAM,$@)" ] || \
877		{ echo "#define  CFG_ENV_IS_IN_NVRAM" 	>>$(obj)include/config.h ; \
878		  echo "... with ENV in NVRAM ..."; \
879		}
880	@$(MKCONFIG) -a RPXlite_DW ppc mpc8xx RPXlite_dw
881
882rmu_config:	unconfig
883	@$(MKCONFIG) $(@:_config=) ppc mpc8xx rmu
884
885RRvision_config:	unconfig
886	@$(MKCONFIG) $(@:_config=) ppc mpc8xx RRvision
887
888RRvision_LCD_config:	unconfig
889	@mkdir -p $(obj)include
890	@echo "#define CONFIG_LCD" >$(obj)include/config.h
891	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>$(obj)include/config.h
892	@$(MKCONFIG) -a RRvision ppc mpc8xx RRvision
893
894SM850_config	:	unconfig
895	@$(MKCONFIG) $(@:_config=) ppc mpc8xx tqm8xx
896
897spc1920_config:
898	@$(MKCONFIG) $(@:_config=) ppc mpc8xx spc1920
899
900SPD823TS_config:	unconfig
901	@$(MKCONFIG) $(@:_config=) ppc mpc8xx spd8xx
902
903stxxtc_config:	unconfig
904	@$(MKCONFIG) $(@:_config=) ppc mpc8xx stxxtc
905
906svm_sc8xx_config:	unconfig
907	@$(MKCONFIG) $(@:_config=) ppc mpc8xx svm_sc8xx
908
909SXNI855T_config:	unconfig
910	@$(MKCONFIG) $(@:_config=) ppc mpc8xx sixnet
911
912# EMK MPC8xx based modules
913TOP860_config:		unconfig
914	@$(MKCONFIG) $(@:_config=) ppc mpc8xx top860 emk
915
916# Play some tricks for configuration selection
917# Only 855 and 860 boards may come with FEC
918# and only 823 boards may have LCD support
919xtract_8xx = $(subst _LCD,,$(subst _config,,$1))
920
921FPS850L_config		\
922FPS860L_config		\
923NSCU_config		\
924TQM823L_config		\
925TQM823L_LCD_config	\
926TQM850L_config		\
927TQM855L_config		\
928TQM860L_config		\
929TQM862L_config		\
930TQM823M_config		\
931TQM850M_config		\
932TQM855M_config		\
933TQM860M_config		\
934TQM862M_config		\
935TQM866M_config		\
936TQM885D_config		\
937virtlab2_config:	unconfig
938	@mkdir -p $(obj)include
939	@ >$(obj)include/config.h
940	@[ -z "$(findstring _LCD,$@)" ] || \
941		{ echo "#define CONFIG_LCD"		>>$(obj)include/config.h ; \
942		  echo "#define CONFIG_NEC_NL6448BC20"	>>$(obj)include/config.h ; \
943		  echo "... with LCD display" ; \
944		}
945	@$(MKCONFIG) -a $(call xtract_8xx,$@) ppc mpc8xx tqm8xx
946
947TTTech_config:	unconfig
948	@mkdir -p $(obj)include
949	@echo "#define CONFIG_LCD" >$(obj)include/config.h
950	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>$(obj)include/config.h
951	@$(MKCONFIG) -a TQM823L ppc mpc8xx tqm8xx
952
953uc100_config	:	unconfig
954	@$(MKCONFIG) $(@:_config=) ppc mpc8xx uc100
955
956v37_config:	unconfig
957	@mkdir -p $(obj)include
958	@echo "#define CONFIG_LCD" >$(obj)include/config.h
959	@echo "#define CONFIG_SHARP_LQ084V1DG21" >>$(obj)include/config.h
960	@$(MKCONFIG) $(@:_config=) ppc mpc8xx v37
961
962wtk_config:	unconfig
963	@mkdir -p $(obj)include
964	@echo "#define CONFIG_LCD" >$(obj)include/config.h
965	@echo "#define CONFIG_SHARP_LQ065T9DR51U" >>$(obj)include/config.h
966	@$(MKCONFIG) -a TQM823L ppc mpc8xx tqm8xx
967
968#########################################################################
969## PPC4xx Systems
970#########################################################################
971xtract_4xx = $(subst _25,,$(subst _33,,$(subst _BA,,$(subst _ME,,$(subst _HI,,$(subst _config,,$1))))))
972
973ADCIOP_config:	unconfig
974	@$(MKCONFIG) $(@:_config=) ppc ppc4xx adciop esd
975
976AP1000_config:unconfig
977	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ap1000 amirix
978
979APC405_config:	unconfig
980	@$(MKCONFIG) $(@:_config=) ppc ppc4xx apc405 esd
981
982AR405_config:	unconfig
983	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ar405 esd
984
985ASH405_config:	unconfig
986	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ash405 esd
987
988bamboo_config:	unconfig
989	@$(MKCONFIG) $(@:_config=) ppc ppc4xx bamboo amcc
990
991bubinga_config:	unconfig
992	@$(MKCONFIG) $(@:_config=) ppc ppc4xx bubinga amcc
993
994CANBT_config:	unconfig
995	@$(MKCONFIG) $(@:_config=) ppc ppc4xx canbt esd
996
997CATcenter_config	\
998CATcenter_25_config	\
999CATcenter_33_config:	unconfig
1000	@mkdir -p $(obj)include
1001	@ echo "/* CATcenter uses PPChameleon Model ME */"  > $(obj)include/config.h
1002	@ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 1" >> $(obj)include/config.h
1003	@[ -z "$(findstring _25,$@)" ] || \
1004		{ echo "#define CONFIG_PPCHAMELEON_CLK_25" >> $(obj)include/config.h ; \
1005		  echo "SysClk = 25MHz" ; \
1006		}
1007	@[ -z "$(findstring _33,$@)" ] || \
1008		{ echo "#define CONFIG_PPCHAMELEON_CLK_33" >> $(obj)include/config.h ; \
1009		  echo "SysClk = 33MHz" ; \
1010		}
1011	@$(MKCONFIG) -a $(call xtract_4xx,$@) ppc ppc4xx PPChameleonEVB dave
1012
1013CPCI2DP_config:	unconfig
1014	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpci2dp esd
1015
1016CPCI405_config	\
1017CPCI4052_config	\
1018CPCI405DT_config	\
1019CPCI405AB_config:	unconfig
1020	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpci405 esd
1021	@echo "BOARD_REVISION = $(@:_config=)"	>> $(obj)include/config.mk
1022
1023CPCI440_config:	unconfig
1024	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpci440 esd
1025
1026CPCIISER4_config:	unconfig
1027	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cpciiser4 esd
1028
1029CRAYL1_config:	unconfig
1030	@$(MKCONFIG) $(@:_config=) ppc ppc4xx L1 cray
1031
1032csb272_config:	unconfig
1033	@$(MKCONFIG) $(@:_config=) ppc ppc4xx csb272
1034
1035csb472_config:	unconfig
1036	@$(MKCONFIG) $(@:_config=) ppc ppc4xx csb472
1037
1038DASA_SIM_config: unconfig
1039	@$(MKCONFIG) $(@:_config=) ppc ppc4xx dasa_sim esd
1040
1041DP405_config:	unconfig
1042	@$(MKCONFIG) $(@:_config=) ppc ppc4xx dp405 esd
1043
1044DU405_config:	unconfig
1045	@$(MKCONFIG) $(@:_config=) ppc ppc4xx du405 esd
1046
1047ebony_config:	unconfig
1048	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ebony amcc
1049
1050ERIC_config:	unconfig
1051	@$(MKCONFIG) $(@:_config=) ppc ppc4xx eric
1052
1053EXBITGEN_config:	unconfig
1054	@$(MKCONFIG) $(@:_config=) ppc ppc4xx exbitgen
1055
1056G2000_config:	unconfig
1057	@$(MKCONFIG) $(@:_config=) ppc ppc4xx g2000
1058
1059HH405_config:	unconfig
1060	@$(MKCONFIG) $(@:_config=) ppc ppc4xx hh405 esd
1061
1062HUB405_config:	unconfig
1063	@$(MKCONFIG) $(@:_config=) ppc ppc4xx hub405 esd
1064
1065JSE_config:	unconfig
1066	@$(MKCONFIG) $(@:_config=) ppc ppc4xx jse
1067
1068KAREF_config: unconfig
1069	@$(MKCONFIG) $(@:_config=) ppc ppc4xx karef sandburst
1070
1071luan_config:	unconfig
1072	@$(MKCONFIG) $(@:_config=) ppc ppc4xx luan amcc
1073
1074METROBOX_config: unconfig
1075	@$(MKCONFIG) $(@:_config=) ppc ppc4xx metrobox sandburst
1076
1077MIP405_config:	unconfig
1078	@$(MKCONFIG) $(@:_config=) ppc ppc4xx mip405 mpl
1079
1080MIP405T_config:	unconfig
1081	@mkdir -p $(obj)include
1082	@echo "#define CONFIG_MIP405T" >$(obj)include/config.h
1083	@echo "Enable subset config for MIP405T"
1084	@$(MKCONFIG) -a MIP405 ppc ppc4xx mip405 mpl
1085
1086ML2_config:	unconfig
1087	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ml2
1088
1089ml300_config:	unconfig
1090	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ml300 xilinx
1091
1092ocotea_config:	unconfig
1093	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ocotea amcc
1094
1095OCRTC_config		\
1096ORSG_config:	unconfig
1097	@$(MKCONFIG) $(@:_config=) ppc ppc4xx ocrtc esd
1098
1099p3p440_config:	unconfig
1100	@$(MKCONFIG) $(@:_config=) ppc ppc4xx p3p440 prodrive
1101
1102PCI405_config:	unconfig
1103	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pci405 esd
1104
1105pcs440ep_config:	unconfig
1106	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pcs440ep
1107
1108PIP405_config:	unconfig
1109	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pip405 mpl
1110
1111PLU405_config:	unconfig
1112	@$(MKCONFIG) $(@:_config=) ppc ppc4xx plu405 esd
1113
1114PMC405_config:	unconfig
1115	@$(MKCONFIG) $(@:_config=) ppc ppc4xx pmc405 esd
1116
1117PPChameleonEVB_config		\
1118PPChameleonEVB_BA_25_config	\
1119PPChameleonEVB_ME_25_config	\
1120PPChameleonEVB_HI_25_config	\
1121PPChameleonEVB_BA_33_config	\
1122PPChameleonEVB_ME_33_config	\
1123PPChameleonEVB_HI_33_config:	unconfig
1124	@mkdir -p $(obj)include
1125	@ >$(obj)include/config.h
1126	@[ -z "$(findstring EVB_BA,$@)" ] || \
1127		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 0" >>$(obj)include/config.h ; \
1128		  echo "... BASIC model" ; \
1129		}
1130	@[ -z "$(findstring EVB_ME,$@)" ] || \
1131		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 1" >>$(obj)include/config.h ; \
1132		  echo "... MEDIUM model" ; \
1133		}
1134	@[ -z "$(findstring EVB_HI,$@)" ] || \
1135		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 2" >>$(obj)include/config.h ; \
1136		  echo "... HIGH-END model" ; \
1137		}
1138	@[ -z "$(findstring _25,$@)" ] || \
1139		{ echo "#define CONFIG_PPCHAMELEON_CLK_25" >>$(obj)include/config.h ; \
1140		  echo "SysClk = 25MHz" ; \
1141		}
1142	@[ -z "$(findstring _33,$@)" ] || \
1143		{ echo "#define CONFIG_PPCHAMELEON_CLK_33" >>$(obj)include/config.h ; \
1144		  echo "SysClk = 33MHz" ; \
1145		}
1146	@$(MKCONFIG) -a $(call xtract_4xx,$@) ppc ppc4xx PPChameleonEVB dave
1147
1148sbc405_config:	unconfig
1149	@$(MKCONFIG) $(@:_config=) ppc ppc4xx sbc405
1150
1151sequoia_config:	unconfig
1152	@$(MKCONFIG) $(@:_config=) ppc ppc4xx sequoia amcc
1153
1154sequoia_nand_config:	unconfig
1155	@ln -s board/amcc/sequoia/Makefile nand_spl/Makefile
1156	@echo "#define CONFIG_NAND_U_BOOT" >include/config.h
1157	@echo "Compile NAND boot image for sequoia"
1158	@$(MKCONFIG) -a sequoia ppc ppc4xx sequoia amcc
1159	@echo "TEXT_BASE = 0x01000000" >board/amcc/sequoia/config.tmp
1160	@echo "CONFIG_NAND_U_BOOT = y" >> include/config.mk
1161
1162sycamore_config:	unconfig
1163	@echo "Configuring for sycamore board as subset of walnut..."
1164	@$(MKCONFIG) -a walnut ppc ppc4xx walnut amcc
1165
1166VOH405_config:	unconfig
1167	@$(MKCONFIG) $(@:_config=) ppc ppc4xx voh405 esd
1168
1169VOM405_config:	unconfig
1170	@$(MKCONFIG) $(@:_config=) ppc ppc4xx vom405 esd
1171
1172CMS700_config:	unconfig
1173	@$(MKCONFIG) $(@:_config=) ppc ppc4xx cms700 esd
1174
1175W7OLMC_config	\
1176W7OLMG_config: unconfig
1177	@$(MKCONFIG) $(@:_config=) ppc ppc4xx w7o
1178
1179walnut_config: unconfig
1180	@$(MKCONFIG) $(@:_config=) ppc ppc4xx walnut amcc
1181
1182WUH405_config:	unconfig
1183	@$(MKCONFIG) $(@:_config=) ppc ppc4xx wuh405 esd
1184
1185XPEDITE1K_config:	unconfig
1186	@$(MKCONFIG) $(@:_config=) ppc ppc4xx xpedite1k
1187
1188yosemite_config:	unconfig
1189	@$(MKCONFIG) $(@:_config=) ppc ppc4xx yosemite amcc
1190
1191yellowstone_config:	unconfig
1192	@$(MKCONFIG) $(@:_config=) ppc ppc4xx yellowstone amcc
1193
1194yucca_config:	unconfig
1195	@$(MKCONFIG) $(@:_config=) ppc ppc4xx yucca amcc
1196
1197#########################################################################
1198## MPC8220 Systems
1199#########################################################################
1200
1201Alaska8220_config	\
1202Yukon8220_config:	unconfig
1203	@$(MKCONFIG) $(@:_config=) ppc mpc8220 alaska
1204
1205sorcery_config:		unconfig
1206	@$(MKCONFIG) $(@:_config=) ppc mpc8220 sorcery
1207
1208#########################################################################
1209## MPC824x Systems
1210#########################################################################
1211xtract_82xx = $(subst _BIGFLASH,,$(subst _ROMBOOT,,$(subst _L2,,$(subst _266MHz,,$(subst _300MHz,,$(subst _config,,$1))))))
1212
1213A3000_config: unconfig
1214	@$(MKCONFIG) $(@:_config=) ppc mpc824x a3000
1215
1216barco_config: unconfig
1217	@$(MKCONFIG) $(@:_config=) ppc mpc824x barco
1218
1219BMW_config: unconfig
1220	@$(MKCONFIG) $(@:_config=) ppc mpc824x bmw
1221
1222CPC45_config	\
1223CPC45_ROMBOOT_config:	unconfig
1224	@$(MKCONFIG) $(call xtract_82xx,$@) ppc mpc824x cpc45
1225	@cd $(obj)include ;				\
1226	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1227		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
1228		echo "... booting from 8-bit flash" ; \
1229	else \
1230		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
1231		echo "... booting from 64-bit flash" ; \
1232	fi; \
1233	echo "export CONFIG_BOOT_ROM" >> config.mk;
1234
1235CU824_config: unconfig
1236	@$(MKCONFIG) $(@:_config=) ppc mpc824x cu824
1237
1238debris_config: unconfig
1239	@$(MKCONFIG) $(@:_config=) ppc mpc824x debris etin
1240
1241eXalion_config: unconfig
1242	@$(MKCONFIG) $(@:_config=) ppc mpc824x eXalion
1243
1244HIDDEN_DRAGON_config: unconfig
1245	@$(MKCONFIG) $(@:_config=) ppc mpc824x hidden_dragon
1246
1247kvme080_config: unconfig
1248	@$(MKCONFIG) $(@:_config=) ppc mpc824x kvme080 etin
1249
1250MOUSSE_config: unconfig
1251	@$(MKCONFIG) $(@:_config=) ppc mpc824x mousse
1252
1253MUSENKI_config: unconfig
1254	@$(MKCONFIG) $(@:_config=) ppc mpc824x musenki
1255
1256MVBLUE_config:	unconfig
1257	@$(MKCONFIG) $(@:_config=) ppc mpc824x mvblue
1258
1259OXC_config: unconfig
1260	@$(MKCONFIG) $(@:_config=) ppc mpc824x oxc
1261
1262PN62_config: unconfig
1263	@$(MKCONFIG) $(@:_config=) ppc mpc824x pn62
1264
1265Sandpoint8240_config: unconfig
1266	@$(MKCONFIG) $(@:_config=) ppc mpc824x sandpoint
1267
1268Sandpoint8245_config: unconfig
1269	@$(MKCONFIG) $(@:_config=) ppc mpc824x sandpoint
1270
1271sbc8240_config: unconfig
1272	@$(MKCONFIG) $(@:_config=) ppc mpc824x sbc8240
1273
1274SL8245_config: unconfig
1275	@$(MKCONFIG) $(@:_config=) ppc mpc824x sl8245
1276
1277utx8245_config: unconfig
1278	@$(MKCONFIG) $(@:_config=) ppc mpc824x utx8245
1279
1280#########################################################################
1281## MPC8260 Systems
1282#########################################################################
1283
1284atc_config:	unconfig
1285	@$(MKCONFIG) $(@:_config=) ppc mpc8260 atc
1286
1287cogent_mpc8260_config:	unconfig
1288	@$(MKCONFIG) $(@:_config=) ppc mpc8260 cogent
1289
1290CPU86_config	\
1291CPU86_ROMBOOT_config: unconfig
1292	@$(MKCONFIG) $(call xtract_82xx,$@) ppc mpc8260 cpu86
1293	@cd $(obj)include ;				\
1294	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1295		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
1296		echo "... booting from 8-bit flash" ; \
1297	else \
1298		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
1299		echo "... booting from 64-bit flash" ; \
1300	fi; \
1301	echo "export CONFIG_BOOT_ROM" >> config.mk;
1302
1303CPU87_config	\
1304CPU87_ROMBOOT_config: unconfig
1305	@$(MKCONFIG) $(call xtract_82xx,$@) ppc mpc8260 cpu87
1306	@cd $(obj)include ;				\
1307	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1308		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
1309		echo "... booting from 8-bit flash" ; \
1310	else \
1311		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
1312		echo "... booting from 64-bit flash" ; \
1313	fi; \
1314	echo "export CONFIG_BOOT_ROM" >> config.mk;
1315
1316ep8248_config	\
1317ep8248E_config	:	unconfig
1318	@$(MKCONFIG) ep8248 ppc mpc8260 ep8248
1319
1320ep8260_config:	unconfig
1321	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ep8260
1322
1323gw8260_config:	unconfig
1324	@$(MKCONFIG) $(@:_config=) ppc mpc8260 gw8260
1325
1326hymod_config:	unconfig
1327	@$(MKCONFIG) $(@:_config=) ppc mpc8260 hymod
1328
1329IDS8247_config:	unconfig
1330	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ids8247
1331
1332IPHASE4539_config:	unconfig
1333	@$(MKCONFIG) $(@:_config=) ppc mpc8260 iphase4539
1334
1335ISPAN_config		\
1336ISPAN_REVB_config:	unconfig
1337	@mkdir -p $(obj)include
1338	@if [ "$(findstring _REVB_,$@)" ] ; then \
1339		echo "#define CFG_REV_B" > $(obj)include/config.h ; \
1340	fi
1341	@$(MKCONFIG) -a ISPAN ppc mpc8260 ispan
1342
1343MPC8260ADS_config	\
1344MPC8260ADS_lowboot_config	\
1345MPC8260ADS_33MHz_config	\
1346MPC8260ADS_33MHz_lowboot_config	\
1347MPC8260ADS_40MHz_config	\
1348MPC8260ADS_40MHz_lowboot_config	\
1349MPC8272ADS_config	\
1350MPC8272ADS_lowboot_config	\
1351PQ2FADS_config		\
1352PQ2FADS_lowboot_config		\
1353PQ2FADS-VR_config	\
1354PQ2FADS-VR_lowboot_config	\
1355PQ2FADS-ZU_config	\
1356PQ2FADS-ZU_lowboot_config	\
1357PQ2FADS-ZU_66MHz_config	\
1358PQ2FADS-ZU_66MHz_lowboot_config	\
1359	:		unconfig
1360	@mkdir -p $(obj)include
1361	@mkdir -p $(obj)board/mpc8260ads
1362	$(if $(findstring PQ2FADS,$@), \
1363	@echo "#define CONFIG_ADSTYPE CFG_PQ2FADS" > $(obj)include/config.h, \
1364	@echo "#define CONFIG_ADSTYPE CFG_"$(subst MPC,,$(word 1,$(subst _, ,$@))) > $(obj)include/config.h)
1365	$(if $(findstring MHz,$@), \
1366	@echo "#define CONFIG_8260_CLKIN" $(subst MHz,,$(word 2,$(subst _, ,$@)))"000000" >> $(obj)include/config.h, \
1367	$(if $(findstring VR,$@), \
1368	@echo "#define CONFIG_8260_CLKIN 66000000" >> $(obj)include/config.h))
1369	@[ -z "$(findstring lowboot_,$@)" ] || \
1370		{ echo "TEXT_BASE = 0xFF800000" >$(obj)board/mpc8260ads/config.tmp ; \
1371		  echo "... with lowboot configuration" ; \
1372		}
1373	@$(MKCONFIG) -a MPC8260ADS ppc mpc8260 mpc8260ads
1374
1375MPC8266ADS_config:	unconfig
1376	@$(MKCONFIG) $(@:_config=) ppc mpc8260 mpc8266ads
1377
1378# PM825/PM826 default configuration:  small (= 8 MB) Flash / boot from 64-bit flash
1379PM825_config	\
1380PM825_ROMBOOT_config	\
1381PM825_BIGFLASH_config	\
1382PM825_ROMBOOT_BIGFLASH_config	\
1383PM826_config	\
1384PM826_ROMBOOT_config	\
1385PM826_BIGFLASH_config	\
1386PM826_ROMBOOT_BIGFLASH_config:	unconfig
1387	@mkdir -p $(obj)include
1388	@mkdir -p $(obj)board/pm826
1389	@if [ "$(findstring PM825_,$@)" ] ; then \
1390		echo "#define CONFIG_PCI"	>$(obj)include/config.h ; \
1391	else \
1392		>$(obj)include/config.h ; \
1393	fi
1394	@if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1395		echo "... booting from 8-bit flash" ; \
1396		echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
1397		echo "TEXT_BASE = 0xFF800000" >$(obj)board/pm826/config.tmp ; \
1398		if [ "$(findstring _BIGFLASH_,$@)" ] ; then \
1399			echo "... with 32 MB Flash" ; \
1400			echo "#define CONFIG_FLASH_32MB" >>$(obj)include/config.h ; \
1401		fi; \
1402	else \
1403		echo "... booting from 64-bit flash" ; \
1404		if [ "$(findstring _BIGFLASH_,$@)" ] ; then \
1405			echo "... with 32 MB Flash" ; \
1406			echo "#define CONFIG_FLASH_32MB" >>$(obj)include/config.h ; \
1407			echo "TEXT_BASE = 0x40000000" >$(obj)board/pm826/config.tmp ; \
1408		else \
1409			echo "TEXT_BASE = 0xFF000000" >$(obj)board/pm826/config.tmp ; \
1410		fi; \
1411	fi
1412	@$(MKCONFIG) -a PM826 ppc mpc8260 pm826
1413
1414PM828_config	\
1415PM828_PCI_config	\
1416PM828_ROMBOOT_config	\
1417PM828_ROMBOOT_PCI_config:	unconfig
1418	@mkdir -p $(obj)include
1419	@mkdir -p $(obj)board/pm826
1420	@if [ "$(findstring _PCI_,$@)" ] ; then \
1421		echo "#define CONFIG_PCI"  >>$(obj)include/config.h ; \
1422		echo "... with PCI enabled" ; \
1423	else \
1424		>$(obj)include/config.h ; \
1425	fi
1426	@if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1427		echo "... booting from 8-bit flash" ; \
1428		echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
1429		echo "TEXT_BASE = 0xFF800000" >$(obj)board/pm826/config.tmp ; \
1430	fi
1431	@$(MKCONFIG) -a PM828 ppc mpc8260 pm828
1432
1433ppmc8260_config:	unconfig
1434	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ppmc8260
1435
1436Rattler8248_config	\
1437Rattler_config:		unconfig
1438	@mkdir -p $(obj)include
1439	$(if $(findstring 8248,$@), \
1440	@echo "#define CONFIG_MPC8248" > $(obj)include/config.h)
1441	@$(MKCONFIG) -a Rattler ppc mpc8260 rattler
1442
1443RPXsuper_config:	unconfig
1444	@$(MKCONFIG) $(@:_config=) ppc mpc8260 rpxsuper
1445
1446rsdproto_config:	unconfig
1447	@$(MKCONFIG) $(@:_config=) ppc mpc8260 rsdproto
1448
1449sacsng_config:	unconfig
1450	@$(MKCONFIG) $(@:_config=) ppc mpc8260 sacsng
1451
1452sbc8260_config:	unconfig
1453	@$(MKCONFIG) $(@:_config=) ppc mpc8260 sbc8260
1454
1455SCM_config:		unconfig
1456	@$(MKCONFIG) $(@:_config=) ppc mpc8260 SCM siemens
1457
1458TQM8255_AA_config \
1459TQM8260_AA_config \
1460TQM8260_AB_config \
1461TQM8260_AC_config \
1462TQM8260_AD_config \
1463TQM8260_AE_config \
1464TQM8260_AF_config \
1465TQM8260_AG_config \
1466TQM8260_AH_config \
1467TQM8260_AI_config \
1468TQM8265_AA_config:  unconfig
1469	@mkdir -p $(obj)include
1470	@case "$@" in \
1471	TQM8255_AA_config) CTYPE=MPC8255; CFREQ=300; CACHE=no;	BMODE=8260;;  \
1472	TQM8260_AA_config) CTYPE=MPC8260; CFREQ=200; CACHE=no;	BMODE=8260;; \
1473	TQM8260_AB_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes;	BMODE=60x;;  \
1474	TQM8260_AC_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes;	BMODE=60x;;  \
1475	TQM8260_AD_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1476	TQM8260_AE_config) CTYPE=MPC8260; CFREQ=266; CACHE=no;	BMODE=8260;; \
1477	TQM8260_AF_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1478	TQM8260_AG_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=8260;; \
1479	TQM8260_AH_config) CTYPE=MPC8260; CFREQ=300; CACHE=yes;	BMODE=60x;;  \
1480	TQM8260_AI_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1481	TQM8265_AA_config) CTYPE=MPC8265; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1482	esac; \
1483	>$(obj)include/config.h ; \
1484	if [ "$${CTYPE}" != "MPC8260" ] ; then \
1485		echo "#define CONFIG_$${CTYPE}"	>>$(obj)include/config.h ; \
1486	fi; \
1487	echo "#define CONFIG_$${CFREQ}MHz"	>>$(obj)include/config.h ; \
1488	echo "... with $${CFREQ}MHz system clock" ; \
1489	if [ "$${CACHE}" == "yes" ] ; then \
1490		echo "#define CONFIG_L2_CACHE"	>>$(obj)include/config.h ; \
1491		echo "... with L2 Cache support" ; \
1492	else \
1493		echo "#undef CONFIG_L2_CACHE"	>>$(obj)include/config.h ; \
1494		echo "... without L2 Cache support" ; \
1495	fi; \
1496	if [ "$${BMODE}" == "60x" ] ; then \
1497		echo "#define CONFIG_BUSMODE_60x" >>$(obj)include/config.h ; \
1498		echo "... with 60x Bus Mode" ; \
1499	else \
1500		echo "#undef CONFIG_BUSMODE_60x"  >>$(obj)include/config.h ; \
1501		echo "... without 60x Bus Mode" ; \
1502	fi
1503	@$(MKCONFIG) -a TQM8260 ppc mpc8260 tqm8260
1504
1505VoVPN-GW_66MHz_config	\
1506VoVPN-GW_100MHz_config:		unconfig
1507	@mkdir -p $(obj)include
1508	@echo "#define CONFIG_CLKIN_$(word 2,$(subst _, ,$@))" > $(obj)include/config.h
1509	@$(MKCONFIG) -a VoVPN-GW ppc mpc8260 vovpn-gw funkwerk
1510
1511ZPC1900_config: unconfig
1512	@$(MKCONFIG) $(@:_config=) ppc mpc8260 zpc1900
1513
1514#########################################################################
1515## Coldfire
1516#########################################################################
1517
1518cobra5272_config :		unconfig
1519	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 cobra5272
1520
1521EB+MCF-EV123_config :		unconfig
1522	@mkdir -p $(obj)include
1523	@mkdir -p $(obj)board/BuS/EB+MCF-EV123
1524	@ >$(obj)include/config.h
1525	@echo "TEXT_BASE = 0xFFE00000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
1526	@$(MKCONFIG) EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
1527
1528EB+MCF-EV123_internal_config :	unconfig
1529	@mkdir -p $(obj)include
1530	@mkdir -p $(obj)board/BuS/EB+MCF-EV123
1531	@ >$(obj)include/config.h
1532	@echo "TEXT_BASE = 0xF0000000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
1533	@$(MKCONFIG) EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
1534
1535M5271EVB_config :		unconfig
1536	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5271evb
1537
1538M5272C3_config :		unconfig
1539	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5272c3
1540
1541M5282EVB_config :		unconfig
1542	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5282evb
1543
1544TASREG_config :		unconfig
1545	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 tasreg esd
1546
1547r5200_config :		unconfig
1548	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 r5200
1549
1550#########################################################################
1551## MPC83xx Systems
1552#########################################################################
1553
1554MPC8349ADS_config:	unconfig
1555	@$(MKCONFIG) $(@:_config=) ppc mpc83xx mpc8349ads
1556
1557TQM834x_config:	unconfig
1558	@$(MKCONFIG) $(@:_config=) ppc mpc83xx tqm834x
1559
1560MPC8349EMDS_config:	unconfig
1561	@$(MKCONFIG) $(@:_config=) ppc mpc83xx mpc8349emds
1562
1563#########################################################################
1564## MPC85xx Systems
1565#########################################################################
1566
1567MPC8540ADS_config:	unconfig
1568	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8540ads
1569
1570MPC8540EVAL_config \
1571MPC8540EVAL_33_config \
1572MPC8540EVAL_66_config \
1573MPC8540EVAL_33_slave_config \
1574MPC8540EVAL_66_slave_config:      unconfig
1575	@mkdir -p $(obj)include
1576	@echo "" >$(obj)include/config.h ; \
1577	if [ "$(findstring _33_,$@)" ] ; then \
1578		echo -n "... 33 MHz PCI" ; \
1579	else \
1580		echo "#define CONFIG_SYSCLK_66M" >>$(obj)include/config.h ; \
1581		echo -n "... 66 MHz PCI" ; \
1582	fi ; \
1583	if [ "$(findstring _slave_,$@)" ] ; then \
1584		echo "#define CONFIG_PCI_SLAVE" >>$(obj)include/config.h ; \
1585		echo " slave" ; \
1586	else \
1587		echo " host" ; \
1588	fi
1589	@$(MKCONFIG) -a MPC8540EVAL ppc mpc85xx mpc8540eval
1590
1591MPC8560ADS_config:	unconfig
1592	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8560ads
1593
1594MPC8541CDS_config:	unconfig
1595	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8541cds cds
1596
1597MPC8548CDS_config:	unconfig
1598	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8548cds cds
1599
1600MPC8555CDS_config:	unconfig
1601	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8555cds cds
1602
1603PM854_config:	unconfig
1604	@$(MKCONFIG) $(@:_config=) ppc mpc85xx pm854
1605
1606PM856_config:	unconfig
1607	@$(MKCONFIG) $(@:_config=) ppc mpc85xx pm856
1608
1609sbc8540_config \
1610sbc8540_33_config \
1611sbc8540_66_config:	unconfig
1612	@mkdir -p $(obj)include
1613	@if [ "$(findstring _66_,$@)" ] ; then \
1614		echo "#define CONFIG_PCI_66"	>>$(obj)include/config.h ; \
1615		echo "... 66 MHz PCI" ; \
1616	else \
1617		>$(obj)include/config.h ; \
1618		echo "... 33 MHz PCI" ; \
1619	fi
1620	@$(MKCONFIG) -a SBC8540 ppc mpc85xx sbc8560
1621
1622sbc8560_config \
1623sbc8560_33_config \
1624sbc8560_66_config:      unconfig
1625	@mkdir -p $(obj)include
1626	@if [ "$(findstring _66_,$@)" ] ; then \
1627		echo "#define CONFIG_PCI_66"	>>$(obj)include/config.h ; \
1628		echo "... 66 MHz PCI" ; \
1629	else \
1630		>$(obj)include/config.h ; \
1631		echo "... 33 MHz PCI" ; \
1632	fi
1633	@$(MKCONFIG) -a sbc8560 ppc mpc85xx sbc8560
1634
1635stxgp3_config:		unconfig
1636	@$(MKCONFIG) $(@:_config=) ppc mpc85xx stxgp3
1637
1638TQM8540_config		\
1639TQM8541_config		\
1640TQM8555_config		\
1641TQM8560_config:		unconfig
1642	@mkdir -p $(obj)include
1643	@CTYPE=$(subst TQM,,$(@:_config=)); \
1644	>$(obj)include/config.h ; \
1645	echo "... TQM"$${CTYPE}; \
1646	echo "#define CONFIG_MPC$${CTYPE}">>$(obj)include/config.h; \
1647	echo "#define CONFIG_TQM$${CTYPE}">>$(obj)include/config.h; \
1648	echo "#define CONFIG_HOSTNAME tqm$${CTYPE}">>$(obj)include/config.h; \
1649	echo "#define CONFIG_BOARDNAME \"TQM$${CTYPE}\"">>$(obj)include/config.h; \
1650	echo "#define CFG_BOOTFILE \"bootfile=/tftpboot/tqm$${CTYPE}/uImage\0\"">>$(obj)include/config.h
1651	@$(MKCONFIG) -a TQM85xx ppc mpc85xx tqm85xx
1652
1653#########################################################################
1654## 74xx/7xx Systems
1655#########################################################################
1656
1657AmigaOneG3SE_config:	unconfig
1658	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx AmigaOneG3SE MAI
1659
1660BAB7xx_config: unconfig
1661	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx bab7xx eltec
1662
1663CPCI750_config:        unconfig
1664	@$(MKCONFIG) CPCI750 ppc 74xx_7xx cpci750 esd
1665
1666DB64360_config:  unconfig
1667	@$(MKCONFIG) DB64360 ppc 74xx_7xx db64360 Marvell
1668
1669DB64460_config:  unconfig
1670	@$(MKCONFIG) DB64460 ppc 74xx_7xx db64460 Marvell
1671
1672ELPPC_config: unconfig
1673	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx elppc eltec
1674
1675EVB64260_config	\
1676EVB64260_750CX_config:	unconfig
1677	@$(MKCONFIG) EVB64260 ppc 74xx_7xx evb64260
1678
1679P3G4_config: unconfig
1680	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx evb64260
1681
1682PCIPPC2_config \
1683PCIPPC6_config: unconfig
1684	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx pcippc2
1685
1686ZUMA_config:	unconfig
1687	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx evb64260
1688
1689ppmc7xx_config: unconfig
1690	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx ppmc7xx
1691
1692#========================================================================
1693# ARM
1694#========================================================================
1695#########################################################################
1696## StrongARM Systems
1697#########################################################################
1698
1699assabet_config	:	unconfig
1700	@$(MKCONFIG) $(@:_config=) arm sa1100 assabet
1701
1702dnp1110_config	:	unconfig
1703	@$(MKCONFIG) $(@:_config=) arm sa1100 dnp1110
1704
1705gcplus_config	:	unconfig
1706	@$(MKCONFIG) $(@:_config=) arm sa1100 gcplus
1707
1708lart_config	:	unconfig
1709	@$(MKCONFIG) $(@:_config=) arm sa1100 lart
1710
1711shannon_config	:	unconfig
1712	@$(MKCONFIG) $(@:_config=) arm sa1100 shannon
1713
1714#########################################################################
1715## ARM92xT Systems
1716#########################################################################
1717
1718xtract_trab = $(subst _bigram,,$(subst _bigflash,,$(subst _old,,$(subst _config,,$1))))
1719
1720xtract_omap1610xxx = $(subst _cs0boot,,$(subst _cs3boot,,$(subst _cs_autoboot,,$(subst _config,,$1))))
1721
1722xtract_omap730p2 = $(subst _cs0boot,,$(subst _cs3boot,, $(subst _config,,$1)))
1723
1724at91rm9200dk_config	:	unconfig
1725	@$(MKCONFIG) $(@:_config=) arm arm920t at91rm9200dk NULL at91rm9200
1726
1727cmc_pu2_config	:	unconfig
1728	@$(MKCONFIG) $(@:_config=) arm arm920t cmc_pu2 NULL at91rm9200
1729
1730csb637_config	:	unconfig
1731	@$(MKCONFIG) $(@:_config=) arm arm920t csb637 NULL at91rm9200
1732
1733mp2usb_config	:	unconfig
1734	@$(MKCONFIG) $(@:_config=) arm arm920t mp2usb NULL at91rm9200
1735
1736
1737########################################################################
1738## ARM Integrator boards - see doc/README-integrator for more info.
1739integratorap_config	\
1740ap_config		\
1741ap966_config		\
1742ap922_config		\
1743ap922_XA10_config	\
1744ap7_config		\
1745ap720t_config  		\
1746ap920t_config		\
1747ap926ejs_config		\
1748ap946es_config: unconfig
1749	@board/integratorap/split_by_variant.sh $@
1750
1751integratorcp_config	\
1752cp_config		\
1753cp920t_config		\
1754cp926ejs_config		\
1755cp946es_config		\
1756cp1136_config		\
1757cp966_config		\
1758cp922_config		\
1759cp922_XA10_config	\
1760cp1026_config: unconfig
1761	@board/integratorcp/split_by_variant.sh $@
1762
1763kb9202_config	:	unconfig
1764	@$(MKCONFIG) $(@:_config=) arm arm920t kb9202 NULL at91rm9200
1765
1766lpd7a400_config \
1767lpd7a404_config:	unconfig
1768	@$(MKCONFIG) $(@:_config=) arm lh7a40x lpd7a40x
1769
1770mx1ads_config	:	unconfig
1771	@$(MKCONFIG) $(@:_config=) arm arm920t mx1ads NULL imx
1772
1773mx1fs2_config	:	unconfig
1774	@$(MKCONFIG) $(@:_config=) arm arm920t mx1fs2 NULL imx
1775
1776netstar_32_config	\
1777netstar_config:		unconfig
1778	@mkdir -p $(obj)include
1779	@if [ "$(findstring _32_,$@)" ] ; then \
1780		echo "... 32MB SDRAM" ; \
1781		echo "#define PHYS_SDRAM_1_SIZE SZ_32M" >>$(obj)include/config.h ; \
1782	else \
1783		echo "... 64MB SDRAM" ; \
1784		echo "#define PHYS_SDRAM_1_SIZE SZ_64M" >>$(obj)include/config.h ; \
1785	fi
1786	@$(MKCONFIG) -a netstar arm arm925t netstar
1787
1788omap1510inn_config :	unconfig
1789	@$(MKCONFIG) $(@:_config=) arm arm925t omap1510inn
1790
1791omap5912osk_config :	unconfig
1792	@$(MKCONFIG) $(@:_config=) arm arm926ejs omap5912osk NULL omap
1793
1794omap1610inn_config \
1795omap1610inn_cs0boot_config \
1796omap1610inn_cs3boot_config \
1797omap1610inn_cs_autoboot_config \
1798omap1610h2_config \
1799omap1610h2_cs0boot_config \
1800omap1610h2_cs3boot_config \
1801omap1610h2_cs_autoboot_config:	unconfig
1802	@mkdir -p $(obj)include
1803	@if [ "$(findstring _cs0boot_, $@)" ] ; then \
1804		echo "#define CONFIG_CS0_BOOT" >> .$(obj)/include/config.h ; \
1805		echo "... configured for CS0 boot"; \
1806	elif [ "$(findstring _cs_autoboot_, $@)" ] ; then \
1807		echo "#define CONFIG_CS_AUTOBOOT" >> $(obj)./include/config.h ; \
1808		echo "... configured for CS_AUTO boot"; \
1809	else \
1810		echo "#define CONFIG_CS3_BOOT" >> $(obj)./include/config.h ; \
1811		echo "... configured for CS3 boot"; \
1812	fi;
1813	@$(MKCONFIG) -a $(call xtract_omap1610xxx,$@) arm arm926ejs omap1610inn NULL omap
1814
1815omap730p2_config \
1816omap730p2_cs0boot_config \
1817omap730p2_cs3boot_config :	unconfig
1818	@mkdir -p $(obj)include
1819	@if [ "$(findstring _cs0boot_, $@)" ] ; then \
1820		echo "#define CONFIG_CS0_BOOT" >> $(obj)include/config.h ; \
1821		echo "... configured for CS0 boot"; \
1822	else \
1823		echo "#define CONFIG_CS3_BOOT" >> $(obj)include/config.h ; \
1824		echo "... configured for CS3 boot"; \
1825	fi;
1826	@$(MKCONFIG) -a $(call xtract_omap730p2,$@) arm arm926ejs omap730p2 NULL omap
1827
1828sbc2410x_config: unconfig
1829	@$(MKCONFIG) $(@:_config=) arm arm920t sbc2410x NULL s3c24x0
1830
1831scb9328_config	:	unconfig
1832	@$(MKCONFIG) $(@:_config=) arm arm920t scb9328 NULL imx
1833
1834smdk2400_config	:	unconfig
1835	@$(MKCONFIG) $(@:_config=) arm arm920t smdk2400 NULL s3c24x0
1836
1837smdk2410_config	:	unconfig
1838	@$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0
1839
1840SX1_config :		unconfig
1841	@$(MKCONFIG) $(@:_config=) arm arm925t sx1
1842
1843# TRAB default configuration:	8 MB Flash, 32 MB RAM
1844trab_config \
1845trab_bigram_config \
1846trab_bigflash_config \
1847trab_old_config:	unconfig
1848	@mkdir -p $(obj)include
1849	@mkdir -p $(obj)board/trab
1850	@ >$(obj)include/config.h
1851	@[ -z "$(findstring _bigram,$@)" ] || \
1852		{ echo "#define CONFIG_FLASH_8MB"  >>$(obj)include/config.h ; \
1853		  echo "#define CONFIG_RAM_32MB"   >>$(obj)include/config.h ; \
1854		  echo "... with 8 MB Flash, 32 MB RAM" ; \
1855		}
1856	@[ -z "$(findstring _bigflash,$@)" ] || \
1857		{ echo "#define CONFIG_FLASH_16MB" >>$(obj)include/config.h ; \
1858		  echo "#define CONFIG_RAM_16MB"   >>$(obj)include/config.h ; \
1859		  echo "... with 16 MB Flash, 16 MB RAM" ; \
1860		  echo "TEXT_BASE = 0x0CF40000" >$(obj)board/trab/config.tmp ; \
1861		}
1862	@[ -z "$(findstring _old,$@)" ] || \
1863		{ echo "#define CONFIG_FLASH_8MB"  >>$(obj)include/config.h ; \
1864		  echo "#define CONFIG_RAM_16MB"   >>$(obj)include/config.h ; \
1865		  echo "... with 8 MB Flash, 16 MB RAM" ; \
1866		  echo "TEXT_BASE = 0x0CF40000" >$(obj)board/trab/config.tmp ; \
1867		}
1868	@$(MKCONFIG) -a $(call xtract_trab,$@) arm arm920t trab NULL s3c24x0
1869
1870VCMA9_config	:	unconfig
1871	@$(MKCONFIG) $(@:_config=) arm arm920t vcma9 mpl s3c24x0
1872
1873#========================================================================
1874# ARM supplied Versatile development boards
1875#========================================================================
1876versatile_config	\
1877versatileab_config	\
1878versatilepb_config :	unconfig
1879	@board/versatile/split_by_variant.sh $@
1880
1881voiceblue_smallflash_config	\
1882voiceblue_config:	unconfig
1883	@mkdir -p $(obj)include
1884	@mkdir -p $(obj)board/voiceblue
1885	@if [ "$(findstring _smallflash_,$@)" ] ; then \
1886		echo "... boot from lower flash bank" ; \
1887		echo "#define VOICEBLUE_SMALL_FLASH" >>$(obj)include/config.h ; \
1888		echo "VOICEBLUE_SMALL_FLASH=y" >$(obj)board/voiceblue/config.tmp ; \
1889	else \
1890		echo "... boot from upper flash bank" ; \
1891		>$(obj)include/config.h ; \
1892		echo "VOICEBLUE_SMALL_FLASH=n" >$(obj)board/voiceblue/config.tmp ; \
1893	fi
1894	@$(MKCONFIG) -a voiceblue arm arm925t voiceblue
1895
1896cm4008_config	:	unconfig
1897	@$(MKCONFIG) $(@:_config=) arm arm920t cm4008 NULL ks8695
1898
1899cm41xx_config	:	unconfig
1900	@$(MKCONFIG) $(@:_config=) arm arm920t cm41xx NULL ks8695
1901
1902gth2_config		: 	unconfig
1903	@mkdir -p $(obj)include
1904	@ >$(obj)include/config.h
1905	@echo "#define CONFIG_GTH2 1" >>$(obj)include/config.h
1906	@$(MKCONFIG) -a gth2 mips mips gth2
1907
1908#########################################################################
1909## S3C44B0 Systems
1910#########################################################################
1911
1912B2_config	:	unconfig
1913	@$(MKCONFIG) $(@:_config=) arm s3c44b0 B2 dave
1914
1915#########################################################################
1916## ARM720T Systems
1917#########################################################################
1918
1919armadillo_config:	unconfig
1920	@$(MKCONFIG) $(@:_config=) arm arm720t armadillo
1921
1922ep7312_config	:	unconfig
1923	@$(MKCONFIG) $(@:_config=) arm arm720t ep7312
1924
1925impa7_config	:	unconfig
1926	@$(MKCONFIG) $(@:_config=) arm arm720t impa7
1927
1928modnet50_config :	unconfig
1929	@$(MKCONFIG) $(@:_config=) arm arm720t modnet50
1930
1931evb4510_config :	unconfig
1932	@$(MKCONFIG) $(@:_config=) arm arm720t evb4510
1933
1934#########################################################################
1935## XScale Systems
1936#########################################################################
1937
1938adsvix_config	:	unconfig
1939	@$(MKCONFIG) $(@:_config=) arm pxa adsvix
1940
1941cerf250_config :	unconfig
1942	@$(MKCONFIG) $(@:_config=) arm pxa cerf250
1943
1944cradle_config	:	unconfig
1945	@$(MKCONFIG) $(@:_config=) arm pxa cradle
1946
1947csb226_config	:	unconfig
1948	@$(MKCONFIG) $(@:_config=) arm pxa csb226
1949
1950delta_config :
1951	@$(MKCONFIG) $(@:_config=) arm pxa delta
1952
1953innokom_config	:	unconfig
1954	@$(MKCONFIG) $(@:_config=) arm pxa innokom
1955
1956ixdp425_config	:	unconfig
1957	@$(MKCONFIG) $(@:_config=) arm ixp ixdp425
1958
1959ixdpg425_config	:	unconfig
1960	@$(MKCONFIG) $(@:_config=) arm ixp ixdp425
1961
1962lubbock_config	:	unconfig
1963	@$(MKCONFIG) $(@:_config=) arm pxa lubbock
1964
1965pleb2_config	:	unconfig
1966	@$(MKCONFIG) $(@:_config=) arm pxa pleb2
1967
1968logodl_config	:	unconfig
1969	@$(MKCONFIG) $(@:_config=) arm pxa logodl
1970
1971pdnb3_config	:	unconfig
1972	@$(MKCONFIG) $(@:_config=) arm ixp pdnb3 prodrive
1973
1974pxa255_idp_config:	unconfig
1975	@$(MKCONFIG) $(@:_config=) arm pxa pxa255_idp
1976
1977wepep250_config	:	unconfig
1978	@$(MKCONFIG) $(@:_config=) arm pxa wepep250
1979
1980xaeniax_config	:	unconfig
1981	@$(MKCONFIG) $(@:_config=) arm pxa xaeniax
1982
1983xm250_config	:	unconfig
1984	@$(MKCONFIG) $(@:_config=) arm pxa xm250
1985
1986xsengine_config :	unconfig
1987	@$(MKCONFIG) $(@:_config=) arm pxa xsengine
1988
1989zylonite_config :
1990	@$(MKCONFIG) $(@:_config=) arm pxa zylonite
1991
1992#########################################################################
1993## ARM1136 Systems
1994#########################################################################
1995omap2420h4_config :    unconfig
1996	@$(MKCONFIG) $(@:_config=) arm arm1136 omap2420h4
1997
1998#========================================================================
1999# i386
2000#========================================================================
2001#########################################################################
2002## AMD SC520 CDP
2003#########################################################################
2004sc520_cdp_config	:	unconfig
2005	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_cdp
2006
2007sc520_spunk_config	:	unconfig
2008	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_spunk
2009
2010sc520_spunk_rel_config	:	unconfig
2011	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_spunk
2012
2013#========================================================================
2014# MIPS
2015#========================================================================
2016#########################################################################
2017## MIPS32 4Kc
2018#########################################################################
2019
2020xtract_incaip = $(subst _100MHz,,$(subst _133MHz,,$(subst _150MHz,,$(subst _config,,$1))))
2021
2022incaip_100MHz_config	\
2023incaip_133MHz_config	\
2024incaip_150MHz_config	\
2025incaip_config: unconfig
2026	@mkdir -p $(obj)include
2027	@ >$(obj)include/config.h
2028	@[ -z "$(findstring _100MHz,$@)" ] || \
2029		{ echo "#define CPU_CLOCK_RATE 100000000" >>$(obj)include/config.h ; \
2030		  echo "... with 100MHz system clock" ; \
2031		}
2032	@[ -z "$(findstring _133MHz,$@)" ] || \
2033		{ echo "#define CPU_CLOCK_RATE 133000000" >>$(obj)include/config.h ; \
2034		  echo "... with 133MHz system clock" ; \
2035		}
2036	@[ -z "$(findstring _150MHz,$@)" ] || \
2037		{ echo "#define CPU_CLOCK_RATE 150000000" >>$(obj)include/config.h ; \
2038		  echo "... with 150MHz system clock" ; \
2039		}
2040	@$(MKCONFIG) -a $(call xtract_incaip,$@) mips mips incaip
2041
2042tb0229_config: unconfig
2043	@$(MKCONFIG) $(@:_config=) mips mips tb0229
2044
2045#########################################################################
2046## MIPS32 AU1X00
2047#########################################################################
2048dbau1000_config		: 	unconfig
2049	@mkdir -p $(obj)include
2050	@ >$(obj)include/config.h
2051	@echo "#define CONFIG_DBAU1000 1" >>$(obj)include/config.h
2052	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2053
2054dbau1100_config		: 	unconfig
2055	@mkdir -p $(obj)include
2056	@ >$(obj)include/config.h
2057	@echo "#define CONFIG_DBAU1100 1" >>$(obj)include/config.h
2058	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2059
2060dbau1500_config		: 	unconfig
2061	@mkdir -p $(obj)include
2062	@ >$(obj)include/config.h
2063	@echo "#define CONFIG_DBAU1500 1" >>$(obj)include/config.h
2064	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2065
2066dbau1550_config		:	unconfig
2067	@mkdir -p $(obj)include
2068	@ >$(obj)include/config.h
2069	@echo "#define CONFIG_DBAU1550 1" >>$(obj)include/config.h
2070	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2071
2072dbau1550_el_config	:	unconfig
2073	@mkdir -p $(obj)include
2074	@ >$(obj)include/config.h
2075	@echo "#define CONFIG_DBAU1550 1" >>$(obj)include/config.h
2076	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2077
2078pb1000_config		: 	unconfig
2079	@mkdir -p $(obj)include
2080	@ >$(obj)include/config.h
2081	@echo "#define CONFIG_PB1000 1" >>$(obj)include/config.h
2082	@$(MKCONFIG) -a pb1x00 mips mips pb1x00
2083
2084#########################################################################
2085## MIPS64 5Kc
2086#########################################################################
2087
2088purple_config :		unconfig
2089	@$(MKCONFIG) $(@:_config=) mips mips purple
2090
2091#========================================================================
2092# Nios
2093#========================================================================
2094#########################################################################
2095## Nios32
2096#########################################################################
2097
2098DK1C20_safe_32_config		\
2099DK1C20_standard_32_config	\
2100DK1C20_config:	unconfig
2101	@mkdir -p $(obj)include
2102	@ >$(obj)include/config.h
2103	@[ -z "$(findstring _safe_32,$@)" ] || \
2104		{ echo "#define CONFIG_NIOS_SAFE_32 1" >>$(obj)include/config.h ; \
2105		  echo "... NIOS 'safe_32' configuration" ; \
2106		}
2107	@[ -z "$(findstring _standard_32,$@)" ] || \
2108		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2109		  echo "... NIOS 'standard_32' configuration" ; \
2110		}
2111	@[ -z "$(findstring DK1C20_config,$@)" ] || \
2112		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2113		  echo "... NIOS 'standard_32' configuration (DEFAULT)" ; \
2114		}
2115	@$(MKCONFIG) -a DK1C20 nios nios dk1c20 altera
2116
2117DK1S10_safe_32_config		\
2118DK1S10_standard_32_config	\
2119DK1S10_mtx_ldk_20_config	\
2120DK1S10_config:	unconfig
2121	@mkdir -p $(obj)include
2122	@ >$(obj)include/config.h
2123	@[ -z "$(findstring _safe_32,$@)" ] || \
2124		{ echo "#define CONFIG_NIOS_SAFE_32 1" >>$(obj)include/config.h ; \
2125		  echo "... NIOS 'safe_32' configuration" ; \
2126		}
2127	@[ -z "$(findstring _standard_32,$@)" ] || \
2128		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2129		  echo "... NIOS 'standard_32' configuration" ; \
2130		}
2131	@[ -z "$(findstring _mtx_ldk_20,$@)" ] || \
2132		{ echo "#define CONFIG_NIOS_MTX_LDK_20 1" >>$(obj)include/config.h ; \
2133		  echo "... NIOS 'mtx_ldk_20' configuration" ; \
2134		}
2135	@[ -z "$(findstring DK1S10_config,$@)" ] || \
2136		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2137		  echo "... NIOS 'standard_32' configuration (DEFAULT)" ; \
2138		}
2139	@$(MKCONFIG) -a DK1S10 nios nios dk1s10 altera
2140
2141ADNPESC1_DNPEVA2_base_32_config	\
2142ADNPESC1_base_32_config		\
2143ADNPESC1_config: unconfig
2144	@mkdir -p $(obj)include
2145	@ >$(obj)include/config.h
2146	@[ -z "$(findstring _DNPEVA2,$@)" ] || \
2147		{ echo "#define CONFIG_DNPEVA2 1" >>$(obj)include/config.h ; \
2148		  echo "... DNP/EVA2 configuration" ; \
2149		}
2150	@[ -z "$(findstring _base_32,$@)" ] || \
2151		{ echo "#define CONFIG_NIOS_BASE_32 1" >>$(obj)include/config.h ; \
2152		  echo "... NIOS 'base_32' configuration" ; \
2153		}
2154	@[ -z "$(findstring ADNPESC1_config,$@)" ] || \
2155		{ echo "#define CONFIG_NIOS_BASE_32 1" >>$(obj)include/config.h ; \
2156		  echo "... NIOS 'base_32' configuration (DEFAULT)" ; \
2157		}
2158	@$(MKCONFIG) -a ADNPESC1 nios nios adnpesc1 ssv
2159
2160#########################################################################
2161## Nios-II
2162#########################################################################
2163
2164EP1C20_config : unconfig
2165	@$(MKCONFIG)  EP1C20 nios2 nios2 ep1c20 altera
2166
2167EP1S10_config : unconfig
2168	@$(MKCONFIG)  EP1S10 nios2 nios2 ep1s10 altera
2169
2170EP1S40_config : unconfig
2171	@$(MKCONFIG)  EP1S40 nios2 nios2 ep1s40 altera
2172
2173PK1C20_config : unconfig
2174	@$(MKCONFIG)  PK1C20 nios2 nios2 pk1c20 psyent
2175
2176PCI5441_config : unconfig
2177	@$(MKCONFIG)  PCI5441 nios2 nios2 pci5441 psyent
2178
2179#========================================================================
2180# MicroBlaze
2181#========================================================================
2182#########################################################################
2183## Microblaze
2184#########################################################################
2185suzaku_config:	unconfig
2186	@mkdir -p $(obj)include
2187	@ >$(obj)include/config.h
2188	@echo "#define CONFIG_SUZAKU 1" >> $(obj)include/config.h
2189	@$(MKCONFIG) -a $(@:_config=) microblaze microblaze suzaku AtmarkTechno
2190
2191#########################################################################
2192## Blackfin
2193#########################################################################
2194ezkit533_config	:	unconfig
2195	@$(MKCONFIG) $(@:_config=) blackfin bf533 ezkit533
2196
2197stamp_config	:	unconfig
2198	@$(MKCONFIG) $(@:_config=) blackfin bf533 stamp
2199
2200dspstamp_config	:	unconfig
2201	@$(MKCONFIG) $(@:_config=) blackfin bf533 dsp_stamp
2202
2203#########################################################################
2204#########################################################################
2205#########################################################################
2206
2207clean:
2208	find $(OBJTREE) -type f \
2209		\( -name 'core' -o -name '*.bak' -o -name '*~' \
2210		-o -name '*.o'  -o -name '*.a'  \) -print \
2211		| xargs rm -f
2212	rm -f $(obj)examples/hello_world $(obj)examples/timer \
2213	      $(obj)examples/eepro100_eeprom $(obj)examples/sched \
2214	      $(obj)examples/mem_to_mem_idma2intr $(obj)examples/82559_eeprom \
2215	      $(obj)examples/smc91111_eeprom $(obj)examples/interrupt \
2216	      $(obj)examples/test_burst
2217	rm -f $(obj)tools/img2srec $(obj)tools/mkimage $(obj)tools/envcrc \
2218		$(obj)tools/gen_eth_addr
2219	rm -f $(obj)tools/mpc86x_clk $(obj)tools/ncb
2220	rm -f $(obj)tools/easylogo/easylogo $(obj)tools/bmp_logo
2221	rm -f $(obj)tools/gdb/astest $(obj)tools/gdb/gdbcont $(obj)tools/gdb/gdbsend
2222	rm -f $(obj)tools/env/fw_printenv $(obj)tools/env/fw_setenv
2223	rm -f $(obj)board/cray/L1/bootscript.c $(obj)board/cray/L1/bootscript.image
2224	rm -f $(obj)board/netstar/eeprom $(obj)board/netstar/crcek $(obj)board/netstar/crcit
2225	rm -f $(obj)board/netstar/*.srec $(obj)board/netstar/*.bin
2226	rm -f $(obj)board/trab/trab_fkt $(obj)board/voiceblue/eeprom
2227	rm -f $(obj)board/integratorap/u-boot.lds $(obj)board/integratorcp/u-boot.lds
2228	rm -f $(obj)include/bmp_logo.h
2229	find nand_spl -lname "*" -print | xargs rm -f
2230	rm -f nand_spl/u-boot-spl nand_spl/u-boot-spl.map
2231
2232clobber:	clean
2233	find $(OBJTREE) -type f \( -name .depend \
2234		-o -name '*.srec' -o -name '*.bin' -o -name u-boot.img \) \
2235		-print0 \
2236		| xargs -0 rm -f
2237	rm -f $(OBJS) $(obj)*.bak $(obj)ctags $(obj)etags $(obj)TAGS $(obj)include/version_autogenerated.h
2238	rm -fr $(obj)*.*~
2239	rm -f $(obj)u-boot $(obj)u-boot.map $(obj)u-boot.hex $(ALL)
2240	rm -f $(obj)tools/crc32.c $(obj)tools/environment.c $(obj)tools/env/crc32.c
2241	rm -f $(obj)tools/inca-swap-bytes $(obj)cpu/mpc824x/bedbug_603e.c
2242	rm -f $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm
2243
2244ifeq ($(OBJTREE),$(SRCTREE))
2245mrproper \
2246distclean:	clobber unconfig
2247else
2248mrproper \
2249distclean:	clobber unconfig
2250	rm -rf $(OBJTREE)/*
2251endif
2252
2253backup:
2254	F=`basename $(TOPDIR)` ; cd .. ; \
2255	gtar --force-local -zcvf `date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
2256
2257#########################################################################
2258