xref: /rk3399_rockchip-uboot/Makefile (revision 854bc8da75709f13dab4cfa6e9094c0cb49b5c5a)
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
1335gw8260_config:	unconfig
1336	@$(MKCONFIG) $(@:_config=) ppc mpc8260 gw8260
1337
1338hymod_config:	unconfig
1339	@$(MKCONFIG) $(@:_config=) ppc mpc8260 hymod
1340
1341IDS8247_config:	unconfig
1342	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ids8247
1343
1344IPHASE4539_config:	unconfig
1345	@$(MKCONFIG) $(@:_config=) ppc mpc8260 iphase4539
1346
1347ISPAN_config		\
1348ISPAN_REVB_config:	unconfig
1349	@mkdir -p $(obj)include
1350	@if [ "$(findstring _REVB_,$@)" ] ; then \
1351		echo "#define CFG_REV_B" > $(obj)include/config.h ; \
1352	fi
1353	@$(MKCONFIG) -a ISPAN ppc mpc8260 ispan
1354
1355MPC8260ADS_config	\
1356MPC8260ADS_lowboot_config	\
1357MPC8260ADS_33MHz_config	\
1358MPC8260ADS_33MHz_lowboot_config	\
1359MPC8260ADS_40MHz_config	\
1360MPC8260ADS_40MHz_lowboot_config	\
1361MPC8272ADS_config	\
1362MPC8272ADS_lowboot_config	\
1363PQ2FADS_config		\
1364PQ2FADS_lowboot_config		\
1365PQ2FADS-VR_config	\
1366PQ2FADS-VR_lowboot_config	\
1367PQ2FADS-ZU_config	\
1368PQ2FADS-ZU_lowboot_config	\
1369PQ2FADS-ZU_66MHz_config	\
1370PQ2FADS-ZU_66MHz_lowboot_config	\
1371	:		unconfig
1372	@mkdir -p $(obj)include
1373	@mkdir -p $(obj)board/mpc8260ads
1374	$(if $(findstring PQ2FADS,$@), \
1375	@echo "#define CONFIG_ADSTYPE CFG_PQ2FADS" > $(obj)include/config.h, \
1376	@echo "#define CONFIG_ADSTYPE CFG_"$(subst MPC,,$(word 1,$(subst _, ,$@))) > $(obj)include/config.h)
1377	$(if $(findstring MHz,$@), \
1378	@echo "#define CONFIG_8260_CLKIN" $(subst MHz,,$(word 2,$(subst _, ,$@)))"000000" >> $(obj)include/config.h, \
1379	$(if $(findstring VR,$@), \
1380	@echo "#define CONFIG_8260_CLKIN 66000000" >> $(obj)include/config.h))
1381	@[ -z "$(findstring lowboot_,$@)" ] || \
1382		{ echo "TEXT_BASE = 0xFF800000" >$(obj)board/mpc8260ads/config.tmp ; \
1383		  echo "... with lowboot configuration" ; \
1384		}
1385	@$(MKCONFIG) -a MPC8260ADS ppc mpc8260 mpc8260ads
1386
1387MPC8266ADS_config:	unconfig
1388	@$(MKCONFIG) $(@:_config=) ppc mpc8260 mpc8266ads
1389
1390# PM825/PM826 default configuration:  small (= 8 MB) Flash / boot from 64-bit flash
1391PM825_config	\
1392PM825_ROMBOOT_config	\
1393PM825_BIGFLASH_config	\
1394PM825_ROMBOOT_BIGFLASH_config	\
1395PM826_config	\
1396PM826_ROMBOOT_config	\
1397PM826_BIGFLASH_config	\
1398PM826_ROMBOOT_BIGFLASH_config:	unconfig
1399	@mkdir -p $(obj)include
1400	@mkdir -p $(obj)board/pm826
1401	@if [ "$(findstring PM825_,$@)" ] ; then \
1402		echo "#define CONFIG_PCI"	>$(obj)include/config.h ; \
1403	else \
1404		>$(obj)include/config.h ; \
1405	fi
1406	@if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1407		echo "... booting from 8-bit flash" ; \
1408		echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
1409		echo "TEXT_BASE = 0xFF800000" >$(obj)board/pm826/config.tmp ; \
1410		if [ "$(findstring _BIGFLASH_,$@)" ] ; then \
1411			echo "... with 32 MB Flash" ; \
1412			echo "#define CONFIG_FLASH_32MB" >>$(obj)include/config.h ; \
1413		fi; \
1414	else \
1415		echo "... booting from 64-bit flash" ; \
1416		if [ "$(findstring _BIGFLASH_,$@)" ] ; then \
1417			echo "... with 32 MB Flash" ; \
1418			echo "#define CONFIG_FLASH_32MB" >>$(obj)include/config.h ; \
1419			echo "TEXT_BASE = 0x40000000" >$(obj)board/pm826/config.tmp ; \
1420		else \
1421			echo "TEXT_BASE = 0xFF000000" >$(obj)board/pm826/config.tmp ; \
1422		fi; \
1423	fi
1424	@$(MKCONFIG) -a PM826 ppc mpc8260 pm826
1425
1426PM828_config	\
1427PM828_PCI_config	\
1428PM828_ROMBOOT_config	\
1429PM828_ROMBOOT_PCI_config:	unconfig
1430	@mkdir -p $(obj)include
1431	@mkdir -p $(obj)board/pm826
1432	@if [ "$(findstring _PCI_,$@)" ] ; then \
1433		echo "#define CONFIG_PCI"  >>$(obj)include/config.h ; \
1434		echo "... with PCI enabled" ; \
1435	else \
1436		>$(obj)include/config.h ; \
1437	fi
1438	@if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
1439		echo "... booting from 8-bit flash" ; \
1440		echo "#define CONFIG_BOOT_ROM" >>$(obj)include/config.h ; \
1441		echo "TEXT_BASE = 0xFF800000" >$(obj)board/pm826/config.tmp ; \
1442	fi
1443	@$(MKCONFIG) -a PM828 ppc mpc8260 pm828
1444
1445ppmc8260_config:	unconfig
1446	@$(MKCONFIG) $(@:_config=) ppc mpc8260 ppmc8260
1447
1448Rattler8248_config	\
1449Rattler_config:		unconfig
1450	@mkdir -p $(obj)include
1451	$(if $(findstring 8248,$@), \
1452	@echo "#define CONFIG_MPC8248" > $(obj)include/config.h)
1453	@$(MKCONFIG) -a Rattler ppc mpc8260 rattler
1454
1455RPXsuper_config:	unconfig
1456	@$(MKCONFIG) $(@:_config=) ppc mpc8260 rpxsuper
1457
1458rsdproto_config:	unconfig
1459	@$(MKCONFIG) $(@:_config=) ppc mpc8260 rsdproto
1460
1461sacsng_config:	unconfig
1462	@$(MKCONFIG) $(@:_config=) ppc mpc8260 sacsng
1463
1464sbc8260_config:	unconfig
1465	@$(MKCONFIG) $(@:_config=) ppc mpc8260 sbc8260
1466
1467SCM_config:		unconfig
1468	@$(MKCONFIG) $(@:_config=) ppc mpc8260 SCM siemens
1469
1470TQM8255_AA_config \
1471TQM8260_AA_config \
1472TQM8260_AB_config \
1473TQM8260_AC_config \
1474TQM8260_AD_config \
1475TQM8260_AE_config \
1476TQM8260_AF_config \
1477TQM8260_AG_config \
1478TQM8260_AH_config \
1479TQM8260_AI_config \
1480TQM8265_AA_config:  unconfig
1481	@mkdir -p $(obj)include
1482	@case "$@" in \
1483	TQM8255_AA_config) CTYPE=MPC8255; CFREQ=300; CACHE=no;	BMODE=8260;;  \
1484	TQM8260_AA_config) CTYPE=MPC8260; CFREQ=200; CACHE=no;	BMODE=8260;; \
1485	TQM8260_AB_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes;	BMODE=60x;;  \
1486	TQM8260_AC_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes;	BMODE=60x;;  \
1487	TQM8260_AD_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1488	TQM8260_AE_config) CTYPE=MPC8260; CFREQ=266; CACHE=no;	BMODE=8260;; \
1489	TQM8260_AF_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1490	TQM8260_AG_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=8260;; \
1491	TQM8260_AH_config) CTYPE=MPC8260; CFREQ=300; CACHE=yes;	BMODE=60x;;  \
1492	TQM8260_AI_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1493	TQM8265_AA_config) CTYPE=MPC8265; CFREQ=300; CACHE=no;	BMODE=60x;;  \
1494	esac; \
1495	>$(obj)include/config.h ; \
1496	if [ "$${CTYPE}" != "MPC8260" ] ; then \
1497		echo "#define CONFIG_$${CTYPE}"	>>$(obj)include/config.h ; \
1498	fi; \
1499	echo "#define CONFIG_$${CFREQ}MHz"	>>$(obj)include/config.h ; \
1500	echo "... with $${CFREQ}MHz system clock" ; \
1501	if [ "$${CACHE}" == "yes" ] ; then \
1502		echo "#define CONFIG_L2_CACHE"	>>$(obj)include/config.h ; \
1503		echo "... with L2 Cache support" ; \
1504	else \
1505		echo "#undef CONFIG_L2_CACHE"	>>$(obj)include/config.h ; \
1506		echo "... without L2 Cache support" ; \
1507	fi; \
1508	if [ "$${BMODE}" == "60x" ] ; then \
1509		echo "#define CONFIG_BUSMODE_60x" >>$(obj)include/config.h ; \
1510		echo "... with 60x Bus Mode" ; \
1511	else \
1512		echo "#undef CONFIG_BUSMODE_60x"  >>$(obj)include/config.h ; \
1513		echo "... without 60x Bus Mode" ; \
1514	fi
1515	@$(MKCONFIG) -a TQM8260 ppc mpc8260 tqm8260
1516
1517VoVPN-GW_66MHz_config	\
1518VoVPN-GW_100MHz_config:		unconfig
1519	@mkdir -p $(obj)include
1520	@echo "#define CONFIG_CLKIN_$(word 2,$(subst _, ,$@))" > $(obj)include/config.h
1521	@$(MKCONFIG) -a VoVPN-GW ppc mpc8260 vovpn-gw funkwerk
1522
1523ZPC1900_config: unconfig
1524	@$(MKCONFIG) $(@:_config=) ppc mpc8260 zpc1900
1525
1526#########################################################################
1527## Coldfire
1528#########################################################################
1529
1530cobra5272_config :		unconfig
1531	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 cobra5272
1532
1533EB+MCF-EV123_config :		unconfig
1534	@mkdir -p $(obj)include
1535	@mkdir -p $(obj)board/BuS/EB+MCF-EV123
1536	@ >$(obj)include/config.h
1537	@echo "TEXT_BASE = 0xFFE00000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
1538	@$(MKCONFIG) EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
1539
1540EB+MCF-EV123_internal_config :	unconfig
1541	@mkdir -p $(obj)include
1542	@mkdir -p $(obj)board/BuS/EB+MCF-EV123
1543	@ >$(obj)include/config.h
1544	@echo "TEXT_BASE = 0xF0000000"|tee $(obj)board/BuS/EB+MCF-EV123/textbase.mk
1545	@$(MKCONFIG) EB+MCF-EV123 m68k mcf52x2 EB+MCF-EV123 BuS
1546
1547M5271EVB_config :		unconfig
1548	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5271evb
1549
1550M5272C3_config :		unconfig
1551	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5272c3
1552
1553M5282EVB_config :		unconfig
1554	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 m5282evb
1555
1556TASREG_config :		unconfig
1557	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 tasreg esd
1558
1559r5200_config :		unconfig
1560	@$(MKCONFIG) $(@:_config=) m68k mcf52x2 r5200
1561
1562#########################################################################
1563## MPC83xx Systems
1564#########################################################################
1565
1566MPC8349ADS_config:	unconfig
1567	@$(MKCONFIG) $(@:_config=) ppc mpc83xx mpc8349ads
1568
1569TQM834x_config:	unconfig
1570	@$(MKCONFIG) $(@:_config=) ppc mpc83xx tqm834x
1571
1572MPC8349EMDS_config:	unconfig
1573	@$(MKCONFIG) $(@:_config=) ppc mpc83xx mpc8349emds
1574
1575#########################################################################
1576## MPC85xx Systems
1577#########################################################################
1578
1579MPC8540ADS_config:	unconfig
1580	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8540ads
1581
1582MPC8540EVAL_config \
1583MPC8540EVAL_33_config \
1584MPC8540EVAL_66_config \
1585MPC8540EVAL_33_slave_config \
1586MPC8540EVAL_66_slave_config:      unconfig
1587	@mkdir -p $(obj)include
1588	@echo "" >$(obj)include/config.h ; \
1589	if [ "$(findstring _33_,$@)" ] ; then \
1590		echo -n "... 33 MHz PCI" ; \
1591	else \
1592		echo "#define CONFIG_SYSCLK_66M" >>$(obj)include/config.h ; \
1593		echo -n "... 66 MHz PCI" ; \
1594	fi ; \
1595	if [ "$(findstring _slave_,$@)" ] ; then \
1596		echo "#define CONFIG_PCI_SLAVE" >>$(obj)include/config.h ; \
1597		echo " slave" ; \
1598	else \
1599		echo " host" ; \
1600	fi
1601	@$(MKCONFIG) -a MPC8540EVAL ppc mpc85xx mpc8540eval
1602
1603MPC8560ADS_config:	unconfig
1604	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8560ads
1605
1606MPC8541CDS_config:	unconfig
1607	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8541cds cds
1608
1609MPC8548CDS_config:	unconfig
1610	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8548cds cds
1611
1612MPC8555CDS_config:	unconfig
1613	@$(MKCONFIG) $(@:_config=) ppc mpc85xx mpc8555cds cds
1614
1615PM854_config:	unconfig
1616	@$(MKCONFIG) $(@:_config=) ppc mpc85xx pm854
1617
1618PM856_config:	unconfig
1619	@$(MKCONFIG) $(@:_config=) ppc mpc85xx pm856
1620
1621sbc8540_config \
1622sbc8540_33_config \
1623sbc8540_66_config:	unconfig
1624	@mkdir -p $(obj)include
1625	@if [ "$(findstring _66_,$@)" ] ; then \
1626		echo "#define CONFIG_PCI_66"	>>$(obj)include/config.h ; \
1627		echo "... 66 MHz PCI" ; \
1628	else \
1629		>$(obj)include/config.h ; \
1630		echo "... 33 MHz PCI" ; \
1631	fi
1632	@$(MKCONFIG) -a SBC8540 ppc mpc85xx sbc8560
1633
1634sbc8560_config \
1635sbc8560_33_config \
1636sbc8560_66_config:      unconfig
1637	@mkdir -p $(obj)include
1638	@if [ "$(findstring _66_,$@)" ] ; then \
1639		echo "#define CONFIG_PCI_66"	>>$(obj)include/config.h ; \
1640		echo "... 66 MHz PCI" ; \
1641	else \
1642		>$(obj)include/config.h ; \
1643		echo "... 33 MHz PCI" ; \
1644	fi
1645	@$(MKCONFIG) -a sbc8560 ppc mpc85xx sbc8560
1646
1647stxgp3_config:		unconfig
1648	@$(MKCONFIG) $(@:_config=) ppc mpc85xx stxgp3
1649
1650TQM8540_config		\
1651TQM8541_config		\
1652TQM8555_config		\
1653TQM8560_config:		unconfig
1654	@mkdir -p $(obj)include
1655	@CTYPE=$(subst TQM,,$(@:_config=)); \
1656	>$(obj)include/config.h ; \
1657	echo "... TQM"$${CTYPE}; \
1658	echo "#define CONFIG_MPC$${CTYPE}">>$(obj)include/config.h; \
1659	echo "#define CONFIG_TQM$${CTYPE}">>$(obj)include/config.h; \
1660	echo "#define CONFIG_HOSTNAME tqm$${CTYPE}">>$(obj)include/config.h; \
1661	echo "#define CONFIG_BOARDNAME \"TQM$${CTYPE}\"">>$(obj)include/config.h; \
1662	echo "#define CFG_BOOTFILE \"bootfile=/tftpboot/tqm$${CTYPE}/uImage\0\"">>$(obj)include/config.h
1663	@$(MKCONFIG) -a TQM85xx ppc mpc85xx tqm85xx
1664
1665#########################################################################
1666## 74xx/7xx Systems
1667#########################################################################
1668
1669AmigaOneG3SE_config:	unconfig
1670	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx AmigaOneG3SE MAI
1671
1672BAB7xx_config: unconfig
1673	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx bab7xx eltec
1674
1675CPCI750_config:        unconfig
1676	@$(MKCONFIG) CPCI750 ppc 74xx_7xx cpci750 esd
1677
1678DB64360_config:  unconfig
1679	@$(MKCONFIG) DB64360 ppc 74xx_7xx db64360 Marvell
1680
1681DB64460_config:  unconfig
1682	@$(MKCONFIG) DB64460 ppc 74xx_7xx db64460 Marvell
1683
1684ELPPC_config: unconfig
1685	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx elppc eltec
1686
1687EVB64260_config	\
1688EVB64260_750CX_config:	unconfig
1689	@$(MKCONFIG) EVB64260 ppc 74xx_7xx evb64260
1690
1691P3G4_config: unconfig
1692	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx evb64260
1693
1694PCIPPC2_config \
1695PCIPPC6_config: unconfig
1696	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx pcippc2
1697
1698ZUMA_config:	unconfig
1699	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx evb64260
1700
1701ppmc7xx_config: unconfig
1702	@$(MKCONFIG) $(@:_config=) ppc 74xx_7xx ppmc7xx
1703
1704#========================================================================
1705# ARM
1706#========================================================================
1707#########################################################################
1708## StrongARM Systems
1709#########################################################################
1710
1711assabet_config	:	unconfig
1712	@$(MKCONFIG) $(@:_config=) arm sa1100 assabet
1713
1714dnp1110_config	:	unconfig
1715	@$(MKCONFIG) $(@:_config=) arm sa1100 dnp1110
1716
1717gcplus_config	:	unconfig
1718	@$(MKCONFIG) $(@:_config=) arm sa1100 gcplus
1719
1720lart_config	:	unconfig
1721	@$(MKCONFIG) $(@:_config=) arm sa1100 lart
1722
1723shannon_config	:	unconfig
1724	@$(MKCONFIG) $(@:_config=) arm sa1100 shannon
1725
1726#########################################################################
1727## ARM92xT Systems
1728#########################################################################
1729
1730xtract_trab = $(subst _bigram,,$(subst _bigflash,,$(subst _old,,$(subst _config,,$1))))
1731
1732xtract_omap1610xxx = $(subst _cs0boot,,$(subst _cs3boot,,$(subst _cs_autoboot,,$(subst _config,,$1))))
1733
1734xtract_omap730p2 = $(subst _cs0boot,,$(subst _cs3boot,, $(subst _config,,$1)))
1735
1736at91rm9200dk_config	:	unconfig
1737	@$(MKCONFIG) $(@:_config=) arm arm920t at91rm9200dk NULL at91rm9200
1738
1739cmc_pu2_config	:	unconfig
1740	@$(MKCONFIG) $(@:_config=) arm arm920t cmc_pu2 NULL at91rm9200
1741
1742csb637_config	:	unconfig
1743	@$(MKCONFIG) $(@:_config=) arm arm920t csb637 NULL at91rm9200
1744
1745mp2usb_config	:	unconfig
1746	@$(MKCONFIG) $(@:_config=) arm arm920t mp2usb NULL at91rm9200
1747
1748
1749########################################################################
1750## ARM Integrator boards - see doc/README-integrator for more info.
1751integratorap_config	\
1752ap_config		\
1753ap966_config		\
1754ap922_config		\
1755ap922_XA10_config	\
1756ap7_config		\
1757ap720t_config  		\
1758ap920t_config		\
1759ap926ejs_config		\
1760ap946es_config: unconfig
1761	@board/integratorap/split_by_variant.sh $@
1762
1763integratorcp_config	\
1764cp_config		\
1765cp920t_config		\
1766cp926ejs_config		\
1767cp946es_config		\
1768cp1136_config		\
1769cp966_config		\
1770cp922_config		\
1771cp922_XA10_config	\
1772cp1026_config: unconfig
1773	@board/integratorcp/split_by_variant.sh $@
1774
1775kb9202_config	:	unconfig
1776	@$(MKCONFIG) $(@:_config=) arm arm920t kb9202 NULL at91rm9200
1777
1778lpd7a400_config \
1779lpd7a404_config:	unconfig
1780	@$(MKCONFIG) $(@:_config=) arm lh7a40x lpd7a40x
1781
1782mx1ads_config	:	unconfig
1783	@$(MKCONFIG) $(@:_config=) arm arm920t mx1ads NULL imx
1784
1785mx1fs2_config	:	unconfig
1786	@$(MKCONFIG) $(@:_config=) arm arm920t mx1fs2 NULL imx
1787
1788netstar_32_config	\
1789netstar_config:		unconfig
1790	@mkdir -p $(obj)include
1791	@if [ "$(findstring _32_,$@)" ] ; then \
1792		echo "... 32MB SDRAM" ; \
1793		echo "#define PHYS_SDRAM_1_SIZE SZ_32M" >>$(obj)include/config.h ; \
1794	else \
1795		echo "... 64MB SDRAM" ; \
1796		echo "#define PHYS_SDRAM_1_SIZE SZ_64M" >>$(obj)include/config.h ; \
1797	fi
1798	@$(MKCONFIG) -a netstar arm arm925t netstar
1799
1800omap1510inn_config :	unconfig
1801	@$(MKCONFIG) $(@:_config=) arm arm925t omap1510inn
1802
1803omap5912osk_config :	unconfig
1804	@$(MKCONFIG) $(@:_config=) arm arm926ejs omap5912osk NULL omap
1805
1806omap1610inn_config \
1807omap1610inn_cs0boot_config \
1808omap1610inn_cs3boot_config \
1809omap1610inn_cs_autoboot_config \
1810omap1610h2_config \
1811omap1610h2_cs0boot_config \
1812omap1610h2_cs3boot_config \
1813omap1610h2_cs_autoboot_config:	unconfig
1814	@mkdir -p $(obj)include
1815	@if [ "$(findstring _cs0boot_, $@)" ] ; then \
1816		echo "#define CONFIG_CS0_BOOT" >> .$(obj)/include/config.h ; \
1817		echo "... configured for CS0 boot"; \
1818	elif [ "$(findstring _cs_autoboot_, $@)" ] ; then \
1819		echo "#define CONFIG_CS_AUTOBOOT" >> $(obj)./include/config.h ; \
1820		echo "... configured for CS_AUTO boot"; \
1821	else \
1822		echo "#define CONFIG_CS3_BOOT" >> $(obj)./include/config.h ; \
1823		echo "... configured for CS3 boot"; \
1824	fi;
1825	@$(MKCONFIG) -a $(call xtract_omap1610xxx,$@) arm arm926ejs omap1610inn NULL omap
1826
1827omap730p2_config \
1828omap730p2_cs0boot_config \
1829omap730p2_cs3boot_config :	unconfig
1830	@mkdir -p $(obj)include
1831	@if [ "$(findstring _cs0boot_, $@)" ] ; then \
1832		echo "#define CONFIG_CS0_BOOT" >> $(obj)include/config.h ; \
1833		echo "... configured for CS0 boot"; \
1834	else \
1835		echo "#define CONFIG_CS3_BOOT" >> $(obj)include/config.h ; \
1836		echo "... configured for CS3 boot"; \
1837	fi;
1838	@$(MKCONFIG) -a $(call xtract_omap730p2,$@) arm arm926ejs omap730p2 NULL omap
1839
1840sbc2410x_config: unconfig
1841	@$(MKCONFIG) $(@:_config=) arm arm920t sbc2410x NULL s3c24x0
1842
1843scb9328_config	:	unconfig
1844	@$(MKCONFIG) $(@:_config=) arm arm920t scb9328 NULL imx
1845
1846smdk2400_config	:	unconfig
1847	@$(MKCONFIG) $(@:_config=) arm arm920t smdk2400 NULL s3c24x0
1848
1849smdk2410_config	:	unconfig
1850	@$(MKCONFIG) $(@:_config=) arm arm920t smdk2410 NULL s3c24x0
1851
1852SX1_config :		unconfig
1853	@$(MKCONFIG) $(@:_config=) arm arm925t sx1
1854
1855# TRAB default configuration:	8 MB Flash, 32 MB RAM
1856trab_config \
1857trab_bigram_config \
1858trab_bigflash_config \
1859trab_old_config:	unconfig
1860	@mkdir -p $(obj)include
1861	@mkdir -p $(obj)board/trab
1862	@ >$(obj)include/config.h
1863	@[ -z "$(findstring _bigram,$@)" ] || \
1864		{ echo "#define CONFIG_FLASH_8MB"  >>$(obj)include/config.h ; \
1865		  echo "#define CONFIG_RAM_32MB"   >>$(obj)include/config.h ; \
1866		  echo "... with 8 MB Flash, 32 MB RAM" ; \
1867		}
1868	@[ -z "$(findstring _bigflash,$@)" ] || \
1869		{ echo "#define CONFIG_FLASH_16MB" >>$(obj)include/config.h ; \
1870		  echo "#define CONFIG_RAM_16MB"   >>$(obj)include/config.h ; \
1871		  echo "... with 16 MB Flash, 16 MB RAM" ; \
1872		  echo "TEXT_BASE = 0x0CF40000" >$(obj)board/trab/config.tmp ; \
1873		}
1874	@[ -z "$(findstring _old,$@)" ] || \
1875		{ echo "#define CONFIG_FLASH_8MB"  >>$(obj)include/config.h ; \
1876		  echo "#define CONFIG_RAM_16MB"   >>$(obj)include/config.h ; \
1877		  echo "... with 8 MB Flash, 16 MB RAM" ; \
1878		  echo "TEXT_BASE = 0x0CF40000" >$(obj)board/trab/config.tmp ; \
1879		}
1880	@$(MKCONFIG) -a $(call xtract_trab,$@) arm arm920t trab NULL s3c24x0
1881
1882VCMA9_config	:	unconfig
1883	@$(MKCONFIG) $(@:_config=) arm arm920t vcma9 mpl s3c24x0
1884
1885#========================================================================
1886# ARM supplied Versatile development boards
1887#========================================================================
1888versatile_config	\
1889versatileab_config	\
1890versatilepb_config :	unconfig
1891	@board/versatile/split_by_variant.sh $@
1892
1893voiceblue_smallflash_config	\
1894voiceblue_config:	unconfig
1895	@mkdir -p $(obj)include
1896	@mkdir -p $(obj)board/voiceblue
1897	@if [ "$(findstring _smallflash_,$@)" ] ; then \
1898		echo "... boot from lower flash bank" ; \
1899		echo "#define VOICEBLUE_SMALL_FLASH" >>$(obj)include/config.h ; \
1900		echo "VOICEBLUE_SMALL_FLASH=y" >$(obj)board/voiceblue/config.tmp ; \
1901	else \
1902		echo "... boot from upper flash bank" ; \
1903		>$(obj)include/config.h ; \
1904		echo "VOICEBLUE_SMALL_FLASH=n" >$(obj)board/voiceblue/config.tmp ; \
1905	fi
1906	@$(MKCONFIG) -a voiceblue arm arm925t voiceblue
1907
1908cm4008_config	:	unconfig
1909	@$(MKCONFIG) $(@:_config=) arm arm920t cm4008 NULL ks8695
1910
1911cm41xx_config	:	unconfig
1912	@$(MKCONFIG) $(@:_config=) arm arm920t cm41xx NULL ks8695
1913
1914gth2_config		: 	unconfig
1915	@mkdir -p $(obj)include
1916	@ >$(obj)include/config.h
1917	@echo "#define CONFIG_GTH2 1" >>$(obj)include/config.h
1918	@$(MKCONFIG) -a gth2 mips mips gth2
1919
1920#########################################################################
1921## S3C44B0 Systems
1922#########################################################################
1923
1924B2_config	:	unconfig
1925	@$(MKCONFIG) $(@:_config=) arm s3c44b0 B2 dave
1926
1927#########################################################################
1928## ARM720T Systems
1929#########################################################################
1930
1931armadillo_config:	unconfig
1932	@$(MKCONFIG) $(@:_config=) arm arm720t armadillo
1933
1934ep7312_config	:	unconfig
1935	@$(MKCONFIG) $(@:_config=) arm arm720t ep7312
1936
1937impa7_config	:	unconfig
1938	@$(MKCONFIG) $(@:_config=) arm arm720t impa7
1939
1940modnet50_config :	unconfig
1941	@$(MKCONFIG) $(@:_config=) arm arm720t modnet50
1942
1943evb4510_config :	unconfig
1944	@$(MKCONFIG) $(@:_config=) arm arm720t evb4510
1945
1946#########################################################################
1947## XScale Systems
1948#########################################################################
1949
1950adsvix_config	:	unconfig
1951	@$(MKCONFIG) $(@:_config=) arm pxa adsvix
1952
1953cerf250_config :	unconfig
1954	@$(MKCONFIG) $(@:_config=) arm pxa cerf250
1955
1956cradle_config	:	unconfig
1957	@$(MKCONFIG) $(@:_config=) arm pxa cradle
1958
1959csb226_config	:	unconfig
1960	@$(MKCONFIG) $(@:_config=) arm pxa csb226
1961
1962delta_config :
1963	@$(MKCONFIG) $(@:_config=) arm pxa delta
1964
1965innokom_config	:	unconfig
1966	@$(MKCONFIG) $(@:_config=) arm pxa innokom
1967
1968ixdp425_config	:	unconfig
1969	@$(MKCONFIG) $(@:_config=) arm ixp ixdp425
1970
1971ixdpg425_config	:	unconfig
1972	@$(MKCONFIG) $(@:_config=) arm ixp ixdp425
1973
1974lubbock_config	:	unconfig
1975	@$(MKCONFIG) $(@:_config=) arm pxa lubbock
1976
1977pleb2_config	:	unconfig
1978	@$(MKCONFIG) $(@:_config=) arm pxa pleb2
1979
1980logodl_config	:	unconfig
1981	@$(MKCONFIG) $(@:_config=) arm pxa logodl
1982
1983pdnb3_config	:	unconfig
1984	@$(MKCONFIG) $(@:_config=) arm ixp pdnb3 prodrive
1985
1986pxa255_idp_config:	unconfig
1987	@$(MKCONFIG) $(@:_config=) arm pxa pxa255_idp
1988
1989wepep250_config	:	unconfig
1990	@$(MKCONFIG) $(@:_config=) arm pxa wepep250
1991
1992xaeniax_config	:	unconfig
1993	@$(MKCONFIG) $(@:_config=) arm pxa xaeniax
1994
1995xm250_config	:	unconfig
1996	@$(MKCONFIG) $(@:_config=) arm pxa xm250
1997
1998xsengine_config :	unconfig
1999	@$(MKCONFIG) $(@:_config=) arm pxa xsengine
2000
2001zylonite_config :
2002	@$(MKCONFIG) $(@:_config=) arm pxa zylonite
2003
2004#########################################################################
2005## ARM1136 Systems
2006#########################################################################
2007omap2420h4_config :    unconfig
2008	@$(MKCONFIG) $(@:_config=) arm arm1136 omap2420h4
2009
2010#========================================================================
2011# i386
2012#========================================================================
2013#########################################################################
2014## AMD SC520 CDP
2015#########################################################################
2016sc520_cdp_config	:	unconfig
2017	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_cdp
2018
2019sc520_spunk_config	:	unconfig
2020	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_spunk
2021
2022sc520_spunk_rel_config	:	unconfig
2023	@$(MKCONFIG) $(@:_config=) i386 i386 sc520_spunk
2024
2025#========================================================================
2026# MIPS
2027#========================================================================
2028#########################################################################
2029## MIPS32 4Kc
2030#########################################################################
2031
2032xtract_incaip = $(subst _100MHz,,$(subst _133MHz,,$(subst _150MHz,,$(subst _config,,$1))))
2033
2034incaip_100MHz_config	\
2035incaip_133MHz_config	\
2036incaip_150MHz_config	\
2037incaip_config: unconfig
2038	@mkdir -p $(obj)include
2039	@ >$(obj)include/config.h
2040	@[ -z "$(findstring _100MHz,$@)" ] || \
2041		{ echo "#define CPU_CLOCK_RATE 100000000" >>$(obj)include/config.h ; \
2042		  echo "... with 100MHz system clock" ; \
2043		}
2044	@[ -z "$(findstring _133MHz,$@)" ] || \
2045		{ echo "#define CPU_CLOCK_RATE 133000000" >>$(obj)include/config.h ; \
2046		  echo "... with 133MHz system clock" ; \
2047		}
2048	@[ -z "$(findstring _150MHz,$@)" ] || \
2049		{ echo "#define CPU_CLOCK_RATE 150000000" >>$(obj)include/config.h ; \
2050		  echo "... with 150MHz system clock" ; \
2051		}
2052	@$(MKCONFIG) -a $(call xtract_incaip,$@) mips mips incaip
2053
2054tb0229_config: unconfig
2055	@$(MKCONFIG) $(@:_config=) mips mips tb0229
2056
2057#########################################################################
2058## MIPS32 AU1X00
2059#########################################################################
2060dbau1000_config		: 	unconfig
2061	@mkdir -p $(obj)include
2062	@ >$(obj)include/config.h
2063	@echo "#define CONFIG_DBAU1000 1" >>$(obj)include/config.h
2064	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2065
2066dbau1100_config		: 	unconfig
2067	@mkdir -p $(obj)include
2068	@ >$(obj)include/config.h
2069	@echo "#define CONFIG_DBAU1100 1" >>$(obj)include/config.h
2070	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2071
2072dbau1500_config		: 	unconfig
2073	@mkdir -p $(obj)include
2074	@ >$(obj)include/config.h
2075	@echo "#define CONFIG_DBAU1500 1" >>$(obj)include/config.h
2076	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2077
2078dbau1550_config		:	unconfig
2079	@mkdir -p $(obj)include
2080	@ >$(obj)include/config.h
2081	@echo "#define CONFIG_DBAU1550 1" >>$(obj)include/config.h
2082	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2083
2084dbau1550_el_config	:	unconfig
2085	@mkdir -p $(obj)include
2086	@ >$(obj)include/config.h
2087	@echo "#define CONFIG_DBAU1550 1" >>$(obj)include/config.h
2088	@$(MKCONFIG) -a dbau1x00 mips mips dbau1x00
2089
2090pb1000_config		: 	unconfig
2091	@mkdir -p $(obj)include
2092	@ >$(obj)include/config.h
2093	@echo "#define CONFIG_PB1000 1" >>$(obj)include/config.h
2094	@$(MKCONFIG) -a pb1x00 mips mips pb1x00
2095
2096#########################################################################
2097## MIPS64 5Kc
2098#########################################################################
2099
2100purple_config :		unconfig
2101	@$(MKCONFIG) $(@:_config=) mips mips purple
2102
2103#========================================================================
2104# Nios
2105#========================================================================
2106#########################################################################
2107## Nios32
2108#########################################################################
2109
2110DK1C20_safe_32_config		\
2111DK1C20_standard_32_config	\
2112DK1C20_config:	unconfig
2113	@mkdir -p $(obj)include
2114	@ >$(obj)include/config.h
2115	@[ -z "$(findstring _safe_32,$@)" ] || \
2116		{ echo "#define CONFIG_NIOS_SAFE_32 1" >>$(obj)include/config.h ; \
2117		  echo "... NIOS 'safe_32' configuration" ; \
2118		}
2119	@[ -z "$(findstring _standard_32,$@)" ] || \
2120		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2121		  echo "... NIOS 'standard_32' configuration" ; \
2122		}
2123	@[ -z "$(findstring DK1C20_config,$@)" ] || \
2124		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2125		  echo "... NIOS 'standard_32' configuration (DEFAULT)" ; \
2126		}
2127	@$(MKCONFIG) -a DK1C20 nios nios dk1c20 altera
2128
2129DK1S10_safe_32_config		\
2130DK1S10_standard_32_config	\
2131DK1S10_mtx_ldk_20_config	\
2132DK1S10_config:	unconfig
2133	@mkdir -p $(obj)include
2134	@ >$(obj)include/config.h
2135	@[ -z "$(findstring _safe_32,$@)" ] || \
2136		{ echo "#define CONFIG_NIOS_SAFE_32 1" >>$(obj)include/config.h ; \
2137		  echo "... NIOS 'safe_32' configuration" ; \
2138		}
2139	@[ -z "$(findstring _standard_32,$@)" ] || \
2140		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2141		  echo "... NIOS 'standard_32' configuration" ; \
2142		}
2143	@[ -z "$(findstring _mtx_ldk_20,$@)" ] || \
2144		{ echo "#define CONFIG_NIOS_MTX_LDK_20 1" >>$(obj)include/config.h ; \
2145		  echo "... NIOS 'mtx_ldk_20' configuration" ; \
2146		}
2147	@[ -z "$(findstring DK1S10_config,$@)" ] || \
2148		{ echo "#define CONFIG_NIOS_STANDARD_32 1" >>$(obj)include/config.h ; \
2149		  echo "... NIOS 'standard_32' configuration (DEFAULT)" ; \
2150		}
2151	@$(MKCONFIG) -a DK1S10 nios nios dk1s10 altera
2152
2153ADNPESC1_DNPEVA2_base_32_config	\
2154ADNPESC1_base_32_config		\
2155ADNPESC1_config: unconfig
2156	@mkdir -p $(obj)include
2157	@ >$(obj)include/config.h
2158	@[ -z "$(findstring _DNPEVA2,$@)" ] || \
2159		{ echo "#define CONFIG_DNPEVA2 1" >>$(obj)include/config.h ; \
2160		  echo "... DNP/EVA2 configuration" ; \
2161		}
2162	@[ -z "$(findstring _base_32,$@)" ] || \
2163		{ echo "#define CONFIG_NIOS_BASE_32 1" >>$(obj)include/config.h ; \
2164		  echo "... NIOS 'base_32' configuration" ; \
2165		}
2166	@[ -z "$(findstring ADNPESC1_config,$@)" ] || \
2167		{ echo "#define CONFIG_NIOS_BASE_32 1" >>$(obj)include/config.h ; \
2168		  echo "... NIOS 'base_32' configuration (DEFAULT)" ; \
2169		}
2170	@$(MKCONFIG) -a ADNPESC1 nios nios adnpesc1 ssv
2171
2172#########################################################################
2173## Nios-II
2174#########################################################################
2175
2176EP1C20_config : unconfig
2177	@$(MKCONFIG)  EP1C20 nios2 nios2 ep1c20 altera
2178
2179EP1S10_config : unconfig
2180	@$(MKCONFIG)  EP1S10 nios2 nios2 ep1s10 altera
2181
2182EP1S40_config : unconfig
2183	@$(MKCONFIG)  EP1S40 nios2 nios2 ep1s40 altera
2184
2185PK1C20_config : unconfig
2186	@$(MKCONFIG)  PK1C20 nios2 nios2 pk1c20 psyent
2187
2188PCI5441_config : unconfig
2189	@$(MKCONFIG)  PCI5441 nios2 nios2 pci5441 psyent
2190
2191#========================================================================
2192# MicroBlaze
2193#========================================================================
2194#########################################################################
2195## Microblaze
2196#########################################################################
2197suzaku_config:	unconfig
2198	@mkdir -p $(obj)include
2199	@ >$(obj)include/config.h
2200	@echo "#define CONFIG_SUZAKU 1" >> $(obj)include/config.h
2201	@$(MKCONFIG) -a $(@:_config=) microblaze microblaze suzaku AtmarkTechno
2202
2203#########################################################################
2204## Blackfin
2205#########################################################################
2206ezkit533_config	:	unconfig
2207	@$(MKCONFIG) $(@:_config=) blackfin bf533 ezkit533
2208
2209stamp_config	:	unconfig
2210	@$(MKCONFIG) $(@:_config=) blackfin bf533 stamp
2211
2212dspstamp_config	:	unconfig
2213	@$(MKCONFIG) $(@:_config=) blackfin bf533 dsp_stamp
2214
2215#########################################################################
2216#########################################################################
2217#########################################################################
2218
2219clean:
2220	find $(OBJTREE) -type f \
2221		\( -name 'core' -o -name '*.bak' -o -name '*~' \
2222		-o -name '*.o'  -o -name '*.a'  \) -print \
2223		| xargs rm -f
2224	rm -f $(obj)examples/hello_world $(obj)examples/timer \
2225	      $(obj)examples/eepro100_eeprom $(obj)examples/sched \
2226	      $(obj)examples/mem_to_mem_idma2intr $(obj)examples/82559_eeprom \
2227	      $(obj)examples/smc91111_eeprom $(obj)examples/interrupt \
2228	      $(obj)examples/test_burst
2229	rm -f $(obj)tools/img2srec $(obj)tools/mkimage $(obj)tools/envcrc \
2230		$(obj)tools/gen_eth_addr
2231	rm -f $(obj)tools/mpc86x_clk $(obj)tools/ncb
2232	rm -f $(obj)tools/easylogo/easylogo $(obj)tools/bmp_logo
2233	rm -f $(obj)tools/gdb/astest $(obj)tools/gdb/gdbcont $(obj)tools/gdb/gdbsend
2234	rm -f $(obj)tools/env/fw_printenv $(obj)tools/env/fw_setenv
2235	rm -f $(obj)board/cray/L1/bootscript.c $(obj)board/cray/L1/bootscript.image
2236	rm -f $(obj)board/netstar/eeprom $(obj)board/netstar/crcek $(obj)board/netstar/crcit
2237	rm -f $(obj)board/netstar/*.srec $(obj)board/netstar/*.bin
2238	rm -f $(obj)board/trab/trab_fkt $(obj)board/voiceblue/eeprom
2239	rm -f $(obj)board/integratorap/u-boot.lds $(obj)board/integratorcp/u-boot.lds
2240	rm -f $(obj)include/bmp_logo.h
2241	find nand_spl -lname "*" -print | xargs rm -f
2242	rm -f nand_spl/u-boot-spl nand_spl/u-boot-spl.map
2243
2244clobber:	clean
2245	find $(OBJTREE) -type f \( -name .depend \
2246		-o -name '*.srec' -o -name '*.bin' -o -name u-boot.img \) \
2247		-print0 \
2248		| xargs -0 rm -f
2249	rm -f $(OBJS) $(obj)*.bak $(obj)ctags $(obj)etags $(obj)TAGS $(obj)include/version_autogenerated.h
2250	rm -fr $(obj)*.*~
2251	rm -f $(obj)u-boot $(obj)u-boot.map $(obj)u-boot.hex $(ALL)
2252	rm -f $(obj)tools/crc32.c $(obj)tools/environment.c $(obj)tools/env/crc32.c
2253	rm -f $(obj)tools/inca-swap-bytes $(obj)cpu/mpc824x/bedbug_603e.c
2254	rm -f $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm
2255
2256ifeq ($(OBJTREE),$(SRCTREE))
2257mrproper \
2258distclean:	clobber unconfig
2259else
2260mrproper \
2261distclean:	clobber unconfig
2262	rm -rf $(OBJTREE)/*
2263endif
2264
2265backup:
2266	F=`basename $(TOPDIR)` ; cd .. ; \
2267	gtar --force-local -zcvf `date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
2268
2269#########################################################################
2270