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