xref: /rk3399_rockchip-uboot/Makefile (revision b2001f273fcb34d0f2ca43a9b01a24e5c50da6cd)
17ebf7443Swdenk#
27ebf7443Swdenk# (C) Copyright 2000, 2001, 2002
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*b2001f27Swdenkicecube_5200_DDR_config		\
208*b2001f27SwdenkIceCube_5200_DDR_config		\
209a0f2fe52Swdenkicecube_5200_config		\
210945af8d7SwdenkIceCube_5200_config		\
211945af8d7SwdenkIceCube_5100_config:		unconfig
212945af8d7Swdenk	@ >include/config.h
2135cf9da48Swdenk	@[ -z "$(findstring LOWBOOT,$@)" ] || \
2145cf9da48Swdenk		{ echo "TEXT_BASE = 0xFF000000" >board/icecube/config.tmp ; \
2155cf9da48Swdenk		  echo "... with LOWBOOT configuration" ; \
2165cf9da48Swdenk		}
2175cf9da48Swdenk	@[ -z "$(findstring LOWBOOT08,$@)" ] || \
2185cf9da48Swdenk		{ echo "TEXT_BASE = 0xFF800000" >board/icecube/config.tmp ; \
2195cf9da48Swdenk		  echo "... with 8 MB flash only" ; \
2205cf9da48Swdenk		}
221a0f2fe52Swdenk	@[ -z "$(findstring 5200,$@)" ] || \
222945af8d7Swdenk		{ echo "#define CONFIG_MPC5200"		>>include/config.h ; \
223945af8d7Swdenk		  echo "... with MPC5200 processor" ; \
224945af8d7Swdenk		}
225*b2001f27Swdenk	@[ -z "$(findstring DDR,$@)" ] || \
226*b2001f27Swdenk		{ echo "#define CONFIG_MPC5200_DDR"	>>include/config.h ; \
227*b2001f27Swdenk		  echo "... DDR memory revision" ; \
228*b2001f27Swdenk		}
229a0f2fe52Swdenk	@[ -z "$(findstring 5100,$@)" ] || \
230945af8d7Swdenk		{ echo "#define CONFIG_MGT5100"		>>include/config.h ; \
231945af8d7Swdenk		  echo "... with MGT5100 processor" ; \
232945af8d7Swdenk		}
233945af8d7Swdenk	@./mkconfig -a IceCube ppc mpc5xxx icecube
234945af8d7Swdenk
235945af8d7Swdenk#########################################################################
2367ebf7443Swdenk## MPC8xx Systems
2377ebf7443Swdenk#########################################################################
2387ebf7443Swdenk
2390cb61d7dSwdenkAdderII_config:	unconfig
2400cb61d7dSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx adderII
2410cb61d7dSwdenk
2427ebf7443SwdenkADS860_config:	unconfig
2437ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx fads
2447ebf7443Swdenk
2457ebf7443SwdenkAMX860_config	:	unconfig
2467ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx amx860 westel
2477ebf7443Swdenk
248fd3103bbSwdenkbms2003_config	:	unconfig
249fd3103bbSwdenk	@echo "#define CONFIG_BMS2003" >include/config.h
250fd3103bbSwdenk	@echo "#define CONFIG_LCD" >>include/config.h
251fd3103bbSwdenk	@echo "#define CONFIG_NEC_NL6448BC33_54" >>include/config.h
252fd3103bbSwdenk	@./mkconfig -a TQM823L ppc mpc8xx tqm8xx
253fd3103bbSwdenk
2547ebf7443Swdenkc2mon_config:		unconfig
2557ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx c2mon
2567ebf7443Swdenk
2577ebf7443SwdenkCCM_config:		unconfig
2587ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx CCM siemens
2597ebf7443Swdenk
2607ebf7443Swdenkcogent_mpc8xx_config:	unconfig
2617ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx cogent
2627ebf7443Swdenk
2633bac3513SwdenkELPT860_config:		unconfig
2643bac3513Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx elpt860 LEOX
2653bac3513Swdenk
2667ebf7443SwdenkESTEEM192E_config:	unconfig
2677ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx esteem192e
2687ebf7443Swdenk
2697ebf7443SwdenkETX094_config	:	unconfig
2707ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx etx094
2717ebf7443Swdenk
2727ebf7443SwdenkFADS823_config	\
2737ebf7443SwdenkFADS850SAR_config \
2742535d602SwdenkMPC86xADS_config \
2757ebf7443SwdenkFADS860T_config:	unconfig
2767ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx fads
2777ebf7443Swdenk
2787ebf7443SwdenkFLAGADM_config:	unconfig
2797ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx flagadm
2807ebf7443Swdenk
2817aa78614Swdenkxtract_GEN860T = $(subst _SC,,$(subst _config,,$1))
2827aa78614Swdenk
2837aa78614SwdenkGEN860T_SC_config	\
2847ebf7443SwdenkGEN860T_config: unconfig
2857aa78614Swdenk	@ >include/config.h
2867aa78614Swdenk	@[ -z "$(findstring _SC,$@)" ] || \
2877aa78614Swdenk		{ echo "#define CONFIG_SC" >>include/config.h ; \
2887aa78614Swdenk		  echo "With reduced H/W feature set (SC)..." ; \
2897aa78614Swdenk		}
2907aa78614Swdenk	@./mkconfig -a $(call xtract_GEN860T,$@) ppc mpc8xx gen860t
2917ebf7443Swdenk
2927ebf7443SwdenkGENIETV_config:	unconfig
2937ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx genietv
2947ebf7443Swdenk
2957ebf7443SwdenkGTH_config:	unconfig
2967ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx gth
2977ebf7443Swdenk
2987ebf7443Swdenkhermes_config	:	unconfig
2997ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx hermes
3007ebf7443Swdenk
3017ebf7443SwdenkIAD210_config: unconfig
3027ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx IAD210 siemens
3037ebf7443Swdenk
3047ebf7443Swdenkxtract_ICU862 = $(subst _100MHz,,$(subst _config,,$1))
3057ebf7443Swdenk
3067ebf7443SwdenkICU862_100MHz_config	\
3077ebf7443SwdenkICU862_config: unconfig
3087ebf7443Swdenk	@ >include/config.h
3097ebf7443Swdenk	@[ -z "$(findstring _100MHz,$@)" ] || \
3107ebf7443Swdenk		{ echo "#define CONFIG_100MHz"	>>include/config.h ; \
3117ebf7443Swdenk		  echo "... with 100MHz system clock" ; \
3127ebf7443Swdenk		}
3137ebf7443Swdenk	@./mkconfig -a $(call xtract_ICU862,$@) ppc mpc8xx icu862
3147ebf7443Swdenk
3157ebf7443SwdenkIP860_config	:	unconfig
3167ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx ip860
3177ebf7443Swdenk
3187ebf7443SwdenkIVML24_256_config \
3197ebf7443SwdenkIVML24_128_config \
3207ebf7443SwdenkIVML24_config:	unconfig
3217ebf7443Swdenk	@ >include/config.h
3227ebf7443Swdenk	@[ -z "$(findstring IVML24_config,$@)" ] || \
3237ebf7443Swdenk		 { echo "#define CONFIG_IVML24_16M"	>>include/config.h ; \
3247ebf7443Swdenk		 }
3257ebf7443Swdenk	@[ -z "$(findstring IVML24_128_config,$@)" ] || \
3267ebf7443Swdenk		 { echo "#define CONFIG_IVML24_32M"	>>include/config.h ; \
3277ebf7443Swdenk		 }
3287ebf7443Swdenk	@[ -z "$(findstring IVML24_256_config,$@)" ] || \
3297ebf7443Swdenk		 { echo "#define CONFIG_IVML24_64M"	>>include/config.h ; \
3307ebf7443Swdenk		 }
3317ebf7443Swdenk	@./mkconfig -a IVML24 ppc mpc8xx ivm
3327ebf7443Swdenk
3337ebf7443SwdenkIVMS8_256_config \
3347ebf7443SwdenkIVMS8_128_config \
3357ebf7443SwdenkIVMS8_config:	unconfig
3367ebf7443Swdenk	@ >include/config.h
3377ebf7443Swdenk	@[ -z "$(findstring IVMS8_config,$@)" ] || \
3387ebf7443Swdenk		 { echo "#define CONFIG_IVMS8_16M"	>>include/config.h ; \
3397ebf7443Swdenk		 }
3407ebf7443Swdenk	@[ -z "$(findstring IVMS8_128_config,$@)" ] || \
3417ebf7443Swdenk		 { echo "#define CONFIG_IVMS8_32M"	>>include/config.h ; \
3427ebf7443Swdenk		 }
3437ebf7443Swdenk	@[ -z "$(findstring IVMS8_256_config,$@)" ] || \
3447ebf7443Swdenk		 { echo "#define CONFIG_IVMS8_64M"	>>include/config.h ; \
3457ebf7443Swdenk		 }
3467ebf7443Swdenk	@./mkconfig -a IVMS8 ppc mpc8xx ivm
3477ebf7443Swdenk
34856f94be3SwdenkKUP4K_config	:	unconfig
34956f94be3Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx kup4k
35056f94be3Swdenk
3517ebf7443SwdenkLANTEC_config	:	unconfig
3527ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx lantec
3537ebf7443Swdenk
3547ebf7443Swdenklwmon_config:		unconfig
3557ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx lwmon
3567ebf7443Swdenk
3577ebf7443SwdenkMBX_config	\
3587ebf7443SwdenkMBX860T_config:	unconfig
3597ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx mbx8xx
3607ebf7443Swdenk
3617ebf7443SwdenkMHPC_config:		unconfig
3627ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx mhpc eltec
3637ebf7443Swdenk
3647ebf7443SwdenkMVS1_config :		unconfig
3657ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx mvs1
3667ebf7443Swdenk
367993cad93Swdenkxtract_NETVIA = $(subst _V2,,$(subst _config,,$1))
368993cad93Swdenk
369993cad93SwdenkNETVIA_V2_config \
3707ebf7443SwdenkNETVIA_config:		unconfig
371993cad93Swdenk	@ >include/config.h
372993cad93Swdenk	@[ -z "$(findstring NETVIA_config,$@)" ] || \
373993cad93Swdenk		 { echo "#define CONFIG_NETVIA_VERSION 1" >>include/config.h ; \
374993cad93Swdenk		  echo "... Version 1" ; \
375993cad93Swdenk		 }
376993cad93Swdenk	@[ -z "$(findstring NETVIA_V2_config,$@)" ] || \
377993cad93Swdenk		 { echo "#define CONFIG_NETVIA_VERSION 2" >>include/config.h ; \
378993cad93Swdenk		  echo "... Version 2" ; \
379993cad93Swdenk		 }
380993cad93Swdenk	@./mkconfig -a $(call xtract_NETVIA,$@) ppc mpc8xx netvia
3817ebf7443Swdenk
3827ebf7443SwdenkNX823_config:		unconfig
3837ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx nx823
3847ebf7443Swdenk
3857ebf7443Swdenkpcu_e_config:		unconfig
3867ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx pcu_e siemens
3877ebf7443Swdenk
3883bbc899fSwdenkQS850_config:	unconfig
3893bbc899fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx qs850 snmc
3903bbc899fSwdenk
3913bbc899fSwdenkQS823_config:	unconfig
3923bbc899fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx qs850 snmc
3933bbc899fSwdenk
3943bbc899fSwdenkQS860T_config:	unconfig
3953bbc899fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx qs860t snmc
3963bbc899fSwdenk
3977ebf7443SwdenkR360MPI_config:	unconfig
3987ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx r360mpi
3997ebf7443Swdenk
400682011ffSwdenkRBC823_config:	unconfig
401682011ffSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx rbc823
402682011ffSwdenk
4037ebf7443SwdenkRPXClassic_config:	unconfig
4047ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx RPXClassic
4057ebf7443Swdenk
4067ebf7443SwdenkRPXlite_config:		unconfig
4077ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx RPXlite
4087ebf7443Swdenk
40973a8b27cSwdenkrmu_config:	unconfig
41073a8b27cSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx rmu
41173a8b27cSwdenk
4127ebf7443SwdenkRRvision_config:	unconfig
4137ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx RRvision
4147ebf7443Swdenk
4157ebf7443SwdenkRRvision_LCD_config:	unconfig
4167ebf7443Swdenk	@echo "#define CONFIG_LCD" >include/config.h
4177ebf7443Swdenk	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>include/config.h
4187ebf7443Swdenk	@./mkconfig -a RRvision ppc mpc8xx RRvision
4197ebf7443Swdenk
4207ebf7443SwdenkSM850_config	:	unconfig
4217ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx tqm8xx
4227ebf7443Swdenk
4237ebf7443SwdenkSPD823TS_config:	unconfig
4247ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx spd8xx
4257ebf7443Swdenk
426dc7c9a1aSwdenksvm_sc8xx_config:	unconfig
427dc7c9a1aSwdenk	@ >include/config.h
428dc7c9a1aSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx svm_sc8xx
429dc7c9a1aSwdenk
4307ebf7443SwdenkSXNI855T_config:	unconfig
4317ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx sixnet
4327ebf7443Swdenk
433db2f721fSwdenk# EMK MPC8xx based modules
434db2f721fSwdenkTOP860_config:		unconfig
435db2f721fSwdenk	@./mkconfig $(@:_config=) ppc mpc8xx top860 emk
436db2f721fSwdenk
4377ebf7443Swdenk# Play some tricks for configuration selection
43873a8b27cSwdenk# All boards can come with 50 MHz (default), 66MHz, 80MHz or 100 MHz clock,
4397ebf7443Swdenk# but only 855 and 860 boards may come with FEC
4407ebf7443Swdenk# and 823 boards may have LCD support
44173a8b27cSwdenkxtract_8xx = $(subst _66MHz,,$(subst _80MHz,,$(subst _100MHz,,$(subst _LCD,,$(subst _config,,$1)))))
4427ebf7443Swdenk
4437ebf7443SwdenkFPS850L_config		\
444384ae025SwdenkFPS860L_config		\
445f12e568cSwdenkNSCU_config		\
4467ebf7443SwdenkTQM823L_config		\
4477ebf7443SwdenkTQM823L_66MHz_config	\
4487ebf7443SwdenkTQM823L_80MHz_config	\
4497ebf7443SwdenkTQM823L_LCD_config	\
4507ebf7443SwdenkTQM823L_LCD_66MHz_config \
4517ebf7443SwdenkTQM823L_LCD_80MHz_config \
4527ebf7443SwdenkTQM850L_config		\
4537ebf7443SwdenkTQM850L_66MHz_config	\
4547ebf7443SwdenkTQM850L_80MHz_config	\
4557ebf7443SwdenkTQM855L_config		\
4567ebf7443SwdenkTQM855L_66MHz_config	\
4577ebf7443SwdenkTQM855L_80MHz_config	\
4587ebf7443SwdenkTQM860L_config		\
4597ebf7443SwdenkTQM860L_66MHz_config	\
4607ebf7443SwdenkTQM860L_80MHz_config	\
461d126bfbdSwdenkTQM862L_config		\
462d126bfbdSwdenkTQM862L_66MHz_config	\
46373a8b27cSwdenkTQM862L_80MHz_config	\
464ae3af05eSwdenkTQM823M_config		\
465ae3af05eSwdenkTQM823M_66MHz_config	\
466ae3af05eSwdenkTQM823M_80MHz_config	\
467ae3af05eSwdenkTQM850M_config		\
468ae3af05eSwdenkTQM850M_66MHz_config	\
469ae3af05eSwdenkTQM850M_80MHz_config	\
470f12e568cSwdenkTQM855M_config		\
471f12e568cSwdenkTQM855M_66MHz_config	\
472f12e568cSwdenkTQM855M_80MHz_config	\
473f12e568cSwdenkTQM860M_config		\
474f12e568cSwdenkTQM860M_66MHz_config	\
475f12e568cSwdenkTQM860M_80MHz_config	\
476f12e568cSwdenkTQM862M_config		\
477f12e568cSwdenkTQM862M_66MHz_config	\
478f12e568cSwdenkTQM862M_80MHz_config	\
47971f95118SwdenkTQM862M_100MHz_config:	unconfig
4807ebf7443Swdenk	@ >include/config.h
4817ebf7443Swdenk	@[ -z "$(findstring _66MHz,$@)" ] || \
4827ebf7443Swdenk		{ echo "#define CONFIG_66MHz"		>>include/config.h ; \
4837ebf7443Swdenk		  echo "... with 66MHz system clock" ; \
4847ebf7443Swdenk		}
4857ebf7443Swdenk	@[ -z "$(findstring _80MHz,$@)" ] || \
4867ebf7443Swdenk		{ echo "#define CONFIG_80MHz"		>>include/config.h ; \
4877ebf7443Swdenk		  echo "... with 80MHz system clock" ; \
4887ebf7443Swdenk		}
48973a8b27cSwdenk	@[ -z "$(findstring _100MHz,$@)" ] || \
49073a8b27cSwdenk		{ echo "#define CONFIG_100MHz"		>>include/config.h ; \
49173a8b27cSwdenk		  echo "... with 100MHz system clock" ; \
49273a8b27cSwdenk		}
4937ebf7443Swdenk	@[ -z "$(findstring _LCD,$@)" ] || \
4947ebf7443Swdenk		{ echo "#define CONFIG_LCD"		>>include/config.h ; \
495fd3103bbSwdenk		  echo "#define CONFIG_NEC_NL6448BC20"	>>include/config.h ; \
4967ebf7443Swdenk		  echo "... with LCD display" ; \
4977ebf7443Swdenk		}
4987ebf7443Swdenk	@./mkconfig -a $(call xtract_8xx,$@) ppc mpc8xx tqm8xx
4997ebf7443Swdenk
5007ebf7443SwdenkTTTech_config:	unconfig
5017ebf7443Swdenk	@echo "#define CONFIG_LCD" >include/config.h
5027ebf7443Swdenk	@echo "#define CONFIG_SHARP_LQ104V7DS01" >>include/config.h
5037ebf7443Swdenk	@./mkconfig -a TQM823L ppc mpc8xx tqm8xx
5047ebf7443Swdenk
505608c9146Swdenkv37_config:	unconfig
506608c9146Swdenk	@echo "#define CONFIG_LCD" >include/config.h
507608c9146Swdenk	@echo "#define CONFIG_SHARP_LQ084V1DG21" >>include/config.h
508608c9146Swdenk	@./mkconfig $(@:_config=) ppc mpc8xx v37
509608c9146Swdenk
51091e940d9Sdzuwtk_config:	unconfig
51191e940d9Sdzu	@echo "#define CONFIG_LCD" >include/config.h
51291e940d9Sdzu	@echo "#define CONFIG_SHARP_LQ065T9DR51U" >>include/config.h
51391e940d9Sdzu	@./mkconfig -a TQM823L ppc mpc8xx tqm8xx
51491e940d9Sdzu
5157ebf7443Swdenk#########################################################################
5167ebf7443Swdenk## PPC4xx Systems
5177ebf7443Swdenk#########################################################################
518fbe4b5cbSwdenkxtract_4xx = $(subst _MODEL_BA,,$(subst _MODEL_ME,,$(subst _MODEL_HI,,$(subst _config,,$1))))
5197ebf7443Swdenk
5207ebf7443SwdenkADCIOP_config:	unconfig
5217ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx adciop esd
5227ebf7443Swdenk
5237ebf7443SwdenkAR405_config:	unconfig
5247ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ar405 esd
5257ebf7443Swdenk
526549826eaSstroeseASH405_config:	unconfig
527549826eaSstroese	@./mkconfig $(@:_config=) ppc ppc4xx ash405 esd
528549826eaSstroese
529549826eaSstroeseBUBINGA405EP_config:unconfig
530549826eaSstroese	@./mkconfig $(@:_config=) ppc ppc4xx bubinga405ep
531549826eaSstroese
5327ebf7443SwdenkCANBT_config:	unconfig
5337ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx canbt esd
5347ebf7443Swdenk
5357ebf7443SwdenkCPCI405_config	\
536549826eaSstroeseCPCI4052_config	\
537549826eaSstroeseCPCI405AB_config:	unconfig
5387ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx cpci405 esd
5397ebf7443Swdenk	@echo "BOARD_REVISION = $(@:_config=)"	>>include/config.mk
5407ebf7443Swdenk
5417ebf7443SwdenkCPCI440_config:	unconfig
5427ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx cpci440 esd
5437ebf7443Swdenk
5447ebf7443SwdenkCPCIISER4_config:	unconfig
5457ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx cpciiser4 esd
5467ebf7443Swdenk
5477ebf7443SwdenkCRAYL1_config:unconfig
5487ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx L1 cray
5497ebf7443Swdenk
5507ebf7443SwdenkDASA_SIM_config: unconfig
5517ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx dasa_sim esd
5527ebf7443Swdenk
55372cd5aa7SstroeseDP405_config:	unconfig
55472cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx dp405 esd
55572cd5aa7Sstroese
5567ebf7443SwdenkDU405_config:	unconfig
5577ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx du405 esd
5587ebf7443Swdenk
5597ebf7443SwdenkEBONY_config:unconfig
5607ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ebony
5617ebf7443Swdenk
5627ebf7443SwdenkERIC_config:unconfig
5637ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx eric
5647ebf7443Swdenk
565d1cbe85bSwdenkEXBITGEN_config:unconfig
566d1cbe85bSwdenk	@./mkconfig $(@:_config=) ppc ppc4xx exbitgen
567d1cbe85bSwdenk
56872cd5aa7SstroeseHUB405_config:	unconfig
56972cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx hub405 esd
57072cd5aa7Sstroese
5717ebf7443SwdenkMIP405_config:unconfig
5727ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx mip405 mpl
5737ebf7443Swdenk
574f3e0de60SwdenkMIP405T_config:unconfig
575f3e0de60Swdenk	@echo "#define CONFIG_MIP405T" >include/config.h
576f3e0de60Swdenk	@echo "Enable subset config for MIP405T"
577f3e0de60Swdenk	@./mkconfig -a MIP405 ppc ppc4xx mip405 mpl
578f3e0de60Swdenk
5797ebf7443SwdenkML2_config:unconfig
5807ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ml2
5817ebf7443Swdenk
5827ebf7443SwdenkOCRTC_config		\
5837ebf7443SwdenkORSG_config:	unconfig
5847ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx ocrtc esd
5857ebf7443Swdenk
5867ebf7443SwdenkPCI405_config:	unconfig
5877ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx pci405 esd
5887ebf7443Swdenk
5897ebf7443SwdenkPIP405_config:unconfig
5907ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx pip405 mpl
5917ebf7443Swdenk
59272cd5aa7SstroesePLU405_config:	unconfig
59372cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx plu405 esd
59472cd5aa7Sstroese
595549826eaSstroesePMC405_config:	unconfig
596549826eaSstroese	@./mkconfig $(@:_config=) ppc ppc4xx pmc405 esd
597549826eaSstroese
598fbe4b5cbSwdenkPPChameleonEVB_MODEL_BA_config	\
599fbe4b5cbSwdenkPPChameleonEVB_MODEL_ME_config	\
600fbe4b5cbSwdenkPPChameleonEVB_MODEL_HI_config	\
60112f34241SwdenkPPChameleonEVB_config:	unconfig
602fbe4b5cbSwdenk	@ >include/config.h
603fbe4b5cbSwdenk	@[ -z "$(findstring _MODEL_BA,$@)" ] || \
604fbe4b5cbSwdenk		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 0" >>include/config.h ; \
605fbe4b5cbSwdenk		  echo "... BASIC model" ; \
606fbe4b5cbSwdenk		}
607fbe4b5cbSwdenk	@[ -z "$(findstring _MODEL_ME,$@)" ] || \
608fbe4b5cbSwdenk		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 1" >>include/config.h ; \
609fbe4b5cbSwdenk		  echo "... MEDIUM model" ; \
610fbe4b5cbSwdenk		}
611fbe4b5cbSwdenk	@[ -z "$(findstring _MODEL_HI,$@)" ] || \
612fbe4b5cbSwdenk		{ echo "#define CONFIG_PPCHAMELEON_MODULE_MODEL 2" >>include/config.h ; \
613fbe4b5cbSwdenk		  echo "... HIGH-END model" ; \
614fbe4b5cbSwdenk		}
615fbe4b5cbSwdenk	@./mkconfig -a $(call xtract_4xx,$@) ppc ppc4xx PPChameleonEVB dave
61612f34241Swdenk
61772cd5aa7SstroeseVOH405_config:	unconfig
61872cd5aa7Sstroese	@./mkconfig $(@:_config=) ppc ppc4xx voh405 esd
61972cd5aa7Sstroese
6207ebf7443SwdenkW7OLMC_config	\
6217ebf7443SwdenkW7OLMG_config: unconfig
6227ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx w7o
6237ebf7443Swdenk
6247ebf7443SwdenkWALNUT405_config:unconfig
6257ebf7443Swdenk	@./mkconfig $(@:_config=) ppc ppc4xx walnut405
6267ebf7443Swdenk
6277ebf7443Swdenk#########################################################################
6287ebf7443Swdenk## MPC824x Systems
6297ebf7443Swdenk#########################################################################
6303bac3513Swdenkxtract_82xx = $(subst _ROMBOOT,,$(subst _L2,,$(subst _266MHz,,$(subst _300MHz,,$(subst _config,,$1)))))
6313bac3513Swdenk
6320332990bSwdenkA3000_config: unconfig
6330332990bSwdenk	@./mkconfig $(@:_config=) ppc mpc824x a3000
6340332990bSwdenk
6357ebf7443SwdenkBMW_config: unconfig
6367ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x bmw
6377ebf7443Swdenk
6383bac3513SwdenkCPC45_config	\
6393bac3513SwdenkCPC45_ROMBOOT_config:	unconfig
6403bac3513Swdenk	@./mkconfig $(call xtract_82xx,$@) ppc mpc824x cpc45
6413bac3513Swdenk	@cd ./include ;				\
6423bac3513Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
6433bac3513Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
6443bac3513Swdenk		echo "... booting from 8-bit flash" ; \
6453bac3513Swdenk	else \
6463bac3513Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
6473bac3513Swdenk		echo "... booting from 64-bit flash" ; \
6483bac3513Swdenk	fi; \
6493bac3513Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk;
6503bac3513Swdenk
6517ebf7443SwdenkCU824_config: unconfig
6527ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x cu824
6537ebf7443Swdenk
6547ebf7443SwdenkMOUSSE_config: unconfig
6557ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x mousse
6567ebf7443Swdenk
6577ebf7443SwdenkMUSENKI_config: unconfig
6587ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x musenki
6597ebf7443Swdenk
660b4676a25SwdenkMVBLUE_config:	unconfig
661b4676a25Swdenk	@./mkconfig $(@:_config=) ppc mpc824x mvblue
662b4676a25Swdenk
6637ebf7443SwdenkOXC_config: unconfig
6647ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x oxc
6657ebf7443Swdenk
6667ebf7443SwdenkPN62_config: unconfig
6677ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x pn62
6687ebf7443Swdenk
6697ebf7443SwdenkSandpoint8240_config: unconfig
6707ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x sandpoint
6717ebf7443Swdenk
6727ebf7443SwdenkSandpoint8245_config: unconfig
6737ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x sandpoint
6747ebf7443Swdenk
675d1cbe85bSwdenkSL8245_config: unconfig
676d1cbe85bSwdenk	@./mkconfig $(@:_config=) ppc mpc824x sl8245
677d1cbe85bSwdenk
6787ebf7443Swdenkutx8245_config: unconfig
6797ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc824x utx8245
6807ebf7443Swdenk
6817ebf7443Swdenk#########################################################################
6827ebf7443Swdenk## MPC8260 Systems
6837ebf7443Swdenk#########################################################################
6847ebf7443Swdenk
68554387ac9Swdenkatc_config:	unconfig
68654387ac9Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 atc
68754387ac9Swdenk
6887ebf7443Swdenkcogent_mpc8260_config:	unconfig
6897ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 cogent
6907ebf7443Swdenk
6917ebf7443SwdenkCPU86_config	\
6927ebf7443SwdenkCPU86_ROMBOOT_config: unconfig
6937ebf7443Swdenk	@./mkconfig $(call xtract_82xx,$@) ppc mpc8260 cpu86
6947ebf7443Swdenk	@cd ./include ;				\
6957ebf7443Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
6967ebf7443Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
6977ebf7443Swdenk		echo "... booting from 8-bit flash" ; \
6987ebf7443Swdenk	else \
6997ebf7443Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
7007ebf7443Swdenk		echo "... booting from 64-bit flash" ; \
7017ebf7443Swdenk	fi; \
7027ebf7443Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk;
7037ebf7443Swdenk
7047ebf7443Swdenkep8260_config:	unconfig
7057ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 ep8260
7067ebf7443Swdenk
7077ebf7443Swdenkgw8260_config:	unconfig
7087ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 gw8260
7097ebf7443Swdenk
7107ebf7443Swdenkhymod_config:	unconfig
7117ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 hymod
7127ebf7443Swdenk
7137ebf7443SwdenkIPHASE4539_config:	unconfig
7147ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 iphase4539
7157ebf7443Swdenk
7167ebf7443SwdenkMPC8260ADS_config:	unconfig
7177ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 mpc8260ads
7187ebf7443Swdenk
719db2f721fSwdenkMPC8266ADS_config:	unconfig
720db2f721fSwdenk	@./mkconfig $(@:_config=) ppc mpc8260 mpc8266ads
721db2f721fSwdenk
72210f67017SwdenkPM825_config	\
72310f67017SwdenkPM825_ROMBOOT_config: unconfig
72410f67017Swdenk	@echo "#define CONFIG_PCI"	>include/config.h
72510f67017Swdenk	@./mkconfig -a PM826 ppc mpc8260 pm826
72610f67017Swdenk	@cd ./include ;				\
72710f67017Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
72810f67017Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
72910f67017Swdenk		echo "... booting from 8-bit flash" ; \
73010f67017Swdenk	else \
73110f67017Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
73210f67017Swdenk		echo "... booting from 64-bit flash" ; \
73310f67017Swdenk	fi; \
73410f67017Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk; \
73510f67017Swdenk
7367ebf7443SwdenkPM826_config	\
7377ebf7443SwdenkPM826_ROMBOOT_config: unconfig
7387ebf7443Swdenk	@./mkconfig $(call xtract_82xx,$@) ppc mpc8260 pm826
7397ebf7443Swdenk	@cd ./include ;				\
7407ebf7443Swdenk	if [ "$(findstring _ROMBOOT_,$@)" ] ; then \
7417ebf7443Swdenk		echo "CONFIG_BOOT_ROM = y" >> config.mk ; \
7427ebf7443Swdenk		echo "... booting from 8-bit flash" ; \
7437ebf7443Swdenk	else \
7447ebf7443Swdenk		echo "CONFIG_BOOT_ROM = n" >> config.mk ; \
7457ebf7443Swdenk		echo "... booting from 64-bit flash" ; \
7467ebf7443Swdenk	fi; \
7477ebf7443Swdenk	echo "export CONFIG_BOOT_ROM" >> config.mk; \
7487ebf7443Swdenk
7497ebf7443Swdenkppmc8260_config:	unconfig
7507ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 ppmc8260
7517ebf7443Swdenk
7527ebf7443SwdenkRPXsuper_config:	unconfig
7537ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 rpxsuper
7547ebf7443Swdenk
7557ebf7443Swdenkrsdproto_config:	unconfig
7567ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 rsdproto
7577ebf7443Swdenk
7587ebf7443Swdenksacsng_config:	unconfig
7597ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 sacsng
7607ebf7443Swdenk
7617ebf7443Swdenksbc8260_config:	unconfig
7627ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 sbc8260
7637ebf7443Swdenk
7647ebf7443SwdenkSCM_config:		unconfig
7657ebf7443Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 SCM siemens
7667ebf7443Swdenk
76727b207fdSwdenkTQM8255_AA_config \
76827b207fdSwdenkTQM8260_AA_config \
76927b207fdSwdenkTQM8260_AB_config \
77027b207fdSwdenkTQM8260_AC_config \
77127b207fdSwdenkTQM8260_AD_config \
77227b207fdSwdenkTQM8260_AE_config \
77327b207fdSwdenkTQM8260_AF_config \
77427b207fdSwdenkTQM8260_AG_config \
77527b207fdSwdenkTQM8260_AH_config \
77627b207fdSwdenkTQM8265_AA_config:  unconfig
77727b207fdSwdenk	@case "$@" in \
77827b207fdSwdenk	TQM8255_AA_config) CTYPE=MPC8255; CFREQ=300; CACHE=no;  BMODE=8260;;  \
77927b207fdSwdenk	TQM8260_AA_config) CTYPE=MPC8260; CFREQ=200; CACHE=no;  BMODE=8260;; \
78027b207fdSwdenk	TQM8260_AB_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes; BMODE=60x;;  \
78127b207fdSwdenk	TQM8260_AC_config) CTYPE=MPC8260; CFREQ=200; CACHE=yes; BMODE=60x;;  \
78227b207fdSwdenk	TQM8260_AD_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;  BMODE=60x;;  \
78327b207fdSwdenk	TQM8260_AE_config) CTYPE=MPC8260; CFREQ=266; CACHE=no;  BMODE=8260;; \
78427b207fdSwdenk	TQM8260_AF_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;  BMODE=60x;;  \
78527b207fdSwdenk	TQM8260_AG_config) CTYPE=MPC8260; CFREQ=300; CACHE=no;  BMODE=8260;; \
78627b207fdSwdenk	TQM8260_AH_config) CTYPE=MPC8260; CFREQ=300; CACHE=yes; BMODE=60x;;  \
78727b207fdSwdenk	TQM8265_AA_config) CTYPE=MPC8265; CFREQ=300; CACHE=no;  BMODE=60x;;  \
78827b207fdSwdenk	esac; \
78927b207fdSwdenk	>include/config.h ; \
79027b207fdSwdenk	if [ "$${CTYPE}" != "MPC8260" ] ; then \
79127b207fdSwdenk		echo "#define CONFIG_$${CTYPE}"	>>include/config.h ; \
79227b207fdSwdenk	fi; \
79327b207fdSwdenk	echo "#define CONFIG_$${CFREQ}MHz"	>>include/config.h ; \
79427b207fdSwdenk	echo "... with $${CFREQ}MHz system clock" ; \
79527b207fdSwdenk	if [ "$${CACHE}" == "yes" ] ; then \
7967ebf7443Swdenk		echo "#define CONFIG_L2_CACHE"	>>include/config.h ; \
79727b207fdSwdenk		echo "... with L2 Cache support" ; \
7987ebf7443Swdenk	else \
7997ebf7443Swdenk		echo "#undef CONFIG_L2_CACHE"	>>include/config.h ; \
8007ebf7443Swdenk		echo "... without L2 Cache support" ; \
80127b207fdSwdenk	fi; \
80227b207fdSwdenk	if [ "$${BMODE}" == "60x" ] ; then \
80327b207fdSwdenk		echo "#define CONFIG_BUSMODE_60x" >>include/config.h ; \
80427b207fdSwdenk		echo "... with 60x Bus Mode" ; \
80527b207fdSwdenk	else \
80627b207fdSwdenk		echo "#undef CONFIG_BUSMODE_60x"  >>include/config.h ; \
80727b207fdSwdenk		echo "... without 60x Bus Mode" ; \
8087ebf7443Swdenk	fi
8094532cb69Swdenk	@./mkconfig -a TQM8260 ppc mpc8260 tqm8260
8107ebf7443Swdenk
81154387ac9SwdenkZPC1900_config: unconfig
81254387ac9Swdenk	@./mkconfig $(@:_config=) ppc mpc8260 zpc1900
8137aa78614Swdenk
8144e5ca3ebSwdenk#========================================================================
8154e5ca3ebSwdenk# M68K
8164e5ca3ebSwdenk#========================================================================
8174e5ca3ebSwdenk#########################################################################
8184e5ca3ebSwdenk## Coldfire
8194e5ca3ebSwdenk#########################################################################
8204e5ca3ebSwdenk
8214e5ca3ebSwdenkM5272C3_config :		unconfig
8224e5ca3ebSwdenk	@./mkconfig $(@:_config=) m68k coldfire m5272c3
8234e5ca3ebSwdenk
8244e5ca3ebSwdenkM5282EVB_config :		unconfig
8254e5ca3ebSwdenk	@./mkconfig $(@:_config=) m68k coldfire m5282evb
8264e5ca3ebSwdenk
8277ebf7443Swdenk#########################################################################
82842d1f039Swdenk## MPC85xx Systems
82942d1f039Swdenk#########################################################################
83042d1f039Swdenk
83142d1f039SwdenkMPC8540ADS_config:      unconfig
83242d1f039Swdenk	@./mkconfig $(@:_config=) ppc mpc85xx mpc8540ads
83342d1f039Swdenk
83442d1f039SwdenkMPC8560ADS_config:      unconfig
83542d1f039Swdenk	@./mkconfig $(@:_config=) ppc mpc85xx mpc8560ads
83642d1f039Swdenk
83742d1f039Swdenk#########################################################################
8387ebf7443Swdenk## 74xx/7xx Systems
8397ebf7443Swdenk#########################################################################
8407ebf7443Swdenk
841c7de829cSwdenkAmigaOneG3SE_config:	unconfig
842c7de829cSwdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx AmigaOneG3SE MAI
843c7de829cSwdenk
84415647dc7SwdenkBAB7xx_config: unconfig
84515647dc7Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx bab7xx eltec
84615647dc7Swdenk
84715647dc7Swdenkdebris_config: unconfig
84815647dc7Swdenk	@./mkconfig $(@:_config=) ppc mpc824x debris etin
84915647dc7Swdenk
85015647dc7SwdenkELPPC_config: unconfig
85115647dc7Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx elppc eltec
85215647dc7Swdenk
8537ebf7443SwdenkEVB64260_config	\
8547ebf7443SwdenkEVB64260_750CX_config:	unconfig
8557ebf7443Swdenk	@./mkconfig EVB64260 ppc 74xx_7xx evb64260
8567ebf7443Swdenk
85715647dc7SwdenkP3G4_config: unconfig
8587ebf7443Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx evb64260
8597ebf7443Swdenk
8607ebf7443SwdenkPCIPPC2_config \
8617ebf7443SwdenkPCIPPC6_config: unconfig
8627ebf7443Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx pcippc2
8637ebf7443Swdenk
86415647dc7SwdenkZUMA_config:	unconfig
86512f34241Swdenk	@./mkconfig $(@:_config=) ppc 74xx_7xx evb64260
86612f34241Swdenk
8677ebf7443Swdenk#========================================================================
8687ebf7443Swdenk# ARM
8697ebf7443Swdenk#========================================================================
8707ebf7443Swdenk#########################################################################
8717ebf7443Swdenk## StrongARM Systems
8727ebf7443Swdenk#########################################################################
8737ebf7443Swdenk
874dc7c9a1aSwdenkat91rm9200dk_config	:	unconfig
875dc7c9a1aSwdenk	@./mkconfig $(@:_config=) arm at91rm9200 at91rm9200dk
876dc7c9a1aSwdenk
8777ebf7443Swdenklart_config	:	unconfig
8787ebf7443Swdenk	@./mkconfig $(@:_config=) arm sa1100 lart
8797ebf7443Swdenk
8807ebf7443Swdenkdnp1110_config	:	unconfig
8817ebf7443Swdenk	@./mkconfig $(@:_config=) arm sa1100 dnp1110
8827ebf7443Swdenk
8837ebf7443Swdenkshannon_config	:	unconfig
8847ebf7443Swdenk	@./mkconfig $(@:_config=) arm sa1100 shannon
8857ebf7443Swdenk
8867ebf7443Swdenk#########################################################################
8872e5983d2Swdenk## ARM92xT Systems
8887ebf7443Swdenk#########################################################################
8897ebf7443Swdenk
890b0639ca3Swdenkxtract_trab = $(subst _bigram,,$(subst _bigflash,,$(subst _old,,$(subst _config,,$1))))
89143d9616cSwdenk
8922e5983d2Swdenkomap1510inn_config :	unconfig
8932e5983d2Swdenk	@./mkconfig $(@:_config=) arm arm925t omap1510inn
8942e5983d2Swdenk
8956f21347dSwdenkomap1610inn_config :	unconfig
8966f21347dSwdenk	@./mkconfig $(@:_config=) arm arm926ejs omap1610inn
8976f21347dSwdenk
8987ebf7443Swdenksmdk2400_config	:	unconfig
8997ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm920t smdk2400
9007ebf7443Swdenk
9017ebf7443Swdenksmdk2410_config	:	unconfig
9027ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm920t smdk2410
9037ebf7443Swdenk
904*b2001f27Swdenk# TRAB default configuration:	8 MB Flash, 32 MB RAM
90543d9616cSwdenktrab_config \
906b0639ca3Swdenktrab_bigram_config \
907b0639ca3Swdenktrab_bigflash_config \
908f54ebdfaSwdenktrab_old_config:	unconfig
90943d9616cSwdenk	@ >include/config.h
910b0639ca3Swdenk	@[ -z "$(findstring _bigram,$@)" ] || \
911b0639ca3Swdenk		{ echo "#define CONFIG_FLASH_8MB"  >>include/config.h ; \
912*b2001f27Swdenk		  echo "#define CONFIG_RAM_32MB"   >>include/config.h ; \
913b0639ca3Swdenk		  echo "... with 8 MB Flash, 32 MB RAM" ; \
914b0639ca3Swdenk		}
915b0639ca3Swdenk	@[ -z "$(findstring _bigflash,$@)" ] || \
916*b2001f27Swdenk		{ echo "#define CONFIG_FLASH_16MB" >>include/config.h ; \
917*b2001f27Swdenk		  echo "#define CONFIG_RAM_16MB"   >>include/config.h ; \
918b0639ca3Swdenk		  echo "... with 16 MB Flash, 16 MB RAM" ; \
919a8c7c708Swdenk		  echo "TEXT_BASE = 0x0CF40000" >board/trab/config.tmp ; \
920b0639ca3Swdenk		}
921f54ebdfaSwdenk	@[ -z "$(findstring _old,$@)" ] || \
922*b2001f27Swdenk		{ echo "#define CONFIG_FLASH_8MB"  >>include/config.h ; \
923*b2001f27Swdenk		  echo "#define CONFIG_RAM_16MB"   >>include/config.h ; \
924*b2001f27Swdenk		  echo "... with 8 MB Flash, 16 MB RAM" ; \
925a8c7c708Swdenk		  echo "TEXT_BASE = 0x0CF40000" >board/trab/config.tmp ; \
92643d9616cSwdenk		}
92743d9616cSwdenk	@./mkconfig -a $(call xtract_trab,$@) arm arm920t trab
9287ebf7443Swdenk
9291cb8e980SwdenkVCMA9_config	:	unconfig
9301cb8e980Swdenk	@./mkconfig $(@:_config=) arm arm920t vcma9 mpl
9311cb8e980Swdenk
9327ebf7443Swdenk#########################################################################
9337ebf7443Swdenk## ARM720T Systems
9347ebf7443Swdenk#########################################################################
9357ebf7443Swdenk
9367ebf7443Swdenkimpa7_config	:	unconfig
9377ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm720t impa7
9387ebf7443Swdenk
9397ebf7443Swdenkep7312_config	:	unconfig
9407ebf7443Swdenk	@./mkconfig $(@:_config=) arm arm720t ep7312
9417ebf7443Swdenk
9427ebf7443Swdenk#########################################################################
94343d9616cSwdenk## XScale Systems
9447ebf7443Swdenk#########################################################################
9457ebf7443Swdenk
9467ebf7443Swdenkcradle_config	:	unconfig
9474c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa cradle
9487ebf7443Swdenk
9497ebf7443Swdenkcsb226_config	:	unconfig
9504c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa csb226
9517ebf7443Swdenk
95243d9616cSwdenkinnokom_config	:	unconfig
9534c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa innokom
95443d9616cSwdenk
9552d5b561eSwdenkixdp425_config	:	unconfig
9562d5b561eSwdenk	@./mkconfig $(@:_config=) arm ixp ixdp425
9572d5b561eSwdenk
95843d9616cSwdenklubbock_config	:	unconfig
9594c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa lubbock
96043d9616cSwdenk
96152f52c14Swdenklogodl_config	:	unconfig
96252f52c14Swdenk	@./mkconfig $(@:_config=) arm pxa logodl
96352f52c14Swdenk
9643e38691eSwdenkwepep250_config	:	unconfig
9654c3b21a5Swdenk	@./mkconfig $(@:_config=) arm pxa wepep250
9663e38691eSwdenk
9672262cfeeSwdenk#========================================================================
9682262cfeeSwdenk# i386
9692262cfeeSwdenk#========================================================================
9702262cfeeSwdenk#########################################################################
9712262cfeeSwdenk## AMD SC520 CDP
9722262cfeeSwdenk#########################################################################
9732262cfeeSwdenksc520_cdp_config	:	unconfig
9742262cfeeSwdenk	@./mkconfig $(@:_config=) i386 i386 sc520_cdp
9752262cfeeSwdenk
9767a8e9bedSwdenksc520_spunk_config	:	unconfig
9777a8e9bedSwdenk	@./mkconfig $(@:_config=) i386 i386 sc520_spunk
9787a8e9bedSwdenk
9797a8e9bedSwdenksc520_spunk_rel_config	:	unconfig
9807a8e9bedSwdenk	@./mkconfig $(@:_config=) i386 i386 sc520_spunk
9817a8e9bedSwdenk
98243d9616cSwdenk#========================================================================
98343d9616cSwdenk# MIPS
98443d9616cSwdenk#========================================================================
9857ebf7443Swdenk#########################################################################
98643d9616cSwdenk## MIPS32 4Kc
98743d9616cSwdenk#########################################################################
98843d9616cSwdenk
989e0ac62d7Swdenkxtract_incaip = $(subst _100MHz,,$(subst _133MHz,,$(subst _150MHz,,$(subst _config,,$1))))
990e0ac62d7Swdenk
991e0ac62d7Swdenkincaip_100MHz_config	\
992e0ac62d7Swdenkincaip_133MHz_config	\
993e0ac62d7Swdenkincaip_150MHz_config	\
99443d9616cSwdenkincaip_config: unconfig
995e0ac62d7Swdenk	@ >include/config.h
996e0ac62d7Swdenk	@[ -z "$(findstring _100MHz,$@)" ] || \
997e0ac62d7Swdenk		{ echo "#define CPU_CLOCK_RATE 100000000" >>include/config.h ; \
998e0ac62d7Swdenk		  echo "... with 100MHz system clock" ; \
999e0ac62d7Swdenk		}
1000e0ac62d7Swdenk	@[ -z "$(findstring _133MHz,$@)" ] || \
1001e0ac62d7Swdenk		{ echo "#define CPU_CLOCK_RATE 133000000" >>include/config.h ; \
1002e0ac62d7Swdenk		  echo "... with 133MHz system clock" ; \
1003e0ac62d7Swdenk		}
1004e0ac62d7Swdenk	@[ -z "$(findstring _150MHz,$@)" ] || \
1005e0ac62d7Swdenk		{ echo "#define CPU_CLOCK_RATE 150000000" >>include/config.h ; \
1006e0ac62d7Swdenk		  echo "... with 150MHz system clock" ; \
1007e0ac62d7Swdenk		}
1008e0ac62d7Swdenk	@./mkconfig -a $(call xtract_incaip,$@) mips mips incaip
1009e0ac62d7Swdenk
1010e0ac62d7Swdenk#########################################################################
1011e0ac62d7Swdenk## MIPS64 5Kc
1012e0ac62d7Swdenk#########################################################################
101343d9616cSwdenk
10143e38691eSwdenkpurple_config :		unconfig
10153e38691eSwdenk	@./mkconfig $(@:_config=) mips mips purple
101643d9616cSwdenk
10174a551709Swdenk#========================================================================
10184a551709Swdenk# Nios
10194a551709Swdenk#========================================================================
10204a551709Swdenk#########################################################################
10214a551709Swdenk## Nios32
10224a551709Swdenk#########################################################################
10234a551709Swdenk
10244a551709SwdenkDK1C20_config:	unconfig
10254a551709Swdenk	@./mkconfig $(@:_config=) nios nios dk1c20
10264a551709Swdenk
10274a551709Swdenk
10283e38691eSwdenk#########################################################################
1029a2663ea4Swdenk## MIPS32 AU1X00
10305da627a4Swdenk#########################################################################
1031a2663ea4Swdenkdbau1000_config		: 	unconfig
1032a2663ea4Swdenk	@ >include/config.h
1033a2663ea4Swdenk	@echo "#define CONFIG_DBAU1000 1" >>include/config.h
1034a2663ea4Swdenk	@./mkconfig -a dbau1x00 mips mips dbau1x00
1035a2663ea4Swdenk
1036a2663ea4Swdenkdbau1100_config		: 	unconfig
1037a2663ea4Swdenk	@ >include/config.h
1038a2663ea4Swdenk	@echo "#define CONFIG_DBAU1100 1" >>include/config.h
1039a2663ea4Swdenk	@./mkconfig -a dbau1x00 mips mips dbau1x00
1040a2663ea4Swdenk
1041a2663ea4Swdenkdbau1500_config		: 	unconfig
1042a2663ea4Swdenk	@ >include/config.h
1043a2663ea4Swdenk	@echo "#define CONFIG_DBAU1500 1" >>include/config.h
1044a2663ea4Swdenk	@./mkconfig -a dbau1x00 mips mips dbau1x00
10455da627a4Swdenk
10465da627a4Swdenk#########################################################################
10473e38691eSwdenk#########################################################################
10487ebf7443Swdenk
10497ebf7443Swdenkclean:
10507ebf7443Swdenk	find . -type f \
10517ebf7443Swdenk		\( -name 'core' -o -name '*.bak' -o -name '*~' \
10527ebf7443Swdenk		-o -name '*.o'  -o -name '*.a'  \) -print \
10537ebf7443Swdenk		| xargs rm -f
105485ec0bccSwdenk	rm -f examples/hello_world examples/timer \
10553e38691eSwdenk	      examples/eepro100_eeprom examples/sched \
10567a8e9bedSwdenk	      examples/mem_to_mem_idma2intr examples/82559_eeprom
10577a8e9bedSwdenk
10587ebf7443Swdenk	rm -f tools/img2srec tools/mkimage tools/envcrc tools/gen_eth_addr
10597ebf7443Swdenk	rm -f tools/easylogo/easylogo tools/bmp_logo
10607ebf7443Swdenk	rm -f tools/gdb/astest tools/gdb/gdbcont tools/gdb/gdbsend
1061228f29acSwdenk	rm -f tools/env/fw_printenv tools/env/fw_setenv
10627f70e853Swdenk	rm -f board/cray/L1/bootscript.c board/cray/L1/bootscript.image
10635cf9da48Swdenk	rm -f board/trab/trab_fkt board/*/config.tmp
10647ebf7443Swdenk
10657ebf7443Swdenkclobber:	clean
10667ebf7443Swdenk	find . -type f \
10677ebf7443Swdenk		\( -name .depend -o -name '*.srec' -o -name '*.bin' \) \
10687ebf7443Swdenk		-print \
10697ebf7443Swdenk		| xargs rm -f
10707ebf7443Swdenk	rm -f $(OBJS) *.bak tags TAGS
10717ebf7443Swdenk	rm -fr *.*~
1072bdccc4feSwdenk	rm -f u-boot u-boot.map $(ALL)
1073228f29acSwdenk	rm -f tools/crc32.c tools/environment.c tools/env/crc32.c
10743e38691eSwdenk	rm -f tools/inca-swap-bytes cpu/mpc824x/bedbug_603e.c
1075b783edaeSwdenk	rm -f include/asm/proc include/asm/arch include/asm
10767ebf7443Swdenk
10777ebf7443Swdenkmrproper \
10787ebf7443Swdenkdistclean:	clobber unconfig
10797ebf7443Swdenk
10807ebf7443Swdenkbackup:
10817ebf7443Swdenk	F=`basename $(TOPDIR)` ; cd .. ; \
10827ebf7443Swdenk	gtar --force-local -zcvf `date "+$$F-%Y-%m-%d-%T.tar.gz"` $$F
10837ebf7443Swdenk
10847ebf7443Swdenk#########################################################################
1085