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