xref: /openbmc/u-boot/Makefile (revision d4ca31c4)
17ebf7443Swdenk#
2*d4ca31c4Swdenk# (C) Copyright 2000-2004
37ebf7443Swdenk# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
47ebf7443Swdenk#
57ebf7443Swdenk# See file CREDITS for list of people who contributed to this
67ebf7443Swdenk# project.
77ebf7443Swdenk#
87ebf7443Swdenk# This program is free software; you can redistribute it and/or
97ebf7443Swdenk# modify it under the terms of the GNU General Public License as
107ebf7443Swdenk# published by the Free Software Foundation; either version 2 of
117ebf7443Swdenk# the License, or (at your option) any later version.
127ebf7443Swdenk#
137ebf7443Swdenk# This program is distributed in the hope that it will be useful,
147ebf7443Swdenk# but WITHOUT ANY WARRANTY; without even the implied warranty of
157ebf7443Swdenk# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
167ebf7443Swdenk# GNU General Public License for more details.
177ebf7443Swdenk#
187ebf7443Swdenk# You should have received a copy of the GNU General Public License
197ebf7443Swdenk# along with this program; if not, write to the Free Software
207ebf7443Swdenk# Foundation, Inc., 59 Temple Place, Suite 330, Boston,
217ebf7443Swdenk# MA 02111-1307 USA
227ebf7443Swdenk#
237ebf7443Swdenk
247ebf7443SwdenkHOSTARCH := $(shell uname -m | \
257ebf7443Swdenk	sed -e s/i.86/i386/ \
267ebf7443Swdenk	    -e s/sun4u/sparc64/ \
277ebf7443Swdenk	    -e s/arm.*/arm/ \
287ebf7443Swdenk	    -e s/sa110/arm/ \
297ebf7443Swdenk	    -e s/powerpc/ppc/ \
307ebf7443Swdenk	    -e s/macppc/ppc/)
317ebf7443Swdenk
327ebf7443SwdenkHOSTOS := $(shell uname -s | tr A-Z a-z | \
337ebf7443Swdenk	    sed -e 's/\(cygwin\).*/cygwin/')
347ebf7443Swdenk
357ebf7443Swdenkexport	HOSTARCH
367ebf7443Swdenk
377ebf7443Swdenk# Deal with colliding definitions from tcsh etc.
387ebf7443SwdenkVENDOR=
397ebf7443Swdenk
407ebf7443Swdenk#########################################################################
417ebf7443Swdenk
427ebf7443SwdenkTOPDIR	:= $(shell if [ "$$PWD" != "" ]; then echo $$PWD; else pwd; fi)
437ebf7443Swdenkexport	TOPDIR
447ebf7443Swdenk
457ebf7443Swdenkifeq (include/config.mk,$(wildcard include/config.mk))
467ebf7443Swdenk# load ARCH, BOARD, and CPU configuration
477ebf7443Swdenkinclude include/config.mk
487ebf7443Swdenkexport	ARCH CPU BOARD VENDOR
497ebf7443Swdenk# load other configuration
507ebf7443Swdenkinclude $(TOPDIR)/config.mk
517ebf7443Swdenk
527ebf7443Swdenkifndef CROSS_COMPILE
537ebf7443Swdenkifeq ($(HOSTARCH),ppc)
547ebf7443SwdenkCROSS_COMPILE =
557ebf7443Swdenkelse
567ebf7443Swdenkifeq ($(ARCH),ppc)
577ebf7443SwdenkCROSS_COMPILE = ppc_8xx-
587ebf7443Swdenkendif
597ebf7443Swdenkifeq ($(ARCH),arm)
60dc7c9a1aSwdenkCROSS_COMPILE = arm-linux-
617ebf7443Swdenkendif
622262cfeeSwdenkifeq ($(ARCH),i386)
637a8e9bedSwdenkifeq ($(HOSTARCH),i386)
647a8e9bedSwdenkCROSS_COMPILE =
657a8e9bedSwdenkelse
667a8e9bedSwdenkCROSS_COMPILE = i386-linux-
677a8e9bedSwdenkendif
682262cfeeSwdenkendif
6943d9616cSwdenkifeq ($(ARCH),mips)
7043d9616cSwdenkCROSS_COMPILE = mips_4KC-
7143d9616cSwdenkendif
724a551709Swdenkifeq ($(ARCH),nios)
734a551709SwdenkCROSS_COMPILE = nios-elf-
744a551709Swdenkendif
754e5ca3ebSwdenkifeq ($(ARCH),m68k)
764e5ca3ebSwdenkCROSS_COMPILE = m68k-elf-
774e5ca3ebSwdenkendif
787ebf7443Swdenkendif
797ebf7443Swdenkendif
807ebf7443Swdenk
817ebf7443Swdenkexport	CROSS_COMPILE
827ebf7443Swdenk
837ebf7443Swdenk#########################################################################
847ebf7443Swdenk# U-Boot objects....order is important (i.e. start must be first)
857ebf7443Swdenk
867ebf7443SwdenkOBJS  = cpu/$(CPU)/start.o
872262cfeeSwdenkifeq ($(CPU),i386)
882262cfeeSwdenkOBJS += cpu/$(CPU)/start16.o
892262cfeeSwdenkOBJS += cpu/$(CPU)/reset.o
902262cfeeSwdenkendif
917ebf7443Swdenkifeq ($(CPU),ppc4xx)
927ebf7443SwdenkOBJS += cpu/$(CPU)/resetvec.o
937ebf7443Swdenkendif
9442d1f039Swdenkifeq ($(CPU),mpc85xx)
9542d1f039SwdenkOBJS += cpu/$(CPU)/resetvec.o
9642d1f039Swdenkendif
977ebf7443Swdenk
989fd5e31fSwdenkLIBS  = lib_generic/libgeneric.a
999fd5e31fSwdenkLIBS += board/$(BOARDDIR)/lib$(BOARD).a
1007ebf7443SwdenkLIBS += cpu/$(CPU)/lib$(CPU).a
1017ebf7443SwdenkLIBS += lib_$(ARCH)/lib$(ARCH).a
10271f95118SwdenkLIBS += fs/jffs2/libjffs2.a fs/fdos/libfdos.a fs/fat/libfat.a
1037ebf7443SwdenkLIBS += net/libnet.a
1047ebf7443SwdenkLIBS += disk/libdisk.a
1057ebf7443SwdenkLIBS += rtc/librtc.a
1067ebf7443SwdenkLIBS += dtt/libdtt.a
1077ebf7443SwdenkLIBS += drivers/libdrivers.a
1087152b1d0SwdenkLIBS += drivers/sk98lin/libsk98lin.a
1097ebf7443SwdenkLIBS += post/libpost.a post/cpu/libcpu.a
1107ebf7443SwdenkLIBS += common/libcommon.a
1119fd5e31fSwdenk.PHONY : $(LIBS)
112a8c7c708Swdenk
1134f7cb08eSwdenk# Add GCC lib
114fc3e2165SwdenkPLATFORM_LIBS += -L $(shell dirname `$(CC) $(CFLAGS) -print-libgcc-file-name`) -lgcc
1157ebf7443Swdenk
116a8c7c708Swdenk# The "tools" are needed early, so put this first
117a8c7c708Swdenk# Don't include stuff already done in $(LIBS)
118a8c7c708SwdenkSUBDIRS	= tools \
119a8c7c708Swdenk	  examples \
120a8c7c708Swdenk	  post \
121a8c7c708Swdenk	  post/cpu
122b028f715Swdenk.PHONY : $(SUBDIRS)
123a8c7c708Swdenk
1247ebf7443Swdenk#########################################################################
125bdccc4feSwdenk#########################################################################
1267ebf7443Swdenk
127bdccc4feSwdenkALL = u-boot.srec u-boot.bin System.map
1287ebf7443Swdenk
129bdccc4feSwdenkall:		$(ALL)
1307ebf7443Swdenk
1317ebf7443Swdenku-boot.srec:	u-boot
1327ebf7443Swdenk		$(OBJCOPY) ${OBJCFLAGS} -O srec $< $@
1337ebf7443Swdenk
1347ebf7443Swdenku-boot.bin:	u-boot
1357ebf7443Swdenk		$(OBJCOPY) ${OBJCFLAGS} -O binary $< $@
1367ebf7443Swdenk
137bdccc4feSwdenku-boot.img:	u-boot.bin
138bdccc4feSwdenk		./tools/mkimage -A $(ARCH) -T firmware -C none \
139bdccc4feSwdenk		-a $(TEXT_BASE) -e 0 \
140bdccc4feSwdenk		-n $(shell sed -n -e 's/.*U_BOOT_VERSION//p' include/version.h | \
141bdccc4feSwdenk			sed -e 's/"[	 ]*$$/ for $(BOARD) board"/') \
142bdccc4feSwdenk		-d $< $@
143bdccc4feSwdenk
1447ebf7443Swdenku-boot.dis:	u-boot
1457ebf7443Swdenk		$(OBJDUMP) -d $< > $@
1467ebf7443Swdenk
147a8c7c708Swdenku-boot:		depend $(SUBDIRS) $(OBJS) $(LIBS) $(LDSCRIPT)
1488bde7f77Swdenk		UNDEF_SYM=`$(OBJDUMP) -x $(LIBS) |sed  -n -e 's/.*\(__u_boot_cmd_.*\)/-u\1/p'|sort|uniq`;\
1498bde7f77Swdenk		$(LD) $(LDFLAGS) $$UNDEF_SYM $(OBJS) \
1507152b1d0Swdenk			--start-group $(LIBS) $(PLATFORM_LIBS) --end-group \
151b2184c31Swdenk			-Map u-boot.map -o u-boot
1527ebf7443Swdenk
153a8c7c708Swdenk$(LIBS):
154a8c7c708Swdenk		$(MAKE) -C `dirname $@`
155a8c7c708Swdenk
156a8c7c708Swdenk$(SUBDIRS):
157b028f715Swdenk		$(MAKE) -C $@ all
1587ebf7443Swdenk
1598f713fdfSdzugdbtools:
1608f713fdfSdzu		$(MAKE) -C tools/gdb || exit 1
1618f713fdfSdzu
1627ebf7443Swdenkdepend dep:
1637ebf7443Swdenk		@for dir in $(SUBDIRS) ; do $(MAKE) -C $$dir .depend ; done
1647ebf7443Swdenk
1657ebf7443Swdenktags:
1667ebf7443Swdenk		ctags -w `find $(SUBDIRS) include \
1677ebf7443Swdenk			\( -name CVS -prune \) -o \( -name '*.[ch]' -print \)`
1687ebf7443Swdenk
1697ebf7443Swdenketags:
1707ebf7443Swdenk		etags -a `find $(SUBDIRS) include \
1717ebf7443Swdenk			\( -name CVS -prune \) -o \( -name '*.[ch]' -print \)`
1727ebf7443Swdenk
1737ebf7443SwdenkSystem.map:	u-boot
1747ebf7443Swdenk		@$(NM) $< | \
1757ebf7443Swdenk		grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \
1767ebf7443Swdenk		sort > System.map
1777ebf7443Swdenk
1787ebf7443Swdenk#########################################################################
1797ebf7443Swdenkelse
1807ebf7443Swdenkall install u-boot u-boot.srec depend dep:
1817ebf7443Swdenk	@echo "System not configured - see README" >&2
1827ebf7443Swdenk	@ exit 1
1837ebf7443Swdenkendif
1847ebf7443Swdenk
1857ebf7443Swdenk#########################################################################
1867ebf7443Swdenk
1877ebf7443Swdenkunconfig:
1887ebf7443Swdenk	rm -f include/config.h include/config.mk
1897ebf7443Swdenk
1907ebf7443Swdenk#========================================================================
1917ebf7443Swdenk# PowerPC
1927ebf7443Swdenk#========================================================================
1930db5bca8Swdenk
1940db5bca8Swdenk#########################################################################
1950db5bca8Swdenk## MPC5xx Systems
1960db5bca8Swdenk#########################################################################
1970db5bca8Swdenk
1980db5bca8Swdenkcmi_mpc5xx_config:	unconfig
1990db5bca8Swdenk	@./mkconfig $(@:_config=) ppc mpc5xx cmi
2000db5bca8Swdenk
2017ebf7443Swdenk#########################################################################
202945af8d7Swdenk## MPC5xxx Systems
203945af8d7Swdenk#########################################################################
2045cf9da48SwdenkMPC5200LITE_config		\
2055cf9da48SwdenkMPC5200LITE_LOWBOOT_config	\
2065cf9da48SwdenkMPC5200LITE_LOWBOOT08_config	\
207*d4ca31c4Swdenkicecube_5200_DDR_LOWBOOT_config	\
208b2001f27Swdenkicecube_5200_DDR_config		\
209b2001f27SwdenkIceCube_5200_DDR_config		\
210a0f2fe52Swdenkicecube_5200_config		\
211945af8d7SwdenkIceCube_5200_config		\
212945af8d7SwdenkIceCube_5100_config:		unconfig
213945af8d7Swdenk	@ >include/config.h
2145cf9da48Swdenk	@[ -z "$(findstring LOWBOOT,$@)" ] || \
2155cf9da48Swdenk		{ echo "TEXT_BASE = 0xFF000000" >board/icecube/config.tmp ; \
2165cf9da48Swdenk		  echo "... with LOWBOOT configuration" ; \
2175cf9da48Swdenk		}
2185cf9da48Swdenk	@[ -z "$(findstring LOWBOOT08,$@)" ] || \
2195cf9da48Swdenk		{ echo "TEXT_BASE = 0xFF800000" >board/icecube/config.tmp ; \
2205cf9da48Swdenk		  echo "... with 8 MB flash only" ; \
2215cf9da48Swdenk		}
222b2001f27Swdenk	@[ -z "$(findstring DDR,$@)" ] || \
223b2001f27Swdenk		{ echo "#define CONFIG_MPC5200_DDR"	>>include/config.h ; \
224b2001f27Swdenk		  echo "... DDR memory revision" ; \
225b2001f27Swdenk		}
226*d4ca31c4Swdenk	@[ -z "$(findstring 5200,$@)" ] || \
227*d4ca31c4Swdenk		{ echo "#define CONFIG_MPC5200"		>>include/config.h ; \
228*d4ca31c4Swdenk		  echo "... with MPC5200 processor" ; \
229*d4ca31c4Swdenk		}
230a0f2fe52Swdenk	@[ -z "$(findstring 5100,$@)" ] || \
231945af8d7Swdenk		{ echo "#define CONFIG_MGT5100"		>>include/config.h ; \
232945af8d7Swdenk		  echo "... with MGT5100 processor" ; \
233945af8d7Swdenk		}
234945af8d7Swdenk	@./mkconfig -a IceCube ppc mpc5xxx icecube
235945af8d7Swdenk
236*d4ca31c4SwdenkMINI5200_config	\
237*d4ca31c4SwdenkEVAL5200_config	\
238*d4ca31c4SwdenkTOP5200_config:	unconfig
239*d4ca31c4Swdenk	@ echo "#define CONFIG_$(@:_config=) 1"	>include/config.h
240*d4ca31c4Swdenk	@./mkconfig -a TOP5200 ppc mpc5xxx top5200 emk
241*d4ca31c4Swdenk
242945af8d7Swdenk#########################################################################
2437ebf7443Swdenk## MPC8xx Systems
2447ebf7443Swdenk#########################################################################
2457ebf7443Swdenk
2460cb61d7dSwdenkAdderII_config:	unconfig
2470cb61d7dSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx adderII
2480cb61d7dSwdenk
2497ebf7443SwdenkADS860_config:	unconfig
2507ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx fads
2517ebf7443Swdenk
2527ebf7443SwdenkAMX860_config	:	unconfig
2537ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx amx860 westel
2547ebf7443Swdenk
255fd3103bbSwdenkbms2003_config	:	unconfig
256fd3103bbSwdenk	@echo "#define CONFIG_BMS2003" >include/config.h
257fd3103bbSwdenk	@echo "#define CONFIG_LCD" >>include/config.h
258fd3103bbSwdenk	@echo "#define CONFIG_NEC_NL6448BC33_54" >>include/config.h
259fd3103bbSwdenk	@./mkconfig -a TQM823L ppc mpc8xx tqm8xx
260fd3103bbSwdenk
2617ebf7443Swdenkc2mon_config:		unconfig
2627ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx c2mon
2637ebf7443Swdenk
2647ebf7443SwdenkCCM_config:		unconfig
2657ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx CCM siemens
2667ebf7443Swdenk
2677ebf7443Swdenkcogent_mpc8xx_config:	unconfig
2687ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx cogent
2697ebf7443Swdenk
2703bac3513SwdenkELPT860_config:		unconfig
2713bac3513Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx elpt860 LEOX
2723bac3513Swdenk
2737ebf7443SwdenkESTEEM192E_config:	unconfig
2747ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx esteem192e
2757ebf7443Swdenk
2767ebf7443SwdenkETX094_config	:	unconfig
2777ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx etx094
2787ebf7443Swdenk
2797ebf7443SwdenkFADS823_config	\
2807ebf7443SwdenkFADS850SAR_config \
2812535d602SwdenkMPC86xADS_config \
2827ebf7443SwdenkFADS860T_config:	unconfig
2837ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx fads
2847ebf7443Swdenk
2857ebf7443SwdenkFLAGADM_config:	unconfig
2867ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx flagadm
2877ebf7443Swdenk
2887aa78614Swdenkxtract_GEN860T = $(subst _SC,,$(subst _config,,$1))
2897aa78614Swdenk
2907aa78614SwdenkGEN860T_SC_config	\
2917ebf7443SwdenkGEN860T_config: unconfig
2927aa78614Swdenk	@ >include/config.h
2937aa78614Swdenk	@[ -z "$(findstring _SC,$@)" ] || \
2947aa78614Swdenk		{ echo "#define CONFIG_SC" >>include/config.h ; \
2957aa78614Swdenk		  echo "With reduced H/W feature set (SC)..." ; \
2967aa78614Swdenk		}
2977aa78614Swdenk	@./mkconfig -a $(call xtract_GEN860T,$@) ppc mpc8xx gen860t
2987ebf7443Swdenk
2997ebf7443SwdenkGENIETV_config:	unconfig
3007ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx genietv
3017ebf7443Swdenk
3027ebf7443SwdenkGTH_config:	unconfig
3037ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx gth
3047ebf7443Swdenk
3057ebf7443Swdenkhermes_config	:	unconfig
3067ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx hermes
3077ebf7443Swdenk
3087ebf7443SwdenkIAD210_config: unconfig
3097ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx IAD210 siemens
3107ebf7443Swdenk
3117ebf7443Swdenkxtract_ICU862 = $(subst _100MHz,,$(subst _config,,$1))
3127ebf7443Swdenk
3137ebf7443SwdenkICU862_100MHz_config	\
3147ebf7443SwdenkICU862_config: unconfig
3157ebf7443Swdenk	@ >include/config.h
3167ebf7443Swdenk	@[ -z "$(findstring _100MHz,$@)" ] || \
3177ebf7443Swdenk		{ echo "#define CONFIG_100MHz"	>>include/config.h ; \
3187ebf7443Swdenk		  echo "... with 100MHz system clock" ; \
3197ebf7443Swdenk		}
3207ebf7443Swdenk	@./mkconfig -a $(call xtract_ICU862,$@) ppc mpc8xx icu862
3217ebf7443Swdenk
3227ebf7443SwdenkIP860_config	:	unconfig
3237ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx ip860
3247ebf7443Swdenk
3257ebf7443SwdenkIVML24_256_config \
3267ebf7443SwdenkIVML24_128_config \
3277ebf7443SwdenkIVML24_config:	unconfig
3287ebf7443Swdenk	@ >include/config.h
3297ebf7443Swdenk	@[ -z "$(findstring IVML24_config,$@)" ] || \
3307ebf7443Swdenk		 { echo "#define CONFIG_IVML24_16M"	>>include/config.h ; \
3317ebf7443Swdenk		 }
3327ebf7443Swdenk	@[ -z "$(findstring IVML24_128_config,$@)" ] || \
3337ebf7443Swdenk		 { echo "#define CONFIG_IVML24_32M"	>>include/config.h ; \
3347ebf7443Swdenk		 }
3357ebf7443Swdenk	@[ -z "$(findstring IVML24_256_config,$@)" ] || \
3367ebf7443Swdenk		 { echo "#define CONFIG_IVML24_64M"	>>include/config.h ; \
3377ebf7443Swdenk		 }
3387ebf7443Swdenk	@./mkconfig -a IVML24 ppc mpc8xx ivm
3397ebf7443Swdenk
3407ebf7443SwdenkIVMS8_256_config \
3417ebf7443SwdenkIVMS8_128_config \
3427ebf7443SwdenkIVMS8_config:	unconfig
3437ebf7443Swdenk	@ >include/config.h
3447ebf7443Swdenk	@[ -z "$(findstring IVMS8_config,$@)" ] || \
3457ebf7443Swdenk		 { echo "#define CONFIG_IVMS8_16M"	>>include/config.h ; \
3467ebf7443Swdenk		 }
3477ebf7443Swdenk	@[ -z "$(findstring IVMS8_128_config,$@)" ] || \
3487ebf7443Swdenk		 { echo "#define CONFIG_IVMS8_32M"	>>include/config.h ; \
3497ebf7443Swdenk		 }
3507ebf7443Swdenk	@[ -z "$(findstring IVMS8_256_config,$@)" ] || \
3517ebf7443Swdenk		 { echo "#define CONFIG_IVMS8_64M"	>>include/config.h ; \
3527ebf7443Swdenk		 }
3537ebf7443Swdenk	@./mkconfig -a IVMS8 ppc mpc8xx ivm
3547ebf7443Swdenk
35556f94be3SwdenkKUP4K_config	:	unconfig
35656f94be3Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx kup4k
35756f94be3Swdenk
3587ebf7443SwdenkLANTEC_config	:	unconfig
3597ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx lantec
3607ebf7443Swdenk
3617ebf7443Swdenklwmon_config:		unconfig
3627ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx lwmon
3637ebf7443Swdenk
3647ebf7443SwdenkMBX_config	\
3657ebf7443SwdenkMBX860T_config:	unconfig
3667ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx mbx8xx
3677ebf7443Swdenk
3687ebf7443SwdenkMHPC_config:		unconfig
3697ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx mhpc eltec
3707ebf7443Swdenk
3717ebf7443SwdenkMVS1_config :		unconfig
3727ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx mvs1
3737ebf7443Swdenk
374993cad93Swdenkxtract_NETVIA = $(subst _V2,,$(subst _config,,$1))
375993cad93Swdenk
376993cad93SwdenkNETVIA_V2_config \
3777ebf7443SwdenkNETVIA_config:		unconfig
378993cad93Swdenk	@ >include/config.h
379993cad93Swdenk	@[ -z "$(findstring NETVIA_config,$@)" ] || \
380993cad93Swdenk		 { echo "#define CONFIG_NETVIA_VERSION 1" >>include/config.h ; \
381993cad93Swdenk		  echo "... Version 1" ; \
382993cad93Swdenk		 }
383993cad93Swdenk	@[ -z "$(findstring NETVIA_V2_config,$@)" ] || \
384993cad93Swdenk		 { echo "#define CONFIG_NETVIA_VERSION 2" >>include/config.h ; \
385993cad93Swdenk		  echo "... Version 2" ; \
386993cad93Swdenk		 }
387993cad93Swdenk	@./mkconfig -a $(call xtract_NETVIA,$@) ppc mpc8xx netvia
3887ebf7443Swdenk
3897ebf7443SwdenkNX823_config:		unconfig
3907ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx nx823
3917ebf7443Swdenk
3927ebf7443Swdenkpcu_e_config:		unconfig
3937ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx pcu_e siemens
3947ebf7443Swdenk
3953bbc899fSwdenkQS850_config:	unconfig
3963bbc899fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx qs850 snmc
3973bbc899fSwdenk
3983bbc899fSwdenkQS823_config:	unconfig
3993bbc899fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx qs850 snmc
4003bbc899fSwdenk
4013bbc899fSwdenkQS860T_config:	unconfig
4023bbc899fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx qs860t snmc
4033bbc899fSwdenk
4047ebf7443SwdenkR360MPI_config:	unconfig
4057ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx r360mpi
4067ebf7443Swdenk
407682011ffSwdenkRBC823_config:	unconfig
408682011ffSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx rbc823
409682011ffSwdenk
4107ebf7443SwdenkRPXClassic_config:	unconfig
4117ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx RPXClassic
4127ebf7443Swdenk
4137ebf7443SwdenkRPXlite_config:		unconfig
4147ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx RPXlite
4157ebf7443Swdenk
41673a8b27cSwdenkrmu_config:	unconfig
41773a8b27cSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx rmu
41873a8b27cSwdenk
4197ebf7443SwdenkRRvision_config:	unconfig
4207ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx RRvision
4217ebf7443Swdenk
4227ebf7443SwdenkRRvision_LCD_config:	unconfig
4237ebf7443Swdenk	@echo "#define CONFIG_LCD" >include/config.h
4247ebf7443Swdenk	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>include/config.h
4257ebf7443Swdenk	@./mkconfig -a RRvision ppc mpc8xx RRvision
4267ebf7443Swdenk
4277ebf7443SwdenkSM850_config	:	unconfig
4287ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx tqm8xx
4297ebf7443Swdenk
4307ebf7443SwdenkSPD823TS_config:	unconfig
4317ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx spd8xx
4327ebf7443Swdenk
433dc7c9a1aSwdenksvm_sc8xx_config:	unconfig
434dc7c9a1aSwdenk	@ >include/config.h
435dc7c9a1aSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx svm_sc8xx
436dc7c9a1aSwdenk
4377ebf7443SwdenkSXNI855T_config:	unconfig
4387ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx sixnet
4397ebf7443Swdenk
440db2f721fSwdenk# EMK MPC8xx based modules
441db2f721fSwdenkTOP860_config:		unconfig
442db2f721fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx top860 emk
443db2f721fSwdenk
4447ebf7443Swdenk# Play some tricks for configuration selection
44573a8b27cSwdenk# All boards can come with 50 MHz (default), 66MHz, 80MHz or 100 MHz clock,
4467ebf7443Swdenk# but only 855 and 860 boards may come with FEC
4477ebf7443Swdenk# and 823 boards may have LCD support
448*d4ca31c4Swdenkxtract_8xx = $(subst _66MHz,,$(subst _80MHz,,$(subst _100MHz,,$(subst _133MHz,,$(subst _LCD,,$(subst _config,,$1))))))
4497ebf7443Swdenk
4507ebf7443SwdenkFPS850L_config		\
451384ae025SwdenkFPS860L_config		\
452f12e568cSwdenkNSCU_config		\
4537ebf7443SwdenkTQM823L_config		\
4547ebf7443SwdenkTQM823L_66MHz_config	\
4557ebf7443SwdenkTQM823L_80MHz_config	\
4567ebf7443SwdenkTQM823L_LCD_config	\
4577ebf7443SwdenkTQM823L_LCD_66MHz_config \
4587ebf7443SwdenkTQM823L_LCD_80MHz_config \
4597ebf7443SwdenkTQM850L_config		\
4607ebf7443SwdenkTQM850L_66MHz_config	\
4617ebf7443SwdenkTQM850L_80MHz_config	\
4627ebf7443SwdenkTQM855L_config		\
4637ebf7443SwdenkTQM855L_66MHz_config	\
4647ebf7443SwdenkTQM855L_80MHz_config	\
4657ebf7443SwdenkTQM860L_config		\
4667ebf7443SwdenkTQM860L_66MHz_config	\
4677ebf7443SwdenkTQM860L_80MHz_config	\
468d126bfbdSwdenkTQM862L_config		\
469d126bfbdSwdenkTQM862L_66MHz_config	\
47073a8b27cSwdenkTQM862L_80MHz_config	\
471ae3af05eSwdenkTQM823M_config		\
472ae3af05eSwdenkTQM823M_66MHz_config	\
473ae3af05eSwdenkTQM823M_80MHz_config	\
474ae3af05eSwdenkTQM850M_config		\
475ae3af05eSwdenkTQM850M_66MHz_config	\
476ae3af05eSwdenkTQM850M_80MHz_config	\
477f12e568cSwdenkTQM855M_config		\
478f12e568cSwdenkTQM855M_66MHz_config	\
479f12e568cSwdenkTQM855M_80MHz_config	\
480f12e568cSwdenkTQM860M_config		\
481f12e568cSwdenkTQM860M_66MHz_config	\
482f12e568cSwdenkTQM860M_80MHz_config	\
483f12e568cSwdenkTQM862M_config		\
484f12e568cSwdenkTQM862M_66MHz_config	\
485f12e568cSwdenkTQM862M_80MHz_config	\
486*d4ca31c4SwdenkTQM862M_100MHz_config	\
487*d4ca31c4SwdenkTQM866M_config		\
488*d4ca31c4SwdenkTQM866M_66MHz_config	\
489*d4ca31c4SwdenkTQM866M_80MHz_config	\
490*d4ca31c4SwdenkTQM866M_100MHz_config	\
491*d4ca31c4SwdenkTQM866M_133MHz_config:	unconfig
4927ebf7443Swdenk	@ >include/config.h
4937ebf7443Swdenk	@[ -z "$(findstring _66MHz,$@)" ] || \
4947ebf7443Swdenk		{ echo "#define CONFIG_66MHz"		>>include/config.h ; \
4957ebf7443Swdenk		  echo "... with 66MHz system clock" ; \
4967ebf7443Swdenk		}
4977ebf7443Swdenk	@[ -z "$(findstring _80MHz,$@)" ] || \
4987ebf7443Swdenk		{ echo "#define CONFIG_80MHz"		>>include/config.h ; \
4997ebf7443Swdenk		  echo "... with 80MHz system clock" ; \
5007ebf7443Swdenk		}
50173a8b27cSwdenk	@[ -z "$(findstring _100MHz,$@)" ] || \
50273a8b27cSwdenk		{ echo "#define CONFIG_100MHz"		>>include/config.h ; \
50373a8b27cSwdenk		  echo "... with 100MHz system clock" ; \
50473a8b27cSwdenk		}
505*d4ca31c4Swdenk	@[ -z "$(findstring _133MHz,$@)" ] || \
506*d4ca31c4Swdenk		{ echo "#define CONFIG_133MHz"		>>include/config.h ; \
507*d4ca31c4Swdenk		  echo "... with 133MHz system clock" ; \
508*d4ca31c4Swdenk		}
5097ebf7443Swdenk	@[ -z "$(findstring _LCD,$@)" ] || \
5107ebf7443Swdenk		{ echo "#define CONFIG_LCD"		>>include/config.h ; \
511fd3103bbSwdenk		  echo "#define CONFIG_NEC_NL6448BC20"	>>include/config.h ; \
5127ebf7443Swdenk		  echo "... with LCD display" ; \
5137ebf7443Swdenk		}
5147ebf7443Swdenk	@./mkconfig -a $(call xtract_8xx,$@) ppc mpc8xx tqm8xx
5157ebf7443Swdenk
5167ebf7443SwdenkTTTech_config:	unconfig
5177ebf7443Swdenk	@echo "#define CONFIG_LCD" >include/config.h
5187ebf7443Swdenk	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>include/config.h
5197ebf7443Swdenk	@./mkconfig -a TQM823L ppc mpc8xx tqm8xx
5207ebf7443Swdenk
521608c9146Swdenkv37_config:	unconfig
522608c9146Swdenk	@echo "#define CONFIG_LCD" >include/config.h
523608c9146Swdenk	@echo "#define CONFIG_SHARP_LQ084V1DG21" >>include/config.h
524608c9146Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx v37
525608c9146Swdenk
52691e940d9Sdzuwtk_config:	unconfig
52791e940d9Sdzu	@echo "#define CONFIG_LCD" >include/config.h
52891e940d9Sdzu	@echo "#define CONFIG_SHARP_LQ065T9DR51U" >>include/config.h
52991e940d9Sdzu	@./mkconfig -a TQM823L ppc mpc8xx tqm8xx
53091e940d9Sdzu
5317ebf7443Swdenk#########################################################################
5327ebf7443Swdenk## PPC4xx Systems
5337ebf7443Swdenk#########################################################################
534fbe4b5cbSwdenkxtract_4xx = $(subst _MODEL_BA,,$(subst _MODEL_ME,,$(subst _MODEL_HI,,$(subst _config,,$1))))
5357ebf7443Swdenk
5367ebf7443SwdenkADCIOP_config:	unconfig
5377ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx adciop esd
5387ebf7443Swdenk
5397ebf7443SwdenkAR405_config:	unconfig
5407ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ar405 esd
5417ebf7443Swdenk
542549826eaSstroeseASH405_config:	unconfig
543549826eaSstroese	@./mkconfig $(@:_config=) ppc ppc4xx ash405 esd
544549826eaSstroese
545549826eaSstroeseBUBINGA405EP_config:unconfig
546549826eaSstroese	@./mkconfig $(@:_config=) ppc ppc4xx bubinga405ep
547549826eaSstroese
5487ebf7443SwdenkCANBT_config:	unconfig
5497ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx canbt esd
5507ebf7443Swdenk
5517ebf7443SwdenkCPCI405_config	\
552549826eaSstroeseCPCI4052_config	\
553549826eaSstroeseCPCI405AB_config:	unconfig
5547ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx cpci405 esd
5557ebf7443Swdenk	@echo "BOARD_REVISION = $(@:_config=)"	>>include/config.mk
5567ebf7443Swdenk
5577ebf7443SwdenkCPCI440_config:	unconfig
5587ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx cpci440 esd
5597ebf7443Swdenk
5607ebf7443SwdenkCPCIISER4_config:	unconfig
5617ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx cpciiser4 esd
5627ebf7443Swdenk
5637ebf7443SwdenkCRAYL1_config:unconfig
5647ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx L1 cray
5657ebf7443Swdenk
5667ebf7443SwdenkDASA_SIM_config: unconfig
5677ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx dasa_sim esd
5687ebf7443Swdenk
56972cd5aa7SstroeseDP405_config:	unconfig
57072cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx dp405 esd
57172cd5aa7Sstroese
5727ebf7443SwdenkDU405_config:	unconfig
5737ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx du405 esd
5747ebf7443Swdenk
5757ebf7443SwdenkEBONY_config:unconfig
5767ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ebony
5777ebf7443Swdenk
5787ebf7443SwdenkERIC_config:unconfig
5797ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx eric
5807ebf7443Swdenk
581d1cbe85bSwdenkEXBITGEN_config:unconfig
582d1cbe85bSwdenk	@./mkconfig $(@:_config=) ppc ppc4xx exbitgen
583d1cbe85bSwdenk
58472cd5aa7SstroeseHUB405_config:	unconfig
58572cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx hub405 esd
58672cd5aa7Sstroese
5877ebf7443SwdenkMIP405_config:unconfig
5887ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx mip405 mpl
5897ebf7443Swdenk
590f3e0de60SwdenkMIP405T_config:unconfig
591f3e0de60Swdenk	@echo "#define CONFIG_MIP405T" >include/config.h
592f3e0de60Swdenk	@echo "Enable subset config for MIP405T"
593f3e0de60Swdenk	@./mkconfig -a MIP405 ppc ppc4xx mip405 mpl
594f3e0de60Swdenk
5957ebf7443SwdenkML2_config:unconfig
5967ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ml2
5977ebf7443Swdenk
5987ebf7443SwdenkOCRTC_config		\
5997ebf7443SwdenkORSG_config:	unconfig
6007ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ocrtc esd
6017ebf7443Swdenk
6027ebf7443SwdenkPCI405_config:	unconfig
6037ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx pci405 esd
6047ebf7443Swdenk
6057ebf7443SwdenkPIP405_config:unconfig
6067ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx pip405 mpl
6077ebf7443Swdenk
60872cd5aa7SstroesePLU405_config:	unconfig
60972cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx plu405 esd
61072cd5aa7Sstroese
611549826eaSstroesePMC405_config:	unconfig
612549826eaSstroese	@./mkconfig $(@:_config=) ppc ppc4xx pmc405 esd
613549826eaSstroese
614fbe4b5cbSwdenkPPChameleonEVB_MODEL_BA_config	\
615fbe4b5cbSwdenkPPChameleonEVB_MODEL_ME_config	\
616fbe4b5cbSwdenkPPChameleonEVB_MODEL_HI_config	\
61712f34241SwdenkPPChameleonEVB_config:	unconfig
618fbe4b5cbSwdenk	@ >include/config.h
619fbe4b5cbSwdenk	@[ -z "$(findstring _MODEL_BA,$@)" ] || \
620fbe4b5cbSwdenk		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 0" >>include/config.h ; \
621fbe4b5cbSwdenk		  echo "... BASIC model" ; \
622fbe4b5cbSwdenk		}
623fbe4b5cbSwdenk	@[ -z "$(findstring _MODEL_ME,$@)" ] || \
624fbe4b5cbSwdenk		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 1" >>include/config.h ; \
625fbe4b5cbSwdenk		  echo "... MEDIUM model" ; \
626fbe4b5cbSwdenk		}
627fbe4b5cbSwdenk	@[ -z "$(findstring _MODEL_HI,$@)" ] || \
628fbe4b5cbSwdenk		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 2" >>include/config.h ; \
629fbe4b5cbSwdenk		  echo "... HIGH-END model" ; \
630fbe4b5cbSwdenk		}
631fbe4b5cbSwdenk	@./mkconfig -a $(call xtract_4xx,$@) ppc ppc4xx PPChameleonEVB dave
63212f34241Swdenk
63372cd5aa7SstroeseVOH405_config:	unconfig
63472cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx voh405 esd
63572cd5aa7Sstroese
6367ebf7443SwdenkW7OLMC_config	\
6377ebf7443SwdenkW7OLMG_config: unconfig
6387ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx w7o
6397ebf7443Swdenk
6407ebf7443SwdenkWALNUT405_config:unconfig
6417ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx walnut405
6427ebf7443Swdenk
6437ebf7443Swdenk#########################################################################
6447ebf7443Swdenk## MPC824x Systems
6457ebf7443Swdenk#########################################################################
6463bac3513Swdenkxtract_82xx = $(subst _ROMBOOT,,$(subst _L2,,$(subst _266MHz,,$(subst _300MHz,,$(subst _config,,$1)))))
6473bac3513Swdenk
6480332990bSwdenkA3000_config: unconfig
6490332990bSwdenk	@./mkconfig $(@:_config=) ppc mpc824x a3000
6500332990bSwdenk
6517ebf7443SwdenkBMW_config: unconfig
6527ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x bmw
6537ebf7443Swdenk
6543bac3513SwdenkCPC45_config	\
6553bac3513SwdenkCPC45_ROMBOOT_config:	unconfig
6563bac3513Swdenk	@./mkconfig $(call xtract_82xx,$@) ppc mpc824x cpc45
6573bac3513Swdenk	@cd ./include ;				\
6583bac3513Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
6593bac3513Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
6603bac3513Swdenk		echo "... booting from 8-bit flash" ; \
6613bac3513Swdenk	else \
6623bac3513Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
6633bac3513Swdenk		echo "... booting from 64-bit flash" ; \
6643bac3513Swdenk	fi; \
6653bac3513Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk;
6663bac3513Swdenk
6677ebf7443SwdenkCU824_config: unconfig
6687ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x cu824
6697ebf7443Swdenk
6707ebf7443SwdenkMOUSSE_config: unconfig
6717ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x mousse
6727ebf7443Swdenk
6737ebf7443SwdenkMUSENKI_config: unconfig
6747ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x musenki
6757ebf7443Swdenk
676b4676a25SwdenkMVBLUE_config:	unconfig
677b4676a25Swdenk	@./mkconfig $(@:_config=) ppc mpc824x mvblue
678b4676a25Swdenk
6797ebf7443SwdenkOXC_config: unconfig
6807ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x oxc
6817ebf7443Swdenk
6827ebf7443SwdenkPN62_config: unconfig
6837ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x pn62
6847ebf7443Swdenk
6857ebf7443SwdenkSandpoint8240_config: unconfig
6867ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x sandpoint
6877ebf7443Swdenk
6887ebf7443SwdenkSandpoint8245_config: unconfig
6897ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x sandpoint
6907ebf7443Swdenk
691d1cbe85bSwdenkSL8245_config: unconfig
692d1cbe85bSwdenk	@./mkconfig $(@:_config=) ppc mpc824x sl8245
693d1cbe85bSwdenk
6947ebf7443Swdenkutx8245_config: unconfig
6957ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x utx8245
6967ebf7443Swdenk
6977ebf7443Swdenk#########################################################################
6987ebf7443Swdenk## MPC8260 Systems
6997ebf7443Swdenk#########################################################################
7007ebf7443Swdenk
70154387ac9Swdenkatc_config:	unconfig
70254387ac9Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 atc
70354387ac9Swdenk
7047ebf7443Swdenkcogent_mpc8260_config:	unconfig
7057ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 cogent
7067ebf7443Swdenk
7077ebf7443SwdenkCPU86_config	\
7087ebf7443SwdenkCPU86_ROMBOOT_config: unconfig
7097ebf7443Swdenk	@./mkconfig $(call xtract_82xx,$@) ppc mpc8260 cpu86
7107ebf7443Swdenk	@cd ./include ;				\
7117ebf7443Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
7127ebf7443Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
7137ebf7443Swdenk		echo "... booting from 8-bit flash" ; \
7147ebf7443Swdenk	else \
7157ebf7443Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
7167ebf7443Swdenk		echo "... booting from 64-bit flash" ; \
7177ebf7443Swdenk	fi; \
7187ebf7443Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk;
7197ebf7443Swdenk
7207ebf7443Swdenkep8260_config:	unconfig
7217ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 ep8260
7227ebf7443Swdenk
7237ebf7443Swdenkgw8260_config:	unconfig
7247ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 gw8260
7257ebf7443Swdenk
7267ebf7443Swdenkhymod_config:	unconfig
7277ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 hymod
7287ebf7443Swdenk
7297ebf7443SwdenkIPHASE4539_config:	unconfig
7307ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 iphase4539
7317ebf7443Swdenk
7327ebf7443SwdenkMPC8260ADS_config:	unconfig
7337ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 mpc8260ads
7347ebf7443Swdenk
735db2f721fSwdenkMPC8266ADS_config:	unconfig
736db2f721fSwdenk	@./mkconfig $(@:_config=) ppc mpc8260 mpc8266ads
737db2f721fSwdenk
73810f67017SwdenkPM825_config	\
73910f67017SwdenkPM825_ROMBOOT_config: unconfig
74010f67017Swdenk	@echo "#define CONFIG_PCI"	>include/config.h
74110f67017Swdenk	@./mkconfig -a PM826 ppc mpc8260 pm826
74210f67017Swdenk	@cd ./include ;				\
74310f67017Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
74410f67017Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
74510f67017Swdenk		echo "... booting from 8-bit flash" ; \
74610f67017Swdenk	else \
74710f67017Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
74810f67017Swdenk		echo "... booting from 64-bit flash" ; \
74910f67017Swdenk	fi; \
75010f67017Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk; \
75110f67017Swdenk
7527ebf7443SwdenkPM826_config	\
7537ebf7443SwdenkPM826_ROMBOOT_config: unconfig
7547ebf7443Swdenk	@./mkconfig $(call xtract_82xx,$@) ppc mpc8260 pm826
7557ebf7443Swdenk	@cd ./include ;				\
7567ebf7443Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
7577ebf7443Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
7587ebf7443Swdenk		echo "... booting from 8-bit flash" ; \
7597ebf7443Swdenk	else \
7607ebf7443Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
7617ebf7443Swdenk		echo "... booting from 64-bit flash" ; \
7627ebf7443Swdenk	fi; \
7637ebf7443Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk; \
7647ebf7443Swdenk
7657ebf7443Swdenkppmc8260_config:	unconfig
7667ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 ppmc8260
7677ebf7443Swdenk
7687ebf7443SwdenkRPXsuper_config:	unconfig
7697ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 rpxsuper
7707ebf7443Swdenk
7717ebf7443Swdenkrsdproto_config:	unconfig
7727ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 rsdproto
7737ebf7443Swdenk
7747ebf7443Swdenksacsng_config:	unconfig
7757ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 sacsng
7767ebf7443Swdenk
7777ebf7443Swdenksbc8260_config:	unconfig
7787ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 sbc8260
7797ebf7443Swdenk
7807ebf7443SwdenkSCM_config:		unconfig
7817ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 SCM siemens
7827ebf7443Swdenk
78327b207fdSwdenkTQM8255_AA_config \
78427b207fdSwdenkTQM8260_AA_config \
78527b207fdSwdenkTQM8260_AB_config \
78627b207fdSwdenkTQM8260_AC_config \
78727b207fdSwdenkTQM8260_AD_config \
78827b207fdSwdenkTQM8260_AE_config \
78927b207fdSwdenkTQM8260_AF_config \
79027b207fdSwdenkTQM8260_AG_config \
79127b207fdSwdenkTQM8260_AH_config \
79227b207fdSwdenkTQM8265_AA_config:  unconfig
79327b207fdSwdenk	@case "$@" in \
79427b207fdSwdenk	TQM8255_AA_config) CTYPE=MPC8255; CFREQ=300; CACHE=no;  BMODE=8260;;  \
79527b207fdSwdenk	TQM8260_AA_config) CTYPE=MPC8260; CFREQ=200; CACHE=no;  BMODE=8260;; \
79627b207fdSwdenk	TQM8260_AB_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes; BMODE=60x;;  \
79727b207fdSwdenk	TQM8260_AC_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes; BMODE=60x;;  \
79827b207fdSwdenk	TQM8260_AD_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;  BMODE=60x;;  \
79927b207fdSwdenk	TQM8260_AE_config) CTYPE=MPC8260; CFREQ=266; CACHE=no;  BMODE=8260;; \
80027b207fdSwdenk	TQM8260_AF_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;  BMODE=60x;;  \
80127b207fdSwdenk	TQM8260_AG_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;  BMODE=8260;; \
80227b207fdSwdenk	TQM8260_AH_config) CTYPE=MPC8260; CFREQ=300; CACHE=yes; BMODE=60x;;  \
80327b207fdSwdenk	TQM8265_AA_config) CTYPE=MPC8265; CFREQ=300; CACHE=no;  BMODE=60x;;  \
80427b207fdSwdenk	esac; \
80527b207fdSwdenk	>include/config.h ; \
80627b207fdSwdenk	if [ "$${CTYPE}" != "MPC8260" ] ; then \
80727b207fdSwdenk		echo "#define CONFIG_$${CTYPE}"	>>include/config.h ; \
80827b207fdSwdenk	fi; \
80927b207fdSwdenk	echo "#define CONFIG_$${CFREQ}MHz"	>>include/config.h ; \
81027b207fdSwdenk	echo "... with $${CFREQ}MHz system clock" ; \
81127b207fdSwdenk	if [ "$${CACHE}" == "yes" ] ; then \
8127ebf7443Swdenk		echo "#define CONFIG_L2_CACHE"	>>include/config.h ; \
81327b207fdSwdenk		echo "... with L2 Cache support" ; \
8147ebf7443Swdenk	else \
8157ebf7443Swdenk		echo "#undef CONFIG_L2_CACHE"	>>include/config.h ; \
8167ebf7443Swdenk		echo "... without L2 Cache support" ; \
81727b207fdSwdenk	fi; \
81827b207fdSwdenk	if [ "$${BMODE}" == "60x" ] ; then \
81927b207fdSwdenk		echo "#define CONFIG_BUSMODE_60x" >>include/config.h ; \
82027b207fdSwdenk		echo "... with 60x Bus Mode" ; \
82127b207fdSwdenk	else \
82227b207fdSwdenk		echo "#undef CONFIG_BUSMODE_60x"  >>include/config.h ; \
82327b207fdSwdenk		echo "... without 60x Bus Mode" ; \
8247ebf7443Swdenk	fi
8254532cb69Swdenk	@./mkconfig -a TQM8260 ppc mpc8260 tqm8260
8267ebf7443Swdenk
82754387ac9SwdenkZPC1900_config: unconfig
82854387ac9Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 zpc1900
8297aa78614Swdenk
8304e5ca3ebSwdenk#========================================================================
8314e5ca3ebSwdenk# M68K
8324e5ca3ebSwdenk#========================================================================
8334e5ca3ebSwdenk#########################################################################
8344e5ca3ebSwdenk## Coldfire
8354e5ca3ebSwdenk#########################################################################
8364e5ca3ebSwdenk
8374e5ca3ebSwdenkM5272C3_config :		unconfig
8384e5ca3ebSwdenk	@./mkconfig $(@:_config=) m68k coldfire m5272c3
8394e5ca3ebSwdenk
8404e5ca3ebSwdenkM5282EVB_config :		unconfig
8414e5ca3ebSwdenk	@./mkconfig $(@:_config=) m68k coldfire m5282evb
8424e5ca3ebSwdenk
8437ebf7443Swdenk#########################################################################
84442d1f039Swdenk## MPC85xx Systems
84542d1f039Swdenk#########################################################################
84642d1f039Swdenk
84742d1f039SwdenkMPC8540ADS_config:      unconfig
84842d1f039Swdenk	@./mkconfig $(@:_config=) ppc mpc85xx mpc8540ads
84942d1f039Swdenk
85042d1f039SwdenkMPC8560ADS_config:      unconfig
85142d1f039Swdenk	@./mkconfig $(@:_config=) ppc mpc85xx mpc8560ads
85242d1f039Swdenk
85342d1f039Swdenk#########################################################################
8547ebf7443Swdenk## 74xx/7xx Systems
8557ebf7443Swdenk#########################################################################
8567ebf7443Swdenk
857c7de829cSwdenkAmigaOneG3SE_config:	unconfig
858c7de829cSwdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx AmigaOneG3SE MAI
859c7de829cSwdenk
86015647dc7SwdenkBAB7xx_config: unconfig
86115647dc7Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx bab7xx eltec
86215647dc7Swdenk
86315647dc7Swdenkdebris_config: unconfig
86415647dc7Swdenk	@./mkconfig $(@:_config=) ppc mpc824x debris etin
86515647dc7Swdenk
86615647dc7SwdenkELPPC_config: unconfig
86715647dc7Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx elppc eltec
86815647dc7Swdenk
8697ebf7443SwdenkEVB64260_config	\
8707ebf7443SwdenkEVB64260_750CX_config:	unconfig
8717ebf7443Swdenk	@./mkconfig EVB64260 ppc 74xx_7xx evb64260
8727ebf7443Swdenk
87315647dc7SwdenkP3G4_config: unconfig
8747ebf7443Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx evb64260
8757ebf7443Swdenk
8767ebf7443SwdenkPCIPPC2_config \
8777ebf7443SwdenkPCIPPC6_config: unconfig
8787ebf7443Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx pcippc2
8797ebf7443Swdenk
88015647dc7SwdenkZUMA_config:	unconfig
88112f34241Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx evb64260
88212f34241Swdenk
8837ebf7443Swdenk#========================================================================
8847ebf7443Swdenk# ARM
8857ebf7443Swdenk#========================================================================
8867ebf7443Swdenk#########################################################################
8877ebf7443Swdenk## StrongARM Systems
8887ebf7443Swdenk#########################################################################
8897ebf7443Swdenk
890dc7c9a1aSwdenkat91rm9200dk_config	:	unconfig
891dc7c9a1aSwdenk	@./mkconfig $(@:_config=) arm at91rm9200 at91rm9200dk
892dc7c9a1aSwdenk
8937ebf7443Swdenklart_config	:	unconfig
8947ebf7443Swdenk	@./mkconfig $(@:_config=) arm sa1100 lart
8957ebf7443Swdenk
8967ebf7443Swdenkdnp1110_config	:	unconfig
8977ebf7443Swdenk	@./mkconfig $(@:_config=) arm sa1100 dnp1110
8987ebf7443Swdenk
8997ebf7443Swdenkshannon_config	:	unconfig
9007ebf7443Swdenk	@./mkconfig $(@:_config=) arm sa1100 shannon
9017ebf7443Swdenk
9027ebf7443Swdenk#########################################################################
9032e5983d2Swdenk## ARM92xT Systems
9047ebf7443Swdenk#########################################################################
9057ebf7443Swdenk
906b0639ca3Swdenkxtract_trab = $(subst _bigram,,$(subst _bigflash,,$(subst _old,,$(subst _config,,$1))))
90743d9616cSwdenk
9082e5983d2Swdenkomap1510inn_config :	unconfig
9092e5983d2Swdenk	@./mkconfig $(@:_config=) arm arm925t omap1510inn
9102e5983d2Swdenk
9116f21347dSwdenkomap1610inn_config :	unconfig
9126f21347dSwdenk	@./mkconfig $(@:_config=) arm arm926ejs omap1610inn
9136f21347dSwdenk
9147ebf7443Swdenksmdk2400_config	:	unconfig
9157ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm920t smdk2400
9167ebf7443Swdenk
9177ebf7443Swdenksmdk2410_config	:	unconfig
9187ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm920t smdk2410
9197ebf7443Swdenk
920b2001f27Swdenk# TRAB default configuration:	8 MB Flash, 32 MB RAM
92143d9616cSwdenktrab_config \
922b0639ca3Swdenktrab_bigram_config \
923b0639ca3Swdenktrab_bigflash_config \
924f54ebdfaSwdenktrab_old_config:	unconfig
92543d9616cSwdenk	@ >include/config.h
926b0639ca3Swdenk	@[ -z "$(findstring _bigram,$@)" ] || \
927b0639ca3Swdenk		{ echo "#define CONFIG_FLASH_8MB"  >>include/config.h ; \
928b2001f27Swdenk		  echo "#define CONFIG_RAM_32MB"   >>include/config.h ; \
929b0639ca3Swdenk		  echo "... with 8 MB Flash, 32 MB RAM" ; \
930b0639ca3Swdenk		}
931b0639ca3Swdenk	@[ -z "$(findstring _bigflash,$@)" ] || \
932b2001f27Swdenk		{ echo "#define CONFIG_FLASH_16MB" >>include/config.h ; \
933b2001f27Swdenk		  echo "#define CONFIG_RAM_16MB"   >>include/config.h ; \
934b0639ca3Swdenk		  echo "... with 16 MB Flash, 16 MB RAM" ; \
935a8c7c708Swdenk		  echo "TEXT_BASE = 0x0CF40000" >board/trab/config.tmp ; \
936b0639ca3Swdenk		}
937f54ebdfaSwdenk	@[ -z "$(findstring _old,$@)" ] || \
938b2001f27Swdenk		{ echo "#define CONFIG_FLASH_8MB"  >>include/config.h ; \
939b2001f27Swdenk		  echo "#define CONFIG_RAM_16MB"   >>include/config.h ; \
940b2001f27Swdenk		  echo "... with 8 MB Flash, 16 MB RAM" ; \
941a8c7c708Swdenk		  echo "TEXT_BASE = 0x0CF40000" >board/trab/config.tmp ; \
94243d9616cSwdenk		}
94343d9616cSwdenk	@./mkconfig -a $(call xtract_trab,$@) arm arm920t trab
9447ebf7443Swdenk
9451cb8e980SwdenkVCMA9_config	:	unconfig
9461cb8e980Swdenk	@./mkconfig $(@:_config=) arm arm920t vcma9 mpl
9471cb8e980Swdenk
9487ebf7443Swdenk#########################################################################
9497ebf7443Swdenk## ARM720T Systems
9507ebf7443Swdenk#########################################################################
9517ebf7443Swdenk
9527ebf7443Swdenkimpa7_config	:	unconfig
9537ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm720t impa7
9547ebf7443Swdenk
9557ebf7443Swdenkep7312_config	:	unconfig
9567ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm720t ep7312
9577ebf7443Swdenk
9587ebf7443Swdenk#########################################################################
95943d9616cSwdenk## XScale Systems
9607ebf7443Swdenk#########################################################################
9617ebf7443Swdenk
9627ebf7443Swdenkcradle_config	:	unconfig
9634c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa cradle
9647ebf7443Swdenk
9657ebf7443Swdenkcsb226_config	:	unconfig
9664c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa csb226
9677ebf7443Swdenk
96843d9616cSwdenkinnokom_config	:	unconfig
9694c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa innokom
97043d9616cSwdenk
9712d5b561eSwdenkixdp425_config	:	unconfig
9722d5b561eSwdenk	@./mkconfig $(@:_config=) arm ixp ixdp425
9732d5b561eSwdenk
97443d9616cSwdenklubbock_config	:	unconfig
9754c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa lubbock
97643d9616cSwdenk
97752f52c14Swdenklogodl_config	:	unconfig
97852f52c14Swdenk	@./mkconfig $(@:_config=) arm pxa logodl
97952f52c14Swdenk
9803e38691eSwdenkwepep250_config	:	unconfig
9814c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa wepep250
9823e38691eSwdenk
9832262cfeeSwdenk#========================================================================
9842262cfeeSwdenk# i386
9852262cfeeSwdenk#========================================================================
9862262cfeeSwdenk#########################################################################
9872262cfeeSwdenk## AMD SC520 CDP
9882262cfeeSwdenk#########################################################################
9892262cfeeSwdenksc520_cdp_config	:	unconfig
9902262cfeeSwdenk	@./mkconfig $(@:_config=) i386 i386 sc520_cdp
9912262cfeeSwdenk
9927a8e9bedSwdenksc520_spunk_config	:	unconfig
9937a8e9bedSwdenk	@./mkconfig $(@:_config=) i386 i386 sc520_spunk
9947a8e9bedSwdenk
9957a8e9bedSwdenksc520_spunk_rel_config	:	unconfig
9967a8e9bedSwdenk	@./mkconfig $(@:_config=) i386 i386 sc520_spunk
9977a8e9bedSwdenk
99843d9616cSwdenk#========================================================================
99943d9616cSwdenk# MIPS
100043d9616cSwdenk#========================================================================
10017ebf7443Swdenk#########################################################################
100243d9616cSwdenk## MIPS32 4Kc
100343d9616cSwdenk#########################################################################
100443d9616cSwdenk
1005e0ac62d7Swdenkxtract_incaip = $(subst _100MHz,,$(subst _133MHz,,$(subst _150MHz,,$(subst _config,,$1))))
1006e0ac62d7Swdenk
1007e0ac62d7Swdenkincaip_100MHz_config	\
1008e0ac62d7Swdenkincaip_133MHz_config	\
1009e0ac62d7Swdenkincaip_150MHz_config	\
101043d9616cSwdenkincaip_config: unconfig
1011e0ac62d7Swdenk	@ >include/config.h
1012e0ac62d7Swdenk	@[ -z "$(findstring _100MHz,$@)" ] || \
1013e0ac62d7Swdenk		{ echo "#define CPU_CLOCK_RATE 100000000" >>include/config.h ; \
1014e0ac62d7Swdenk		  echo "... with 100MHz system clock" ; \
1015e0ac62d7Swdenk		}
1016e0ac62d7Swdenk	@[ -z "$(findstring _133MHz,$@)" ] || \
1017e0ac62d7Swdenk		{ echo "#define CPU_CLOCK_RATE 133000000" >>include/config.h ; \
1018e0ac62d7Swdenk		  echo "... with 133MHz system clock" ; \
1019e0ac62d7Swdenk		}
1020e0ac62d7Swdenk	@[ -z "$(findstring _150MHz,$@)" ] || \
1021e0ac62d7Swdenk		{ echo "#define CPU_CLOCK_RATE 150000000" >>include/config.h ; \
1022e0ac62d7Swdenk		  echo "... with 150MHz system clock" ; \
1023e0ac62d7Swdenk		}
1024e0ac62d7Swdenk	@./mkconfig -a $(call xtract_incaip,$@) mips mips incaip
1025e0ac62d7Swdenk
1026e0ac62d7Swdenk#########################################################################
1027e0ac62d7Swdenk## MIPS64 5Kc
1028e0ac62d7Swdenk#########################################################################
102943d9616cSwdenk
10303e38691eSwdenkpurple_config :		unconfig
10313e38691eSwdenk	@./mkconfig $(@:_config=) mips mips purple
103243d9616cSwdenk
10334a551709Swdenk#========================================================================
10344a551709Swdenk# Nios
10354a551709Swdenk#========================================================================
10364a551709Swdenk#########################################################################
10374a551709Swdenk## Nios32
10384a551709Swdenk#########################################################################
10394a551709Swdenk
10404a551709SwdenkDK1C20_config:	unconfig
10414a551709Swdenk	@./mkconfig $(@:_config=) nios nios dk1c20
10424a551709Swdenk
10434a551709Swdenk
10443e38691eSwdenk#########################################################################
1045a2663ea4Swdenk## MIPS32 AU1X00
10465da627a4Swdenk#########################################################################
1047a2663ea4Swdenkdbau1000_config		: 	unconfig
1048a2663ea4Swdenk	@ >include/config.h
1049a2663ea4Swdenk	@echo "#define CONFIG_DBAU1000 1" >>include/config.h
1050a2663ea4Swdenk	@./mkconfig -a dbau1x00 mips mips dbau1x00
1051a2663ea4Swdenk
1052a2663ea4Swdenkdbau1100_config		: 	unconfig
1053a2663ea4Swdenk	@ >include/config.h
1054a2663ea4Swdenk	@echo "#define CONFIG_DBAU1100 1" >>include/config.h
1055a2663ea4Swdenk	@./mkconfig -a dbau1x00 mips mips dbau1x00
1056a2663ea4Swdenk
1057a2663ea4Swdenkdbau1500_config		: 	unconfig
1058a2663ea4Swdenk	@ >include/config.h
1059a2663ea4Swdenk	@echo "#define CONFIG_DBAU1500 1" >>include/config.h
1060a2663ea4Swdenk	@./mkconfig -a dbau1x00 mips mips dbau1x00
10615da627a4Swdenk
10625da627a4Swdenk#########################################################################
10633e38691eSwdenk#########################################################################
10647ebf7443Swdenk
10657ebf7443Swdenkclean:
10667ebf7443Swdenk	find . -type f \
10677ebf7443Swdenk		\( -name 'core' -o -name '*.bak' -o -name '*~' \
10687ebf7443Swdenk		-o -name '*.o'  -o -name '*.a'  \) -print \
10697ebf7443Swdenk		| xargs rm -f
107085ec0bccSwdenk	rm -f examples/hello_world examples/timer \
10713e38691eSwdenk	      examples/eepro100_eeprom examples/sched \
10727a8e9bedSwdenk	      examples/mem_to_mem_idma2intr examples/82559_eeprom
10737a8e9bedSwdenk
10747ebf7443Swdenk	rm -f tools/img2srec tools/mkimage tools/envcrc tools/gen_eth_addr
10757ebf7443Swdenk	rm -f tools/easylogo/easylogo tools/bmp_logo
10767ebf7443Swdenk	rm -f tools/gdb/astest tools/gdb/gdbcont tools/gdb/gdbsend
1077228f29acSwdenk	rm -f tools/env/fw_printenv tools/env/fw_setenv
10787f70e853Swdenk	rm -f board/cray/L1/bootscript.c board/cray/L1/bootscript.image
10795cf9da48Swdenk	rm -f board/trab/trab_fkt board/*/config.tmp
10807ebf7443Swdenk
10817ebf7443Swdenkclobber:	clean
10827ebf7443Swdenk	find . -type f \
10837ebf7443Swdenk		\( -name .depend -o -name '*.srec' -o -name '*.bin' \) \
10847ebf7443Swdenk		-print \
10857ebf7443Swdenk		| xargs rm -f
10867ebf7443Swdenk	rm -f $(OBJS) *.bak tags TAGS
10877ebf7443Swdenk	rm -fr *.*~
1088bdccc4feSwdenk	rm -f u-boot u-boot.map $(ALL)
1089228f29acSwdenk	rm -f tools/crc32.c tools/environment.c tools/env/crc32.c
10903e38691eSwdenk	rm -f tools/inca-swap-bytes cpu/mpc824x/bedbug_603e.c
1091b783edaeSwdenk	rm -f include/asm/proc include/asm/arch include/asm
10927ebf7443Swdenk
10937ebf7443Swdenkmrproper \
10947ebf7443Swdenkdistclean:	clobber unconfig
10957ebf7443Swdenk
10967ebf7443Swdenkbackup:
10977ebf7443Swdenk	F=`basename $(TOPDIR)` ; cd .. ; \
10987ebf7443Swdenk	gtar --force-local -zcvf `date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
10997ebf7443Swdenk
11007ebf7443Swdenk#########################################################################
1101