diff options
237 files changed, 3083 insertions, 1948 deletions
| @@ -65,11 +65,9 @@ endif  # the object files are placed in the source directory.  # -ifdef O  ifeq ("$(origin O)", "command line")  BUILD_DIR := $(O)  endif -endif  # Call a source code checker (by default, "sparse") as part of the  # C compilation. @@ -231,87 +229,71 @@ OBJS := $(addprefix $(obj),$(OBJS))  HAVE_VENDOR_COMMON_LIB = $(if $(wildcard board/$(VENDOR)/common/Makefile),y,n) -LIBS-y += lib/libgeneric.o -LIBS-y += lib/rsa/librsa.o -LIBS-y += lib/lzma/liblzma.o -LIBS-y += lib/lzo/liblzo.o -LIBS-y += lib/zlib/libz.o -LIBS-$(CONFIG_TIZEN) += lib/tizen/libtizen.o -LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/lib$(VENDOR).o -LIBS-y += $(CPUDIR)/lib$(CPU).o +LIBS-y += lib/ +LIBS-$(CONFIG_RSA) += lib/rsa/ +LIBS-$(CONFIG_LZMA) += lib/lzma/ +LIBS-$(CONFIG_LZO) += lib/lzo/ +LIBS-$(CONFIG_ZLIB) += lib/zlib/ +LIBS-$(CONFIG_TIZEN) += lib/tizen/ +LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/ +LIBS-y += $(CPUDIR)/  ifdef SOC -LIBS-y += $(CPUDIR)/$(SOC)/lib$(SOC).o -endif -ifeq ($(CPU),ixp) -LIBS-y += drivers/net/npe/libnpe.o +LIBS-y += $(CPUDIR)/$(SOC)/  endif -LIBS-$(CONFIG_OF_EMBED) += dts/libdts.o -LIBS-y += arch/$(ARCH)/lib/lib$(ARCH).o -LIBS-y += fs/libfs.o \ -	fs/fat/libfat.o -LIBS-y += net/libnet.o -LIBS-y += disk/libdisk.o -LIBS-y += drivers/libdrivers.o -LIBS-y += drivers/dma/libdma.o -LIBS-y += drivers/gpio/libgpio.o -LIBS-y += drivers/i2c/libi2c.o -LIBS-y += drivers/input/libinput.o -LIBS-y += drivers/mmc/libmmc.o -LIBS-y += drivers/mtd/libmtd.o -LIBS-y += drivers/mtd/nand/libnand.o -LIBS-y += drivers/mtd/onenand/libonenand.o -LIBS-y += drivers/mtd/ubi/libubi.o -LIBS-y += drivers/mtd/spi/libspi_flash.o -LIBS-y += drivers/net/libnet.o -LIBS-y += drivers/net/phy/libphy.o -LIBS-y += drivers/pci/libpci.o -LIBS-y += drivers/power/libpower.o \ -	drivers/power/fuel_gauge/libfuel_gauge.o \ -	drivers/power/mfd/libmfd.o \ -	drivers/power/pmic/libpmic.o \ -	drivers/power/battery/libbattery.o -LIBS-y += drivers/spi/libspi.o -ifeq ($(CPU),mpc83xx) -LIBS-y += drivers/qe/libqe.o -LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o -LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o -endif -ifeq ($(CPU),mpc85xx) -LIBS-y += drivers/qe/libqe.o -LIBS-y += drivers/net/fm/libfm.o -LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o -LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o -endif -ifeq ($(CPU),mpc86xx) -LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o -LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o -endif -LIBS-y += drivers/serial/libserial.o -LIBS-y += drivers/usb/eth/libusb_eth.o -LIBS-y += drivers/usb/gadget/libusb_gadget.o -LIBS-y += drivers/usb/host/libusb_host.o -LIBS-y += drivers/usb/musb/libusb_musb.o -LIBS-y += drivers/usb/musb-new/libusb_musb-new.o -LIBS-y += drivers/usb/phy/libusb_phy.o -LIBS-y += drivers/usb/ulpi/libusb_ulpi.o -LIBS-y += common/libcommon.o -LIBS-y += lib/libfdt/libfdt.o -LIBS-y += api/libapi.o -LIBS-y += post/libpost.o -LIBS-y += test/libtest.o +LIBS-$(CONFIG_IXP4XX_NPE) += drivers/net/npe/ +LIBS-$(CONFIG_OF_EMBED) += dts/ +LIBS-y += arch/$(ARCH)/lib/ +LIBS-y += fs/ +LIBS-y += net/ +LIBS-y += disk/ +LIBS-y += drivers/ +LIBS-y += drivers/dma/ +LIBS-y += drivers/gpio/ +LIBS-y += drivers/i2c/ +LIBS-y += drivers/input/ +LIBS-y += drivers/mmc/ +LIBS-y += drivers/mtd/ +LIBS-y += drivers/mtd/nand/ +LIBS-y += drivers/mtd/onenand/ +LIBS-y += drivers/mtd/ubi/ +LIBS-y += drivers/mtd/spi/ +LIBS-y += drivers/net/ +LIBS-y += drivers/net/phy/ +LIBS-y += drivers/pci/ +LIBS-y += drivers/power/ \ +	drivers/power/fuel_gauge/ \ +	drivers/power/mfd/ \ +	drivers/power/pmic/ \ +	drivers/power/battery/ +LIBS-y += drivers/spi/ +LIBS-$(CONFIG_FMAN_ENET) += drivers/net/fm/ +LIBS-y += drivers/serial/ +LIBS-y += drivers/usb/eth/ +LIBS-y += drivers/usb/gadget/ +LIBS-y += drivers/usb/host/ +LIBS-y += drivers/usb/musb/ +LIBS-y += drivers/usb/musb-new/ +LIBS-y += drivers/usb/phy/ +LIBS-y += drivers/usb/ulpi/ +LIBS-y += common/ +LIBS-y += lib/libfdt/ +LIBS-y += api/ +LIBS-y += post/ +LIBS-y += test/  ifneq (,$(filter $(SOC), mx25 mx27 mx5 mx6 mx31 mx35 mxs vf610)) -LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o +LIBS-y += arch/$(ARCH)/imx-common/  endif -LIBS-$(CONFIG_ARM) += arch/arm/cpu/libcpu.o +LIBS-$(CONFIG_ARM) += arch/arm/cpu/ +LIBS-$(CONFIG_PPC) += arch/powerpc/cpu/ + +LIBS-y += board/$(BOARDDIR)/ +LIBS-y := $(patsubst %/, %/built-in.o, $(LIBS-y))  LIBS := $(addprefix $(obj),$(sort $(LIBS-y)))  .PHONY : $(LIBS) -LIBBOARD = board/$(BOARDDIR)/lib$(BOARD).o -LIBBOARD := $(addprefix $(obj),$(LIBBOARD)) -  # Add GCC lib  ifdef USE_PRIVATE_LIBGCC  ifeq ("$(USE_PRIVATE_LIBGCC)", "yes") @@ -335,7 +317,7 @@ LDPPFLAGS += \  	  sed -ne 's/GNU ld version \([0-9][0-9]*\)\.\([0-9][0-9]*\).*/-DLD_MAJOR=\1 -DLD_MINOR=\2/p')  __OBJS := $(subst $(obj),,$(OBJS)) -__LIBS := $(subst $(obj),,$(LIBS)) $(subst $(obj),,$(LIBBOARD)) +__LIBS := $(subst $(obj),,$(LIBS))  #########################################################################  ######################################################################### @@ -549,7 +531,7 @@ GEN_UBOOT = \  endif  $(obj)u-boot:	depend \ -		$(SUBDIR_TOOLS) $(OBJS) $(LIBBOARD) $(LIBS) $(LDSCRIPT) $(obj)u-boot.lds +		$(SUBDIR_TOOLS) $(OBJS) $(LIBS) $(LDSCRIPT) $(obj)u-boot.lds  		$(GEN_UBOOT)  ifeq ($(CONFIG_KALLSYMS),y)  		smap=`$(call SYSTEM_MAP,$(obj)u-boot) | \ @@ -564,11 +546,6 @@ $(OBJS):  $(LIBS):	depend $(SUBDIR_TOOLS)  		$(MAKE) $(build) $(dir $(subst $(obj),,$@)) -		mv $(dir $@)built-in.o $@ - -$(LIBBOARD):	depend $(LIBS) -		$(MAKE) $(build) $(dir $(subst $(obj),,$@)) -		mv $(dir $@)built-in.o $@  $(SUBDIRS):	depend  		$(MAKE) -C $@ all @@ -634,7 +611,7 @@ SYSTEM_MAP = \  		grep -v '\(compiled\)\|\(\.o$$\)\|\( [aUw] \)\|\(\.\.ng$$\)\|\(LASH[RL]DI\)' | \  		LC_ALL=C sort  $(obj)System.map:	$(obj)u-boot -		@$(call SYSTEM_MAP,$<) > $(obj)System.map +		@$(call SYSTEM_MAP,$<) > $@  checkthumb:  	@if test $(call cc-version) -lt 0404; then \ @@ -806,12 +783,6 @@ sinclude $(obj).boards.depend  $(obj).boards.depend:	boards.cfg  	@awk '(NF && $$1 !~ /^#/) { print $$7 ": " $$7 "_config; $$(MAKE)" }' $< > $@ -# -# Functions to generate common board directory names -# -lcname	= $(shell echo $(1) | sed -e 's/\(.*\)_config/\L\1/') -ucname	= $(shell echo $(1) | sed -e 's/\(.*\)_config/\U\1/') -  #########################################################################  ######################################################################### @@ -888,8 +859,6 @@ clobber:	tidy  	@rm -f $(obj)MLO MLO.byteswap  	@rm -f $(obj)SPL  	@rm -f $(obj)tools/xway-swap-bytes -	@rm -f $(obj)arch/powerpc/cpu/mpc824x/bedbug_603e.c -	@rm -f $(obj)arch/powerpc/cpu/mpc83xx/ddr-gen?.c  	@rm -fr $(obj)include/asm/proc $(obj)include/asm/arch $(obj)include/asm  	@rm -fr $(obj)include/generated  	@[ ! -d $(obj)nand_spl ] || find $(obj)nand_spl -name "*" -type l -print | xargs rm -f @@ -2040,6 +2040,42 @@ CBFS (Coreboot Filesystem) support  		  - CONFIG_SYS_RCAR_I2C3_SPEED for for the speed channel 3  		  - CONFIF_SYS_RCAR_I2C_NUM_CONTROLLERS for number of i2c buses +		- drivers/i2c/sh_i2c.c: +		  - activate this driver with CONFIG_SYS_I2C_SH +		  - This driver adds from 2 to 5 i2c buses + +		  - CONFIG_SYS_I2C_SH_BASE0 for setting the register channel 0 +		  - CONFIG_SYS_I2C_SH_SPEED0 for for the speed channel 0 +		  - CONFIG_SYS_I2C_SH_BASE1 for setting the register channel 1 +		  - CONFIG_SYS_I2C_SH_SPEED1 for for the speed channel 1 +		  - CONFIG_SYS_I2C_SH_BASE2 for setting the register channel 2 +		  - CONFIG_SYS_I2C_SH_SPEED2 for for the speed channel 2 +		  - CONFIG_SYS_I2C_SH_BASE3 for setting the register channel 3 +		  - CONFIG_SYS_I2C_SH_SPEED3 for for the speed channel 3 +		  - CONFIG_SYS_I2C_SH_BASE4 for setting the register channel 4 +		  - CONFIG_SYS_I2C_SH_SPEED4 for for the speed channel 4 +		  - CONFIG_SYS_I2C_SH_BASE5 for setting the register channel 5 +		  - CONFIG_SYS_I2C_SH_SPEED5 for for the speed channel 5 +		  - CONFIF_SYS_I2C_SH_NUM_CONTROLLERS for nummber of i2c buses + +		- drivers/i2c/omap24xx_i2c.c +		  - activate this driver with CONFIG_SYS_I2C_OMAP24XX +		  - CONFIG_SYS_OMAP24_I2C_SPEED speed channel 0 +		  - CONFIG_SYS_OMAP24_I2C_SLAVE slave addr channel 0 +		  - CONFIG_SYS_OMAP24_I2C_SPEED1 speed channel 1 +		  - CONFIG_SYS_OMAP24_I2C_SLAVE1 slave addr channel 1 +		  - CONFIG_SYS_OMAP24_I2C_SPEED2 speed channel 2 +		  - CONFIG_SYS_OMAP24_I2C_SLAVE2 slave addr channel 2 +		  - CONFIG_SYS_OMAP24_I2C_SPEED3 speed channel 3 +		  - CONFIG_SYS_OMAP24_I2C_SLAVE3 slave addr channel 3 +		  - CONFIG_SYS_OMAP24_I2C_SPEED4 speed channel 4 +		  - CONFIG_SYS_OMAP24_I2C_SLAVE4 slave addr channel 4 + +		- drivers/i2c/zynq_i2c.c +		  - activate this driver with CONFIG_SYS_I2C_ZYNQ +		  - set CONFIG_SYS_I2C_ZYNQ_SPEED for speed setting +		  - set CONFIG_SYS_I2C_ZYNQ_SLAVE for slave addr +  		additional defines:  		CONFIG_SYS_NUM_I2C_BUSES diff --git a/arch/arm/cpu/armv7/omap-common/clocks-common.c b/arch/arm/cpu/armv7/omap-common/clocks-common.c index bb77b5ca3..dfa3760df 100644 --- a/arch/arm/cpu/armv7/omap-common/clocks-common.c +++ b/arch/arm/cpu/armv7/omap-common/clocks-common.c @@ -779,7 +779,8 @@ void gpi2c_init(void)  	static int gpi2c = 1;  	if (gpi2c) { -		i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +		i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, +			 CONFIG_SYS_OMAP24_I2C_SLAVE);  		gpi2c = 0;  	}  } diff --git a/arch/arm/cpu/armv7/omap-common/u-boot-spl.lds b/arch/arm/cpu/armv7/omap-common/u-boot-spl.lds index 5e93b343e..02aa12973 100644 --- a/arch/arm/cpu/armv7/omap-common/u-boot-spl.lds +++ b/arch/arm/cpu/armv7/omap-common/u-boot-spl.lds @@ -33,6 +33,11 @@ SECTIONS  	.data : { *(SORT_BY_ALIGNMENT(.data*)) } >.sram  	. = ALIGN(4); +	.u_boot_list : { +		KEEP(*(SORT(.u_boot_list*_i2c_*))); +	} >.sram + +	. = ALIGN(4);  	__image_copy_end = .;  	_end = .; diff --git a/arch/arm/cpu/armv7/omap3/board.c b/arch/arm/cpu/armv7/omap3/board.c index 7d1f8d9d2..29228160c 100644 --- a/arch/arm/cpu/armv7/omap3/board.c +++ b/arch/arm/cpu/armv7/omap3/board.c @@ -98,7 +98,7 @@ void spl_board_init(void)  	gpmc_init();  #endif  #ifdef CONFIG_SPL_I2C_SUPPORT -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  #endif  }  #endif /* CONFIG_SPL_BUILD */ diff --git a/arch/arm/cpu/armv7/omap3/clock.c b/arch/arm/cpu/armv7/omap3/clock.c index 9f989ff86..14fc7e8e8 100644 --- a/arch/arm/cpu/armv7/omap3/clock.c +++ b/arch/arm/cpu/armv7/omap3/clock.c @@ -708,7 +708,7 @@ void per_clocks_enable(void)  	sr32(&prcm_base->iclken_per, 17, 1, 1);  #endif -#ifdef CONFIG_DRIVER_OMAP34XX_I2C +#ifdef CONFIG_SYS_I2C_OMAP34XX  	/* Turn on all 3 I2C clocks */  	sr32(&prcm_base->fclken1_core, 15, 3, 0x7);  	sr32(&prcm_base->iclken1_core, 15, 3, 0x7);	/* I2C1,2,3 = on */ diff --git a/arch/arm/cpu/armv7/rmobile/Makefile b/arch/arm/cpu/armv7/rmobile/Makefile index 8f4cf3a19..5e296c420 100644 --- a/arch/arm/cpu/armv7/rmobile/Makefile +++ b/arch/arm/cpu/armv7/rmobile/Makefile @@ -15,10 +15,4 @@ obj-$(CONFIG_R8A7740) += cpu_info-r8a7740.o  obj-$(CONFIG_R8A7740) += pfc-r8a7740.o  obj-$(CONFIG_SH73A0) += cpu_info-sh73a0.o  obj-$(CONFIG_SH73A0) += pfc-sh73a0.o -obj-$(CONFIG_TMU_TIMER) += sh_timer.o - -SRCS += $(obj)sh_timer.c -# from arch/sh/lib/ directory -$(obj)sh_timer.c: -	@rm -f $(obj)sh_timer.c -	ln -s $(SRCTREE)/arch/sh/lib/time.c $(obj)sh_timer.c +obj-$(CONFIG_TMU_TIMER) += ../../../../sh/lib/time.o diff --git a/arch/arm/include/asm/arch-am33xx/i2c.h b/arch/arm/include/asm/arch-am33xx/i2c.h index 8bfa53f41..8642c8f87 100644 --- a/arch/arm/include/asm/arch-am33xx/i2c.h +++ b/arch/arm/include/asm/arch-am33xx/i2c.h @@ -4,8 +4,8 @@   *   * SPDX-License-Identifier:	GPL-2.0+   */ -#ifndef _I2C_H_ -#define _I2C_H_ +#ifndef _I2C_AM33XX_H_ +#define _I2C_AM33XX_H_  #define  I2C_BASE1		0x44E0B000  #define  I2C_BASE2		0x4802A000 @@ -62,4 +62,4 @@ struct i2c {  #define I2C_IP_CLK			48000000  #define I2C_INTERNAL_SAMPLING_CLK	12000000 -#endif /* _I2C_H_ */ +#endif /* _I2C_AM33XX_H_ */ diff --git a/arch/microblaze/cpu/u-boot.lds b/arch/microblaze/cpu/u-boot.lds index 3e6204de3..fdad20753 100644 --- a/arch/microblaze/cpu/u-boot.lds +++ b/arch/microblaze/cpu/u-boot.lds @@ -30,7 +30,7 @@ SECTIONS  	{  		__data_start = .;  #ifdef CONFIG_OF_EMBED -		dts/libdts.o (.data) +		dts/built-in.o (.data)  #endif  		*(.data)  		__data_end = .; diff --git a/arch/powerpc/cpu/Makefile b/arch/powerpc/cpu/Makefile new file mode 100644 index 000000000..d630abe1d --- /dev/null +++ b/arch/powerpc/cpu/Makefile @@ -0,0 +1,3 @@ +ifneq ($(filter mpc83xx mpc85xx mpc86xx,$(CPU)),) +obj-y += mpc8xxx/ +endif diff --git a/arch/powerpc/cpu/mpc512x/Makefile b/arch/powerpc/cpu/mpc512x/Makefile index f770350dc..a4934ef78 100644 --- a/arch/powerpc/cpu/mpc512x/Makefile +++ b/arch/powerpc/cpu/mpc512x/Makefile @@ -4,8 +4,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(OBJTREE)/board/freescale/common) -  extra-y	= start.o  obj-y	:= cpu.o  obj-y	+= traps.o diff --git a/arch/powerpc/cpu/mpc824x/.gitignore b/arch/powerpc/cpu/mpc824x/.gitignore deleted file mode 100644 index 2d79931e9..000000000 --- a/arch/powerpc/cpu/mpc824x/.gitignore +++ /dev/null @@ -1 +0,0 @@ -/bedbug_603e.c diff --git a/arch/powerpc/cpu/mpc824x/Makefile b/arch/powerpc/cpu/mpc824x/Makefile index 67b0d1713..2c8be9257 100644 --- a/arch/powerpc/cpu/mpc824x/Makefile +++ b/arch/powerpc/cpu/mpc824x/Makefile @@ -5,15 +5,7 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)drivers/epic $(obj)drivers/i2c) -endif -  extra-y	= start.o  obj-y	= traps.o cpu.o cpu_init.o interrupts.o speed.o \  	  drivers/epic/epic1.o drivers/i2c/i2c.o pci.o -obj-y += bedbug_603e.o - -SRCS += $(obj)bedbug_603e.c -$(obj)bedbug_603e.c: -	ln -sf $(src)../mpc8260/bedbug_603e.c $(obj)bedbug_603e.c +obj-y += ../mpc8260/bedbug_603e.o diff --git a/arch/powerpc/cpu/mpc83xx/Makefile b/arch/powerpc/cpu/mpc83xx/Makefile index b7142f0df..d3f700147 100644 --- a/arch/powerpc/cpu/mpc83xx/Makefile +++ b/arch/powerpc/cpu/mpc83xx/Makefile @@ -39,20 +39,10 @@ obj-$(CONFIG_OF_LIBFDT) += fdt.o  obj-y += cache.o  ifdef CONFIG_FSL_DDR2 -obj-$(CONFIG_MPC8349) += ddr-gen2.o -SRCS += $(obj)ddr-gen2.c +obj-$(CONFIG_MPC8349) += ../mpc85xx/ddr-gen2.o  else  obj-y += spd_sdram.o  endif  obj-$(CONFIG_FSL_DDR2) += law.o  endif # not minimal - -$(obj)ddr-gen1.c: -	ln -sf $(SRCTREE)/arch/powerpc/cpu/mpc85xx/ddr-gen1.c $(obj)ddr-gen1.c - -$(obj)ddr-gen2.c: -	ln -sf $(SRCTREE)/arch/powerpc/cpu/mpc85xx/ddr-gen2.c $(obj)ddr-gen2.c - -$(obj)ddr-gen3.c: -	ln -sf $(SRCTREE)/arch/powerpc/cpu/mpc85xx/ddr-gen3.c $(obj)ddr-gen3.c diff --git a/arch/powerpc/cpu/mpc85xx/Makefile b/arch/powerpc/cpu/mpc85xx/Makefile index 50ddb5040..a34014f30 100644 --- a/arch/powerpc/cpu/mpc85xx/Makefile +++ b/arch/powerpc/cpu/mpc85xx/Makefile @@ -70,6 +70,9 @@ obj-$(CONFIG_PPC_B4860)	+= ddr-gen3.o  obj-$(CONFIG_BSC9131)		+= ddr-gen3.o  obj-$(CONFIG_BSC9132)		+= ddr-gen3.o  obj-$(CONFIG_PPC_T1040)	+= ddr-gen3.o +obj-$(CONFIG_PPC_T1042)	+= ddr-gen3.o +obj-$(CONFIG_PPC_T1020)	+= ddr-gen3.o +obj-$(CONFIG_PPC_T1022)	+= ddr-gen3.o  obj-$(CONFIG_CPM2)	+= ether_fcc.o  obj-$(CONFIG_OF_LIBFDT) += fdt.o @@ -89,6 +92,10 @@ obj-$(CONFIG_PPC_T4160) += t4240_ids.o  obj-$(CONFIG_PPC_B4420) += b4860_ids.o  obj-$(CONFIG_PPC_B4860) += b4860_ids.o  obj-$(CONFIG_PPC_T1040) += t1040_ids.o +obj-$(CONFIG_PPC_T1042)	+= t1040_ids.o +obj-$(CONFIG_PPC_T1020)	+= t1040_ids.o +obj-$(CONFIG_PPC_T1022)	+= t1040_ids.o +  obj-$(CONFIG_QE)	+= qe_io.o  obj-$(CONFIG_CPM2)	+= serial_scc.o @@ -128,6 +135,9 @@ obj-$(CONFIG_PPC_B4420) += b4860_serdes.o  obj-$(CONFIG_PPC_B4860) += b4860_serdes.o  obj-$(CONFIG_BSC9132) += bsc9132_serdes.o  obj-$(CONFIG_PPC_T1040) += t1040_serdes.o +obj-$(CONFIG_PPC_T1042)	+= t1040_serdes.o +obj-$(CONFIG_PPC_T1020)	+= t1040_serdes.o +obj-$(CONFIG_PPC_T1022)	+= t1040_serdes.o  obj-y	+= cpu.o  obj-y	+= cpu_init.o diff --git a/arch/powerpc/cpu/mpc85xx/fdt.c b/arch/powerpc/cpu/mpc85xx/fdt.c index 2ccd9c7b9..33bc90016 100644 --- a/arch/powerpc/cpu/mpc85xx/fdt.c +++ b/arch/powerpc/cpu/mpc85xx/fdt.c @@ -586,6 +586,7 @@ void ft_cpu_setup(void *blob, bd_t *bd)  {  	int off;  	int val; +	int len;  	sys_info_t sysinfo;  	/* delete crypto node if not on an E-processor */ @@ -615,8 +616,8 @@ void ft_cpu_setup(void *blob, bd_t *bd)  	get_sys_info(&sysinfo);  	off = fdt_node_offset_by_prop_value(blob, -1, "device_type", "cpu", 4);  	while (off != -FDT_ERR_NOTFOUND) { -		u32 *reg = (u32 *)fdt_getprop(blob, off, "reg", 0); -		val = cpu_to_fdt32(sysinfo.freq_processor[*reg]); +		u32 *reg = (u32 *)fdt_getprop(blob, off, "reg", &len); +		val = cpu_to_fdt32(sysinfo.freq_processor[(*reg) / (len / 4)]);  		fdt_setprop(blob, off, "clock-frequency", &val, 4);  		off = fdt_node_offset_by_prop_value(blob, off, "device_type",  							"cpu", 4); diff --git a/arch/powerpc/cpu/mpc85xx/liodn.c b/arch/powerpc/cpu/mpc85xx/liodn.c index 4b00da9f7..19e130e87 100644 --- a/arch/powerpc/cpu/mpc85xx/liodn.c +++ b/arch/powerpc/cpu/mpc85xx/liodn.c @@ -239,9 +239,9 @@ static void fdt_fixup_srio_liodn(void *blob, struct srio_liodn_id_table *tbl)  #endif  #define CONFIG_SYS_MAX_PCI_EPS		8 -#define CONFIG_SYS_PCI_EP_LIODN_START	256 -static void fdt_fixup_pci_liodn_offsets(void *fdt, const char *compat) +static void fdt_fixup_pci_liodn_offsets(void *fdt, const char *compat, +					int ep_liodn_start)  {  	int off, pci_idx = 0, pci_cnt = 0, i, rc;  	const uint32_t *base_liodn; @@ -271,7 +271,7 @@ static void fdt_fixup_pci_liodn_offsets(void *fdt, const char *compat)  			continue;  		}  		for (i = 0; i < CONFIG_SYS_MAX_PCI_EPS; i++) -			liodn_offs[i + 1] = CONFIG_SYS_PCI_EP_LIODN_START + +			liodn_offs[i + 1] = ep_liodn_start +  					i * pci_cnt + pci_idx - *base_liodn;  		rc = fdt_setprop(fdt, off, "fsl,liodn-offset-list",  				 liodn_offs, sizeof(liodn_offs)); @@ -338,5 +338,22 @@ void fdt_fixup_liodn(void *blob)  	fdt_fixup_liodn_tbl(blob, rman_liodn_tbl, rman_liodn_tbl_sz);  #endif -	fdt_fixup_pci_liodn_offsets(blob, "fsl,qoriq-pcie-v2.4"); +	ccsr_pcix_t *pcix = (ccsr_pcix_t *)CONFIG_SYS_PCIE1_ADDR; +	int pci_ver = pcix->ipver1 & 0xffff, liodn_base = 0; + +	if (pci_ver >= 0x0204) { +		if (pci_ver >= 0x0300) +			liodn_base = 1024; +		else +			liodn_base = 256; +	} + +	if (liodn_base) { +		char compat[32]; + +		sprintf(compat, "fsl,qoriq-pcie-v%d.%d", +			(pci_ver & 0xff00) >> 8, pci_ver & 0xff); +		fdt_fixup_pci_liodn_offsets(blob, compat, liodn_base); +		fdt_fixup_pci_liodn_offsets(blob, "fsl,qoriq-pcie", liodn_base); +	}  } diff --git a/arch/powerpc/cpu/mpc85xx/t4240_ids.c b/arch/powerpc/cpu/mpc85xx/t4240_ids.c index 54c1cfd2c..f18131513 100644 --- a/arch/powerpc/cpu/mpc85xx/t4240_ids.c +++ b/arch/powerpc/cpu/mpc85xx/t4240_ids.c @@ -86,10 +86,10 @@ struct liodn_id_table liodn_tbl[] = {  	SET_SATA_LIODN(1, 555),  	SET_SATA_LIODN(2, 556), -	SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 1, 148), -	SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 2, 228), -	SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 3, 308), -	SET_PCI_LIODN(CONFIG_SYS_FSL_PCIE_COMPAT, 4, 388), +	SET_PCI_LIODN_BASE(CONFIG_SYS_FSL_PCIE_COMPAT, 1, 148), +	SET_PCI_LIODN_BASE(CONFIG_SYS_FSL_PCIE_COMPAT, 2, 228), +	SET_PCI_LIODN_BASE(CONFIG_SYS_FSL_PCIE_COMPAT, 3, 308), +	SET_PCI_LIODN_BASE(CONFIG_SYS_FSL_PCIE_COMPAT, 4, 388),  	SET_DMA_LIODN(1, 147),  	SET_DMA_LIODN(2, 227), diff --git a/arch/powerpc/cpu/mpc8xxx/Makefile b/arch/powerpc/cpu/mpc8xxx/Makefile index 395fed16b..1d083bf35 100644 --- a/arch/powerpc/cpu/mpc8xxx/Makefile +++ b/arch/powerpc/cpu/mpc8xxx/Makefile @@ -31,3 +31,9 @@ obj-$(CONFIG_SYS_SRIO) += srio.o  obj-$(CONFIG_FSL_LAW) += law.o  endif + +ifdef CONFIG_SPL_BUILD +obj-$(CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT) += ddr/ +else +obj-y += ddr/ +endif diff --git a/arch/powerpc/include/asm/config_mpc85xx.h b/arch/powerpc/include/asm/config_mpc85xx.h index 4cc12ee70..d4cd27dd0 100644 --- a/arch/powerpc/include/asm/config_mpc85xx.h +++ b/arch/powerpc/include/asm/config_mpc85xx.h @@ -674,7 +674,8 @@  #define CONFIG_NUM_DDR_CONTROLLERS	1  #endif -#elif defined(CONFIG_PPC_T1040) +#elif defined(CONFIG_PPC_T1040) || defined(CONFIG_PPC_T1042) ||\ +defined(CONFIG_PPC_T1020) || defined(CONFIG_PPC_T1022)  #define CONFIG_E5500  #define CONFIG_FSL_CORENET		/* Freescale CoreNet platform */  #define CONFIG_SYS_FSL_QORIQ_CHASSIS2	/* Freescale Chassis generation 2 */ diff --git a/arch/powerpc/include/asm/immap_83xx.h b/arch/powerpc/include/asm/immap_83xx.h index 3c86ff66f..289f7cac5 100644 --- a/arch/powerpc/include/asm/immap_83xx.h +++ b/arch/powerpc/include/asm/immap_83xx.h @@ -763,6 +763,7 @@ typedef struct immap {  	u8			res7[0xC0000];  } immap_t; +#ifndef	CONFIG_MPC834x  #ifdef CONFIG_HAS_FSL_MPH_USB  #define CONFIG_SYS_MPC83xx_USB1_OFFSET  0x22000	/* use the MPH controller */  #define CONFIG_SYS_MPC83xx_USB2_OFFSET	0 @@ -770,6 +771,10 @@ typedef struct immap {  #define CONFIG_SYS_MPC83xx_USB1_OFFSET	0  #define CONFIG_SYS_MPC83xx_USB2_OFFSET  0x23000	/* use the DR controller */  #endif +#else +#define CONFIG_SYS_MPC83xx_USB1_OFFSET	0x22000 +#define CONFIG_SYS_MPC83xx_USB2_OFFSET  0x23000 +#endif  #elif defined(CONFIG_MPC8313)  typedef struct immap { diff --git a/arch/powerpc/include/asm/immap_85xx.h b/arch/powerpc/include/asm/immap_85xx.h index 060e0d769..631261857 100644 --- a/arch/powerpc/include/asm/immap_85xx.h +++ b/arch/powerpc/include/asm/immap_85xx.h @@ -282,7 +282,9 @@ typedef struct ccsr_pcix {  	u32	int_ack;	/* PCIX IRQ Acknowledge */  	u8	res000c[52];  	u32	liodn_base;	/* PCIX LIODN base register */ -	u8	res0044[3004]; +	u8	res0044[2996]; +	u32	ipver1;		/* PCIX IP block revision register 1 */ +	u32	ipver2;		/* PCIX IP block revision register 2 */  	u32	potar0;		/* PCIX Outbound Transaction Addr 0 */  	u32	potear0;	/* PCIX Outbound Translation Extended Addr 0 */  	u32	powbar0;	/* PCIX Outbound Window Base Addr 0 */ @@ -1847,7 +1849,8 @@ typedef struct ccsr_gur {  #define FSL_CORENET2_RCWSR4_SRDS2_PRTCL	0x00ff0000  #define FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT	16  #define FSL_CORENET_RCWSR6_BOOT_LOC	0x0f800000 -#elif defined(CONFIG_PPC_T1040) +#elif defined(CONFIG_PPC_T1040) || defined(CONFIG_PPC_T1042) ||\ +defined(CONFIG_PPC_T1020) || defined(CONFIG_PPC_T1022)  #define FSL_CORENET2_RCWSR4_SRDS1_PRTCL	0xff000000  #define FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT	24  #define FSL_CORENET2_RCWSR4_SRDS2_PRTCL	0x00fe0000 diff --git a/board/LEOX/elpt860/u-boot.lds b/board/LEOX/elpt860/u-boot.lds index b30b667eb..c5e57ec03 100644 --- a/board/LEOX/elpt860/u-boot.lds +++ b/board/LEOX/elpt860/u-boot.lds @@ -30,10 +30,10 @@ SECTIONS      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    common/libcommon.o			(.text*) -    arch/powerpc/cpu/mpc8xx/libmpc8xx.o	(.text*) -    board/LEOX/elpt860/libelpt860.o	(.text*) -    arch/powerpc/lib/libpowerpc.o	(.text*) +    common/built-in.o			(.text*) +    arch/powerpc/cpu/mpc8xx/built-in.o	(.text*) +    board/LEOX/elpt860/built-in.o	(.text*) +    arch/powerpc/lib/built-in.o		(.text*)      . = env_offset;      common/env_embedded.o		(.text*) diff --git a/board/LaCie/edminiv2/Makefile b/board/LaCie/edminiv2/Makefile index 7ca06f5a7..035f6865d 100644 --- a/board/LaCie/edminiv2/Makefile +++ b/board/LaCie/edminiv2/Makefile @@ -9,8 +9,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= edminiv2.o ../common/common.o diff --git a/board/LaCie/net2big_v2/Makefile b/board/LaCie/net2big_v2/Makefile index 4fa08c513..f3074af25 100644 --- a/board/LaCie/net2big_v2/Makefile +++ b/board/LaCie/net2big_v2/Makefile @@ -9,10 +9,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= net2big_v2.o ../common/common.o  ifneq ($(and $(CONFIG_KIRKWOOD_GPIO),$(CONFIG_NET2BIG_V2)),)  obj-y	+= ../common/cpld-gpio-bus.o diff --git a/board/LaCie/netspace_v2/Makefile b/board/LaCie/netspace_v2/Makefile index e5357e4bc..47778d847 100644 --- a/board/LaCie/netspace_v2/Makefile +++ b/board/LaCie/netspace_v2/Makefile @@ -9,8 +9,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= netspace_v2.o ../common/common.o diff --git a/board/LaCie/wireless_space/Makefile b/board/LaCie/wireless_space/Makefile index 11c535e99..90a84f489 100644 --- a/board/LaCie/wireless_space/Makefile +++ b/board/LaCie/wireless_space/Makefile @@ -9,8 +9,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= wireless_space.o ../common/common.o diff --git a/board/Marvell/db64360/Makefile b/board/Marvell/db64360/Makefile index aad4776b8..aefe0a789 100644 --- a/board/Marvell/db64360/Makefile +++ b/board/Marvell/db64360/Makefile @@ -8,10 +8,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= db64360.o ../common/flash.o ../common/serial.o ../common/memory.o pci.o \  	  mv_eth.o ../common/ns16550.o mpsc.o ../common/i2c.o \  	  sdram_init.o ../common/intel_flash.o ../common/misc.o diff --git a/board/Marvell/db64460/Makefile b/board/Marvell/db64460/Makefile index ea9e57086..a970f9afd 100644 --- a/board/Marvell/db64460/Makefile +++ b/board/Marvell/db64460/Makefile @@ -8,10 +8,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	+= db64460.o ../common/flash.o ../common/serial.o ../common/memory.o pci.o \  	  mv_eth.o ../common/ns16550.o mpsc.o ../common/i2c.o \  	  sdram_init.o ../common/intel_flash.o ../common/misc.o diff --git a/board/actux1/u-boot.lds b/board/actux1/u-boot.lds index a656fa99d..b0f09f592 100644 --- a/board/actux1/u-boot.lds +++ b/board/actux1/u-boot.lds @@ -16,10 +16,10 @@ SECTIONS  	.text : {  		*(.__image_copy_start)  		arch/arm/cpu/ixp/start.o(.text*) -		net/libnet.o(.text*) -		board/actux1/libactux1.o(.text*) -		arch/arm/cpu/ixp/libixp.o(.text*) -		drivers/input/libinput.o(.text*) +		net/built-in.o(.text*) +		board/actux1/built-in.o(.text*) +		arch/arm/cpu/ixp/built-in.o(.text*) +		drivers/input/built-in.o(.text*)  		. = env_offset;  		common/env_embedded.o(.ppcenv) diff --git a/board/actux2/u-boot.lds b/board/actux2/u-boot.lds index 7a1717640..d84934e1f 100644 --- a/board/actux2/u-boot.lds +++ b/board/actux2/u-boot.lds @@ -16,10 +16,10 @@ SECTIONS  	.text : {  		*(.__image_copy_start)  		arch/arm/cpu/ixp/start.o(.text*) -		net/libnet.o(.text*) -		board/actux2/libactux2.o(.text*) -		arch/arm/cpu/ixp/libixp.o(.text*) -		drivers/input/libinput.o(.text*) +		net/built-in.o(.text*) +		board/actux2/built-in.o(.text*) +		arch/arm/cpu/ixp/built-in.o(.text*) +		drivers/input/built-in.o(.text*)  		. = env_offset;  		common/env_embedded.o(.ppcenv) diff --git a/board/actux3/u-boot.lds b/board/actux3/u-boot.lds index aadfdd2f5..30c204b64 100644 --- a/board/actux3/u-boot.lds +++ b/board/actux3/u-boot.lds @@ -16,10 +16,10 @@ SECTIONS  	.text : {  		*(.__image_copy_start)  		arch/arm/cpu/ixp/start.o(.text*) -		net/libnet.o(.text*) -		board/actux3/libactux3.o(.text*) -		arch/arm/cpu/ixp/libixp.o(.text*) -		drivers/input/libinput.o(.text*) +		net/built-in.o(.text*) +		board/actux3/built-in.o(.text*) +		arch/arm/cpu/ixp/built-in.o(.text*) +		drivers/input/built-in.o(.text*)  		. = env_offset;  		common/env_embedded.o(.ppcenv) diff --git a/board/altera/nios2-generic/Makefile b/board/altera/nios2-generic/Makefile index 84c7bff80..84690fe04 100644 --- a/board/altera/nios2-generic/Makefile +++ b/board/altera/nios2-generic/Makefile @@ -6,10 +6,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= nios2-generic.o  obj-$(CONFIG_CMD_IDE) += ../common/cfide.o  obj-$(CONFIG_EPLED) += ../common/epled.o diff --git a/board/altera/nios2-generic/config.mk b/board/altera/nios2-generic/config.mk index f9f317c44..a67352519 100644 --- a/board/altera/nios2-generic/config.mk +++ b/board/altera/nios2-generic/config.mk @@ -5,11 +5,7 @@  # SPDX-License-Identifier:	GPL-2.0+  # -# we get text_base from board config header, so do not use this -#CONFIG_SYS_TEXT_BASE = do-not-use-me -  PLATFORM_CPPFLAGS += -mno-hw-div -mno-hw-mul -PLATFORM_CPPFLAGS += -I$(TOPDIR)/board/$(VENDOR)/include  ifeq ($(debug),1)  PLATFORM_CPPFLAGS += -DDEBUG diff --git a/board/avionic-design/medcom-wide/Makefile b/board/avionic-design/medcom-wide/Makefile index 6c4ab643e..87e19123b 100644 --- a/board/avionic-design/medcom-wide/Makefile +++ b/board/avionic-design/medcom-wide/Makefile @@ -7,8 +7,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)../common $(obj)../../nvidia/common) -  obj-y	:= ../common/tamonten.o  include ../../nvidia/common/common.mk diff --git a/board/avionic-design/plutux/Makefile b/board/avionic-design/plutux/Makefile index 6c4ab643e..87e19123b 100644 --- a/board/avionic-design/plutux/Makefile +++ b/board/avionic-design/plutux/Makefile @@ -7,8 +7,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)../common $(obj)../../nvidia/common) -  obj-y	:= ../common/tamonten.o  include ../../nvidia/common/common.mk diff --git a/board/avionic-design/tec/Makefile b/board/avionic-design/tec/Makefile index 6c4ab643e..87e19123b 100644 --- a/board/avionic-design/tec/Makefile +++ b/board/avionic-design/tec/Makefile @@ -7,8 +7,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)../common $(obj)../../nvidia/common) -  obj-y	:= ../common/tamonten.o  include ../../nvidia/common/common.mk diff --git a/board/cogent/config.mk b/board/cogent/config.mk deleted file mode 100644 index 1452d46a9..000000000 --- a/board/cogent/config.mk +++ /dev/null @@ -1,12 +0,0 @@ -# -# (C) Copyright 2000 -# Wolfgang Denk, DENX Software Engineering, wd@denx.de. -# -# SPDX-License-Identifier:	GPL-2.0+ -# - -# -# Cogent Modular Architecture -# - -PLATFORM_CPPFLAGS += -I$(TOPDIR) diff --git a/board/cogent/dipsw.c b/board/cogent/dipsw.c index d2027c975..ecfbc2598 100644 --- a/board/cogent/dipsw.c +++ b/board/cogent/dipsw.c @@ -1,5 +1,5 @@  #include <common.h> -#include <board/cogent/dipsw.h> +#include "dipsw.h"  unsigned char  dipsw_raw(void) diff --git a/board/cogent/flash.c b/board/cogent/flash.c index d4ae4d0a3..1da8f10a1 100644 --- a/board/cogent/flash.c +++ b/board/cogent/flash.c @@ -6,7 +6,7 @@   */  #include <common.h> -#include <board/cogent/flash.h> +#include "flash.h"  #include <linux/compiler.h>  flash_info_t	flash_info[CONFIG_SYS_MAX_FLASH_BANKS]; /* info for FLASH chips	*/ diff --git a/board/cogent/lcd.c b/board/cogent/lcd.c index 76f5ad103..8e90f9853 100644 --- a/board/cogent/lcd.c +++ b/board/cogent/lcd.c @@ -48,7 +48,7 @@  #include <common.h>  #include <stdarg.h> -#include <board/cogent/lcd.h> +#include "lcd.h"  static char lines[2][LCD_LINE_LENGTH+1];  static int curline; diff --git a/board/cogent/mb.c b/board/cogent/mb.c index 603f1235a..3eea47d3e 100644 --- a/board/cogent/mb.c +++ b/board/cogent/mb.c @@ -6,11 +6,11 @@   */  #include <common.h> -#include <board/cogent/dipsw.h> -#include <board/cogent/lcd.h> -#include <board/cogent/rtc.h> -#include <board/cogent/par.h> -#include <board/cogent/pci.h> +#include "dipsw.h" +#include "lcd.h" +#include "rtc.h" +#include "par.h" +#include "pci.h"  /* ------------------------------------------------------------------------- */ diff --git a/board/cogent/serial.c b/board/cogent/serial.c index 20631d162..f0d6b22cf 100644 --- a/board/cogent/serial.c +++ b/board/cogent/serial.c @@ -4,7 +4,7 @@   */  #include <common.h> -#include <board/cogent/serial.h> +#include "serial.h"  #include <serial.h>  #include <linux/compiler.h> diff --git a/board/compal/paz00/Makefile b/board/compal/paz00/Makefile index 824cd2ea1..b2d3b6b4b 100644 --- a/board/compal/paz00/Makefile +++ b/board/compal/paz00/Makefile @@ -14,8 +14,6 @@  # more details.  # -$(shell mkdir -p $(obj)../../nvidia/common) -  obj-y	:= paz00.o  include ../../nvidia/common/common.mk diff --git a/board/compulab/cm_t35/cm_t35.c b/board/compulab/cm_t35/cm_t35.c index 9f2937a97..bc8e0cad9 100644 --- a/board/compulab/cm_t35/cm_t35.c +++ b/board/compulab/cm_t35/cm_t35.c @@ -482,7 +482,7 @@ static void setup_net_chip_gmpc(void)  		&ctrl_base->gpmc_nadv_ale);  } -#ifdef CONFIG_DRIVER_OMAP34XX_I2C +#ifdef CONFIG_SYS_I2C_OMAP34XX  /*   * Routine: reset_net_chip   * Description: reset the Ethernet controller via TPS65930 GPIO diff --git a/board/compulab/common/Makefile b/board/compulab/common/Makefile index 831be2e0e..6d7d06815 100644 --- a/board/compulab/common/Makefile +++ b/board/compulab/common/Makefile @@ -6,5 +6,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_DRIVER_OMAP34XX_I2C) += eeprom.o +obj-$(CONFIG_SYS_I2C_OMAP34XX) += eeprom.o  obj-$(CONFIG_LCD) += omap3_display.o diff --git a/board/compulab/common/eeprom.h b/board/compulab/common/eeprom.h index cf8c302b2..e87162930 100644 --- a/board/compulab/common/eeprom.h +++ b/board/compulab/common/eeprom.h @@ -10,7 +10,7 @@  #ifndef _EEPROM_  #define _EEPROM_ -#ifdef CONFIG_DRIVER_OMAP34XX_I2C +#ifdef CONFIG_SYS_I2C_OMAP34XX  int cl_eeprom_read_mac_addr(uchar *buf);  u32 cl_eeprom_get_board_rev(void);  #else diff --git a/board/compulab/trimslice/Makefile b/board/compulab/trimslice/Makefile index 0818673cb..f3bd00dbf 100644 --- a/board/compulab/trimslice/Makefile +++ b/board/compulab/trimslice/Makefile @@ -5,8 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)../../nvidia/common) -  obj-y	:= trimslice.o  include ../../nvidia/common/common.mk diff --git a/board/davinci/da8xxevm/u-boot-spl-hawk.lds b/board/davinci/da8xxevm/u-boot-spl-hawk.lds index e43130aa6..d49c31449 100644 --- a/board/davinci/da8xxevm/u-boot-spl-hawk.lds +++ b/board/davinci/da8xxevm/u-boot-spl-hawk.lds @@ -19,8 +19,8 @@ SECTIONS  	.text      :  	{  	  arch/arm/cpu/arm926ejs/start.o		(.text*) -	  arch/arm/cpu/arm926ejs/davinci/libdavinci.o	(.text*) -	  drivers/mtd/nand/libnand.o			(.text*) +	  arch/arm/cpu/arm926ejs/davinci/built-in.o	(.text*) +	  drivers/mtd/nand/built-in.o			(.text*)  	  *(.text*)  	} diff --git a/board/dvlhost/u-boot.lds b/board/dvlhost/u-boot.lds index 40c9c8038..0035a0bf0 100644 --- a/board/dvlhost/u-boot.lds +++ b/board/dvlhost/u-boot.lds @@ -16,10 +16,10 @@ SECTIONS  	.text : {  		*(.__image_copy_start)  		arch/arm/cpu/ixp/start.o(.text*) -		net/libnet.o(.text*) -		board/dvlhost/libdvlhost.o(.text*) -		arch/arm/cpu/ixp/libixp.o(.text*) -		drivers/serial/libserial.o(.text*) +		net/built-in.o(.text*) +		board/dvlhost/built-in.o(.text*) +		arch/arm/cpu/ixp/built-in.o(.text*) +		drivers/serial/built-in.o(.text*)  		. = env_offset;  		common/env_embedded.o(.ppcenv) diff --git a/board/emk/top5200/Makefile b/board/emk/top5200/Makefile index 0930d484f..b455c26e1 100644 --- a/board/emk/top5200/Makefile +++ b/board/emk/top5200/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= top5200.o ../common/flash.o ../common/vpd.o ../common/am79c874.o diff --git a/board/emk/top860/Makefile b/board/emk/top860/Makefile index b2645f634..0401639ce 100644 --- a/board/emk/top860/Makefile +++ b/board/emk/top860/Makefile @@ -5,7 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif  obj-y	= top860.o ../common/flash.o ../common/vpd.o ../common/am79c874.o diff --git a/board/esd/adciop/Makefile b/board/esd/adciop/Makefile index a096e4441..d0e264de9 100644 --- a/board/esd/adciop/Makefile +++ b/board/esd/adciop/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= adciop.o flash.o ../common/misc.o ../common/pci.o diff --git a/board/esd/apc405/Makefile b/board/esd/apc405/Makefile index c6ab1a5e2..ada8bfd3d 100644 --- a/board/esd/apc405/Makefile +++ b/board/esd/apc405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= apc405.o \  	../common/misc.o \  	../common/auto_update.o diff --git a/board/esd/ar405/Makefile b/board/esd/ar405/Makefile index 2d16313e8..dd54f546a 100644 --- a/board/esd/ar405/Makefile +++ b/board/esd/ar405/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= ar405.o flash.o ../common/misc.o diff --git a/board/esd/ash405/Makefile b/board/esd/ash405/Makefile index 4c866ee0a..aab8de44b 100644 --- a/board/esd/ash405/Makefile +++ b/board/esd/ash405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= ash405.o flash.o \  	../common/misc.o \  	../common/esd405ep_nand.o \ diff --git a/board/esd/cms700/Makefile b/board/esd/cms700/Makefile index 8cfe3baf7..2bf50066c 100644 --- a/board/esd/cms700/Makefile +++ b/board/esd/cms700/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common/xilinx_jtag) -endif -  # Objects for Xilinx JTAG programming (CPLD)  CPLD    = ../common/xilinx_jtag/lenval.o \  	  ../common/xilinx_jtag/micro.o \ diff --git a/board/esd/cpci2dp/Makefile b/board/esd/cpci2dp/Makefile index 1d1502071..ce2c6dd91 100644 --- a/board/esd/cpci2dp/Makefile +++ b/board/esd/cpci2dp/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= cpci2dp.o flash.o ../common/misc.o ../common/cmd_loadpci.o diff --git a/board/esd/cpci405/Makefile b/board/esd/cpci405/Makefile index 1af7e9454..b14057179 100644 --- a/board/esd/cpci405/Makefile +++ b/board/esd/cpci405/Makefile @@ -5,9 +5,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= cpci405.o flash.o ../common/misc.o ../common/auto_update.o  obj-y	+= ../common/cmd_loadpci.o diff --git a/board/esd/cpci5200/Makefile b/board/esd/cpci5200/Makefile index fb6c0e20e..8421f5486 100644 --- a/board/esd/cpci5200/Makefile +++ b/board/esd/cpci5200/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -# ifneq ($(OBJTREE),$(SRCTREE)) -# $(shell mkdir -p $(obj)../common/xilinx_jtag) -# endif -  # Objects for Xilinx JTAG programming (CPLD)  # CPLD  = ../common/xilinx_jtag/lenval.o \  #	  ../common/xilinx_jtag/micro.o \ diff --git a/board/esd/cpci750/Makefile b/board/esd/cpci750/Makefile index 8b3dc3370..a3300c9f4 100644 --- a/board/esd/cpci750/Makefile +++ b/board/esd/cpci750/Makefile @@ -8,10 +8,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../../Marvell/common) -endif -  obj-y	= misc.o  obj-y	+= cpci750.o serial.o ../../Marvell/common/memory.o pci.o \  	  mv_eth.o  mpsc.o i2c.o \ diff --git a/board/esd/cpciiser4/Makefile b/board/esd/cpciiser4/Makefile index 4d3c34ae4..b8d6bea6d 100644 --- a/board/esd/cpciiser4/Makefile +++ b/board/esd/cpciiser4/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= cpciiser4.o flash.o ../common/misc.o diff --git a/board/esd/dasa_sim/Makefile b/board/esd/dasa_sim/Makefile index f0a5a8f09..eb9f5f86d 100644 --- a/board/esd/dasa_sim/Makefile +++ b/board/esd/dasa_sim/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= dasa_sim.o flash.o cmd_dasa_sim.o eeprom.o ../common/pci.o diff --git a/board/esd/dp405/Makefile b/board/esd/dp405/Makefile index 6809c673c..cfcfb66a1 100644 --- a/board/esd/dp405/Makefile +++ b/board/esd/dp405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common/xilinx_jtag) -endif -  # Objects for Xilinx JTAG programming (CPLD)  CPLD    = ../common/xilinx_jtag/lenval.o \  	  ../common/xilinx_jtag/micro.o \ diff --git a/board/esd/du405/Makefile b/board/esd/du405/Makefile index 12ce41a9a..7914eab35 100644 --- a/board/esd/du405/Makefile +++ b/board/esd/du405/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= du405.o flash.o ../common/misc.o diff --git a/board/esd/hh405/Makefile b/board/esd/hh405/Makefile index 0507f1b4d..fba21a3ae 100644 --- a/board/esd/hh405/Makefile +++ b/board/esd/hh405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= hh405.o flash.o \  	../common/misc.o \  	../common/esd405ep_nand.o \ diff --git a/board/esd/hub405/Makefile b/board/esd/hub405/Makefile index 5447a959c..99e18b567 100644 --- a/board/esd/hub405/Makefile +++ b/board/esd/hub405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= hub405.o flash.o \  	../common/misc.o \  	../common/esd405ep_nand.o \ diff --git a/board/esd/ocrtc/Makefile b/board/esd/ocrtc/Makefile index 0d9a6fdc4..44b7d5d07 100644 --- a/board/esd/ocrtc/Makefile +++ b/board/esd/ocrtc/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= ocrtc.o flash.o ../common/misc.o cmd_ocrtc.o diff --git a/board/esd/pci405/Makefile b/board/esd/pci405/Makefile index 2f8706bd6..9e659c796 100644 --- a/board/esd/pci405/Makefile +++ b/board/esd/pci405/Makefile @@ -5,9 +5,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= pci405.o flash.o ../common/misc.o cmd_pci405.o  obj-y	+= writeibm.o diff --git a/board/esd/pf5200/Makefile b/board/esd/pf5200/Makefile index a9d20c90b..a54289c07 100644 --- a/board/esd/pf5200/Makefile +++ b/board/esd/pf5200/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -# ifneq ($(OBJTREE),$(SRCTREE)) -# $(shell mkdir -p $(obj)../common/xilinx_jtag) -# endif -  # Objects for Xilinx JTAG programming (CPLD)  # CPLD  = ../common/xilinx_jtag/lenval.o \  #	  ../common/xilinx_jtag/micro.o \ diff --git a/board/esd/plu405/Makefile b/board/esd/plu405/Makefile index 45b962f69..6ffae677b 100644 --- a/board/esd/plu405/Makefile +++ b/board/esd/plu405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= plu405.o flash.o \  	../common/misc.o \  	../common/esd405ep_nand.o \ diff --git a/board/esd/pmc405/Makefile b/board/esd/pmc405/Makefile index f4aa1c9ee..ad98207f3 100644 --- a/board/esd/pmc405/Makefile +++ b/board/esd/pmc405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common/xilinx_jtag) -endif -  # Objects for Xilinx JTAG programming (CPLD)  CPLD    = ../common/xilinx_jtag/lenval.o \  	  ../common/xilinx_jtag/micro.o \ diff --git a/board/esd/pmc405de/Makefile b/board/esd/pmc405de/Makefile index 7d5b273c0..b3f6dcd1e 100644 --- a/board/esd/pmc405de/Makefile +++ b/board/esd/pmc405de/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= pmc405de.o  obj-$(CONFIG_CMD_CHIP_CONFIG) += chip_config.o  obj-y += ../common/cmd_loadpci.o diff --git a/board/esd/pmc440/Makefile b/board/esd/pmc440/Makefile index b1318c742..708e9d138 100644 --- a/board/esd/pmc440/Makefile +++ b/board/esd/pmc440/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= pmc440.o cmd_pmc440.o sdram.o fpga.o \  	../common/cmd_loadpci.o  extra-y	+= init.o diff --git a/board/esd/voh405/Makefile b/board/esd/voh405/Makefile index 8fcfa37dc..3d82399ed 100644 --- a/board/esd/voh405/Makefile +++ b/board/esd/voh405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= voh405.o flash.o \  	../common/misc.o \  	../common/esd405ep_nand.o \ diff --git a/board/esd/vom405/Makefile b/board/esd/vom405/Makefile index c8a4a4e4c..7cf5c0224 100644 --- a/board/esd/vom405/Makefile +++ b/board/esd/vom405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common/xilinx_jtag) -endif -  # Objects for Xilinx JTAG programming (CPLD)  CPLD    = ../common/xilinx_jtag/lenval.o \  	  ../common/xilinx_jtag/micro.o \ diff --git a/board/esd/wuh405/Makefile b/board/esd/wuh405/Makefile index 046ebad30..b9beeffc5 100644 --- a/board/esd/wuh405/Makefile +++ b/board/esd/wuh405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= wuh405.o flash.o \  	../common/misc.o \  	../common/esd405ep_nand.o \ diff --git a/board/esteem192e/u-boot.lds b/board/esteem192e/u-boot.lds index 87642d6b4..59a86bfdc 100644 --- a/board/esteem192e/u-boot.lds +++ b/board/esteem192e/u-boot.lds @@ -18,8 +18,8 @@ SECTIONS      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    net/libnet.o			(.text*) -    board/esteem192e/libesteem192e.o	(.text*) +    net/built-in.o			(.text*) +    board/esteem192e/built-in.o		(.text*)      . = env_offset;      common/env_embedded.o		(.text*) diff --git a/board/freescale/m52277evb/config.mk b/board/freescale/m52277evb/config.mk deleted file mode 100644 index 0ffb0a204..000000000 --- a/board/freescale/m52277evb/config.mk +++ /dev/null @@ -1,11 +0,0 @@ -# -# (C) Copyright 2000-2003 -# Wolfgang Denk, DENX Software Engineering, wd@denx.de. -# Coldfire contribution by Bernhard Kuhn <bkuhn@metrowerks.com> -# -# SPDX-License-Identifier:	GPL-2.0+ -# - -sinclude $(OBJTREE)/board/$(BOARDDIR)/config.tmp - -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) diff --git a/board/freescale/m52277evb/u-boot.lds b/board/freescale/m52277evb/u-boot.lds index f3337a384..70121d924 100644 --- a/board/freescale/m52277evb/u-boot.lds +++ b/board/freescale/m52277evb/u-boot.lds @@ -13,8 +13,8 @@ SECTIONS    .text      :    {      arch/m68k/cpu/mcf5227x/start.o	(.text*) -    arch/m68k/cpu/mcf5227x/libmcf5227x.o	(.text*) -    arch/m68k/lib/libm68k.o		(.text*) +    arch/m68k/cpu/mcf5227x/built-in.o	(.text*) +    arch/m68k/lib/built-in.o		(.text*)      *(.text*)    } diff --git a/board/freescale/m5235evb/config.mk b/board/freescale/m5235evb/config.mk deleted file mode 100644 index 9ab4582bf..000000000 --- a/board/freescale/m5235evb/config.mk +++ /dev/null @@ -1,12 +0,0 @@ -# -# (C) Copyright 2000-2003 -# Wolfgang Denk, DENX Software Engineering, wd@denx.de. -# Coldfire contribution by Bernhard Kuhn <bkuhn@metrowerks.com> -# -# SPDX-License-Identifier:	GPL-2.0+ -# - -/*CONFIG_SYS_TEXT_BASE = 0xFFC00000*/ -sinclude $(OBJTREE)/board/$(BOARDDIR)/config.tmp - -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) diff --git a/board/freescale/m53017evb/u-boot.lds b/board/freescale/m53017evb/u-boot.lds index ef21299ea..de8d09bf6 100644 --- a/board/freescale/m53017evb/u-boot.lds +++ b/board/freescale/m53017evb/u-boot.lds @@ -12,9 +12,9 @@ SECTIONS    /* Read-only sections, merged into text segment: */    .text      :    { -    arch/m68k/cpu/mcf532x/start.o		(.text*) -    arch/m68k/cpu/mcf532x/libmcf532x.o	(.text*) -    arch/m68k/lib/libm68k.o		(.text*) +    arch/m68k/cpu/mcf532x/start.o	(.text*) +    arch/m68k/cpu/mcf532x/built-in.o	(.text*) +    arch/m68k/lib/built-in.o		(.text*)      . = DEFINED(env_offset) ? env_offset : .;      common/env_embedded.o	(.text*) diff --git a/board/freescale/m54451evb/config.mk b/board/freescale/m54451evb/config.mk deleted file mode 100644 index 0ffb0a204..000000000 --- a/board/freescale/m54451evb/config.mk +++ /dev/null @@ -1,11 +0,0 @@ -# -# (C) Copyright 2000-2003 -# Wolfgang Denk, DENX Software Engineering, wd@denx.de. -# Coldfire contribution by Bernhard Kuhn <bkuhn@metrowerks.com> -# -# SPDX-License-Identifier:	GPL-2.0+ -# - -sinclude $(OBJTREE)/board/$(BOARDDIR)/config.tmp - -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) diff --git a/board/freescale/m54455evb/config.mk b/board/freescale/m54455evb/config.mk deleted file mode 100644 index 0ffb0a204..000000000 --- a/board/freescale/m54455evb/config.mk +++ /dev/null @@ -1,11 +0,0 @@ -# -# (C) Copyright 2000-2003 -# Wolfgang Denk, DENX Software Engineering, wd@denx.de. -# Coldfire contribution by Bernhard Kuhn <bkuhn@metrowerks.com> -# -# SPDX-License-Identifier:	GPL-2.0+ -# - -sinclude $(OBJTREE)/board/$(BOARDDIR)/config.tmp - -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) diff --git a/board/freescale/mx31ads/u-boot.lds b/board/freescale/mx31ads/u-boot.lds index 3acc4ca54..8d5cc9101 100644 --- a/board/freescale/mx31ads/u-boot.lds +++ b/board/freescale/mx31ads/u-boot.lds @@ -22,11 +22,11 @@ SECTIONS  	  /* WARNING - the following is hand-optimized to fit within	*/  	  /* the sector layout of our flash chips!	XXX FIXME XXX	*/ -	  arch/arm/cpu/arm1136/start.o			(.text*) -	  board/freescale/mx31ads/libmx31ads.o	(.text*) -	  arch/arm/lib/libarm.o			(.text*) -	  net/libnet.o				(.text*) -	  drivers/mtd/libmtd.o			(.text*) +	  arch/arm/cpu/arm1136/start.o		(.text*) +	  board/freescale/mx31ads/built-in.o	(.text*) +	  arch/arm/lib/built-in.o		(.text*) +	  net/built-in.o			(.text*) +	  drivers/mtd/built-in.o		(.text*)  	  . = DEFINED(env_offset) ? env_offset : .;  	  common/env_embedded.o(.text*) diff --git a/board/freescale/p1010rdb/README b/board/freescale/p1010rdb/README.P1010RDB-PA index 7f18aaa1b..158a1b315 100644 --- a/board/freescale/p1010rdb/README +++ b/board/freescale/p1010rdb/README.P1010RDB-PA @@ -204,5 +204,5 @@ Place uImage, p1010rdb.dtb and rootfs files in the TFTP disk area.  	=> bootm 1000000 3000000 2000000 -Please contact your local field applications engineer or sales representative -to obtain related documents, such as P1010-RDB User Guide for details. +For more details, please refer to P1010RDB User Guide and access website +www.freescale.com diff --git a/board/freescale/p1010rdb/README.P1010RDB-PB b/board/freescale/p1010rdb/README.P1010RDB-PB new file mode 100644 index 000000000..cf459b339 --- /dev/null +++ b/board/freescale/p1010rdb/README.P1010RDB-PB @@ -0,0 +1,188 @@ +Overview +========= +The P1010RDB-PB is a Freescale Reference Design Board that hosts the P1010 SoC. +P1010RDB-PB is a variation of previous P1010RDB-PA board. + +The P1010 is a cost-effective, low-power, highly integrated host processor +based on a Power Architecture e500v2 core (maximum core frequency 1GHz),that +addresses the requirements of several routing, gateways, storage, consumer, +and industrial applications. Applications of interest include the main CPUs and +I/O processors in network attached storage (NAS), the voice over IP (VoIP) +router/gateway, and wireless LAN (WLAN) and industrial controllers. + +The P1010RDB-PB board features are as following: +Memory subsystem: +	- 1G bytes unbuffered DDR3 SDRAM discrete devices (32-bit bus) +	- 32M bytes NOR flash single-chip memory +	- 2G bytes NAND flash memory +	- 16M bytes SPI memory +	- 256K bit M24256 I2C EEPROM +	- I2C Board EEPROM 128x8 bit memory +	- SD/MMC connector to interface with the SD memory card +Interfaces: +	- Three 10/100/1000 BaseT Ethernet ports (One RGMII and two SGMII) +	- PCIe 2.0: two x1 mini-PCIe slots +	- SATA 2.0: two SATA interfaces +	- USB 2.0: one USB interface +	- FlexCAN: two FlexCAN interfaces (revision 2.0B) +	- UART: one USB-to-Serial interface +	- TDM: 2 FXS ports connected via an external SLIC to the TDM interface. +	       1 FXO port connected via a relay to FXS for switchover to POTS + +Board connectors: +	- Mini-ITX power supply connector +	- JTAG/COP for debugging + +POR: support critical POR setting changed via switch on board +PCB: 6-layer routing (4-layer signals, 2-layer power and ground) + +Physical Memory Map on P1010RDB +=============================== +Address Start   Address End   Memory type	Attributes +0x0000_0000	0x3fff_ffff   DDR		1G Cacheable +0xa000_0000	0xdfff_ffff   PCI Express Mem	1G non-cacheable +0xee00_0000	0xefff_ffff   NOR Flash		32M non-cacheable +0xffc2_0000	0xffc5_ffff   PCI IO range	256K non-cacheable +0xffa0_0000	0xffaf_ffff   NAND Flash	1M cacheable +0xffb0_0000	0xffbf_ffff   Board CPLD	1M non-cacheable +0xffd0_0000	0xffd0_3fff   L1 for Stack	16K Cacheable TLB0 +0xffe0_0000	0xffef_ffff   CCSR		1M non-cacheable + + +Serial Port Configuration on P1010RDB +===================================== +Configure the serial port of the attached computer with the following values: +	-Data rate: 115200 bps +	-Number of data bits: 8 +	-Parity: None +	-Number of Stop bits: 1 +	-Flow Control: Hardware/None + + +P1010RDB-PB default DIP-switch settings +======================================= +SW1[1:8]= 10101010 +SW2[1:8]= 11011000 +SW3[1:8]= 10010000 +SW4[1:4]= 1010 +SW5[1:8]= 11111010 + + +P1010RDB-PB boot mode settings via DIP-switch +============================================= +SW4[1:4]= 1111 and SW3[3:4]= 00 for 16bit NOR boot +SW4[1:4]= 1010 and SW3[3:4]= 01 for 8bit NAND boot +SW4[1:4]= 0110 and SW3[3:4]= 00 for SPI boot +SW4[1:4]= 0111 and SW3[3:4]= 10 for SD boot +Note: 1 stands for 'on', 0 stands for 'off' + + +Switch P1010RDB-PB boot mode via software without setting DIP-switch +==================================================================== +=> run boot_bank0    (boot from NOR bank0) +=> run boot_bank1    (boot from NOR bank1) +=> run boot_nand     (boot from NAND flash) +=> run boot_spi      (boot from SPI flash) +=> run boot_sd       (boot from SD card) + + +Frequency combination support on P1010RDB-PB +============================================= +SW1[4:7] SW5[1] SW5[5:8] SW2[2] Core(MHz) Platform(MHz) DDR(MT/s) +0101      1      1010     0       800       400		800 +1001      1      1010     0       800       400		667 +1010      1      1100     0       667       333		667 +1000      0      1010     0       533       266		667 +0101      1      1010     1       1000      400		800 +1001      1      1010     1       1000      400		667 + + +Setting of pin mux +================== +Since pins multiplexing, TDM and CAN are muxed with SPI flash. +SDHC is muxed with IFC. IFC and SPI flash are enabled by default. + +To enable TDM: +=> setenv hwconfig fsl_p1010mux:tdm_can=tdm +=> save;reset + +To enable FlexCAN: +=> setenv hwconfig fsl_p1010mux:tdm_can=can +=> save;reset + +To enable SDHC in case of NOR/NAND/SPI boot +   a) For temporary use case in runtime without reboot system +      run 'mux sdhc' in u-boot to validate SDHC with invalidating IFC. + +   b) For long-term use case +      set 'esdhc' in hwconfig and save it. + +To enable IFC in case of SD boot +   a) For temporary use case in runtime without reboot system +      run 'mux ifc' in u-boot to validate IFC with invalidating SDHC. + +   b) For long-term use case +      set 'ifc' in hwconfig and save it. + + +Build images for different boot mode +==================================== +First setup cross compile environment on build host +   $ export ARCH=powerpc +   $ export CROSS_COMPILE=<your-compiler-path>/powerpc-linux-gnu- + +1. For NOR boot +   $ make P1010RDB-PB_NOR + +2. For NAND boot +   $ make P1010RDB-PB_NAND + +3. For SPI boot +   $ make P1010RDB-PB_SPIFLASH + +4. For SD boot +   $ make P1010RDB-PB_SDCARD + + +Steps to program images to flash for different boot mode +======================================================== +1. NOR boot +   => tftp 1000000 u-boot.bin +   For bank0 +   => pro off all;era eff80000 efffffff;cp.b 1000000 eff80000 $filesize +   set SW1[8]=0, SW4[1:4]= 1111 and SW3[3:4]= 00, then power on the board + +   For bank1 +   => pro off all;era eef80000 eeffffff;cp.b 1000000 eef80000 $filesize +   set SW1[8]=1, SW4[1:4]= 1111 and SW3[3:4]= 00, then power on the board + +2. NAND boot +   => tftp 1000000 u-boot-nand.bin +   => nand erase 0 $filesize; nand write $loadaddr 0 $filesize +   Set SW4[1:4]= 1010 and SW3[3:4]= 01, then power on the board + +3. SPI boot +   1)  cat p1010rdb-config-header.bin u-boot.bin > u-boot-spi-combined.bin +   2)  =>  tftp 1000000 u-boot-spi-combined.bin +   3)  =>  sf probe 0; sf erase 0 100000; sf write 1000000 0 100000 +   set SW4[1:4]= 0110 and SW3[3:4]= 00, then power on the board + +4. SD boot +   1)	cat p1010rdb-config-header.bin u-boot.bin > u-boot-sd-combined.bin +   2)	=> tftp 1000000 u-boot-sd-combined.bin +   3)	=> mux sdhc +   4)	=> mmc write 1000000 0 1050 +   set SW4[1:4]= 0111 and SW3[3:4]= 10, then power on the board + + +Boot Linux from network using TFTP on P1010RDB-PB +================================================= +Place uImage, p1010rdb.dtb and rootfs files in the TFTP download path. +	=> tftp 1000000 uImage +	=> tftp 2000000 p1010rdb.dtb +	=> tftp 3000000 rootfs.ext2.gz.uboot.p1010rdb +	=> bootm 1000000 3000000 2000000 + + +For more details, please refer to P1010RDB-PB User Guide and access website +www.freescale.com and Freescale QorIQ SDK Infocenter document. diff --git a/board/freescale/t1040qds/Makefile b/board/freescale/t1040qds/Makefile index a2dba6ff1..93af9eb6a 100644 --- a/board/freescale/t1040qds/Makefile +++ b/board/freescale/t1040qds/Makefile @@ -4,7 +4,7 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-y	+= $(BOARD).o +obj-y	+= t1040qds.o  obj-y	+= ddr.o  obj-$(CONFIG_PCI)     += pci.o  obj-y	+= law.o diff --git a/board/freescale/t1040qds/t1040_pbi.cfg b/board/freescale/t1040qds/t1040_pbi.cfg new file mode 100644 index 000000000..624398a25 --- /dev/null +++ b/board/freescale/t1040qds/t1040_pbi.cfg @@ -0,0 +1,27 @@ +#PBI commands +#Initialize CPC1 +09010000 00200400 +09138000 00000000 +091380c0 00000100 +#Configure CPC1 as 512KB SRAM +09010100 00000000 +09010104 fffc0007 +09010f00 08000000 +09010000 80000000 +#Configure LAW for CPC1 +09000cf0 00000000 +09000cf4 fffc0000 +09000cf8 81000011 +#Configure alternate space +09000010 00000000 +09000014 ff000000 +09000018 81000000 +#Configure SPI controller +09110000 80000403 +09110020 2d170008 +09110024 00100008 +09110028 00100008 +0911002c 00100008 +#Flush PBL data +09138000 00000000 +091380c0 00000000 diff --git a/board/freescale/t1040qds/t1040_rcw.cfg b/board/freescale/t1040qds/t1040_rcw.cfg new file mode 100644 index 000000000..0d0dfa5a4 --- /dev/null +++ b/board/freescale/t1040qds/t1040_rcw.cfg @@ -0,0 +1,7 @@ +#PBL preamble and RCW header +aa55aa55 010e0100 +# serdes protocol 0x66 +0a10000c 0c000000 00000000 00000000 +66000002 00000000 fc027000 01000000 +00000000 00000000 00000000 00030810 +00000000 03fc500f 00000000 00000000 diff --git a/board/freescale/t104xrdb/Makefile b/board/freescale/t104xrdb/Makefile new file mode 100644 index 000000000..76c0c94b0 --- /dev/null +++ b/board/freescale/t104xrdb/Makefile @@ -0,0 +1,12 @@ +# +# Copyright 2013 Freescale Semiconductor, Inc. +# +# SPDX-License-Identifier:	GPL-2.0+ +# + + +obj-y	+= t104xrdb.o +obj-y	+= ddr.o +obj-$(CONFIG_PCI)	+= pci.o +obj-y	+= law.o +obj-y	+= tlb.o diff --git a/board/freescale/t104xrdb/README b/board/freescale/t104xrdb/README new file mode 100644 index 000000000..2cd8219c8 --- /dev/null +++ b/board/freescale/t104xrdb/README @@ -0,0 +1,200 @@ +Overview +-------- +The T1040RDB is a Freescale reference board that hosts the T1040 SoC +(and variants). Variants inclued T1042 presonality of T1040, in which +case T1040RDB can also be called T1042RDB. + +The T1042RDB_PI is a Freescale reference board that hosts the T1042 SoC. +(a personality of T1040 SoC). The board is similar to T1040RDB but is +designed specially with low power features targeted for Printing Image Market. + +T1040 SoC Overview +------------------ +The QorIQ T1040/T1042 processor support four integrated 64-bit e5500 PA +processor cores with high-performance data path acceleration architecture +and network peripheral interfaces required for networking & telecommunications. + +The T1040/T1042 SoC includes the following function and features: + + - Four e5500 cores, each with a private 256 KB L2 cache + - 256 KB shared L3 CoreNet platform cache (CPC) + - Interconnect CoreNet platform + - 32-/64-bit DDR3L/DDR4 SDRAM memory controller with ECC and interleaving +   support + - Data Path Acceleration Architecture (DPAA) incorporating acceleration + for the following functions: +    -  Packet parsing, classification, and distribution +    -  Queue management for scheduling, packet sequencing, and congestion +       management +    -  Cryptography Acceleration (SEC 5.0) +    - RegEx Pattern Matching Acceleration (PME 2.2) +    - IEEE Std 1588 support +    - Hardware buffer management for buffer allocation and deallocation + - Ethernet interfaces +    - Integrated 8-port Gigabit Ethernet switch (T1040 only) +    - Four 1 Gbps Ethernet controllers + - Two RGMII interfaces or one RGMII and one MII interfaces + - High speed peripheral interfaces +   - Four PCI Express 2.0 controllers running at up to 5 GHz +   - Two SATA controllers supporting 1.5 and 3.0 Gb/s operation +   - Upto two QSGMII interface +   - Upto six SGMII interface supporting 1000 Mbps +   - One SGMII interface supporting upto 2500 Mbps + - Additional peripheral interfaces +   - Two USB 2.0 controllers with integrated PHY +   - SD/eSDHC/eMMC +   - eSPI controller +   - Four I2C controllers +   - Four UARTs +   - Four GPIO controllers +   - Integrated flash controller (IFC) +   - LCD and HDMI interface (DIU) with 12 bit dual data rate +   - TDM interface + - Multicore programmable interrupt controller (PIC) + - Two 8-channel DMA engines + - Single source clocking implementation + - Deep Sleep power implementaion (wakeup from GPIO/Timer/Ethernet/USB) + +T1040 SoC Personalities +------------------------- + +T1022 Personality: +T1022 is a reduced personality of T1040 with less core/clusters. + +T1042 Personality: +T1042 is a reduced personality of T1040 without Integrated 8-port Gigabit +Ethernet switch. Rest of the blocks are same as T1040 + + +T1040RDB board Overview +------------------------- + - SERDES Connections, 8 lanes information: +	1: None +	2: SGMII +	3: QSGMII +	4: QSGMII +	5: PCIe1 x1 slot +	6: mini PCIe connector +	7: mini PCIe connector +	8: SATA connector + - DDR Controller +     - Supports rates of up to 1600 MHz data-rate +     - Supports one DDR3LP UDIMM/RDIMMs, of single-, dual- or quad-rank types. + - IFC/Local Bus +     - NAND flash: 1GB 8-bit NAND flash +     - NOR: 128MB 16-bit NOR Flash + - Ethernet +     - Two on-board RGMII 10/100/1G ethernet ports. + - CPLD + - Clocks +     - System and DDR clock (SYSCLK, “DDRCLK”) +     - SERDES clocks + - Power Supplies + - USB +     - Supports two USB 2.0 ports with integrated PHYs +     - Two type A ports with 5V@1.5A per port. + - SDHC +     - SDHC/SDXC connector + - SPI +    -  On-board 64MB SPI flash + - Other IO +    - Two Serial ports +    - Four I2C ports + +T1042RDB_PI board Overview +------------------------- + - SERDES Connections, 8 lanes information: +	1, 2, 3, 4 : PCIe x4 slot +	5: mini PCIe connector +	6: mini PCIe connector +	7: NA +	8: SATA connector + - DDR Controller +     - Supports rates of up to 1600 MHz data-rate +     - Supports one DDR3LP UDIMM/RDIMMs, of single-, dual- or quad-rank types. + - IFC/Local Bus +     - NAND flash: 1GB 8-bit NAND flash +     - NOR: 128MB 16-bit NOR Flash + - Ethernet +     - Two on-board RGMII 10/100/1G ethernet ports. + - CPLD + - Clocks +     - System and DDR clock (SYSCLK, “DDRCLK”) +     - SERDES clocks + - Video +     - DIU supports video at up to 1280x1024x32bpp + - Power Supplies + - USB +     - Supports two USB 2.0 ports with integrated PHYs +     - Two type A ports with 5V@1.5A per port. + - SDHC +     - SDHC/SDXC connector + - SPI +    -  On-board 64MB SPI flash + - Other IO +    - Two Serial ports +    - Four I2C ports + +Memory map +----------- +The addresses in brackets are physical addresses. + +Start Address  End Address      Description                     Size +0xF_FFDF_0000  0xF_FFDF_0FFF    IFC - CPLD                      4KB +0xF_FF80_0000  0xF_FF80_FFFF    IFC - NAND Flash                64KB +0xF_FE00_0000  0xF_FEFF_FFFF    CCSRBAR                         16MB +0xF_F803_0000  0xF_F803_FFFF    PCI Express 4 I/O Space         64KB +0xF_F802_0000  0xF_F802_FFFF    PCI Express 3 I/O Space	        64KB +0xF_F801_0000  0xF_F801_FFFF    PCI Express 2 I/O Space         64KB +0xF_F800_0000  0xF_F800_FFFF    PCI Express 1 I/O Space	        64KB +0xF_F600_0000  0xF_F7FF_FFFF    Queue manager software portal   32MB +0xF_F400_0000  0xF_F5FF_FFFF    Buffer manager software portal  32MB +0xF_E800_0000  0xF_EFFF_FFFF    IFC - NOR Flash                 128MB +0xF_0000_0000  0xF_003F_FFFF    DCSR                            4MB +0xC_3000_0000  0xC_3FFF_FFFF    PCI Express 4 Mem Space         256MB +0xC_2000_0000  0xC_2FFF_FFFF    PCI Express 3 Mem Space         256MB +0xC_1000_0000  0xC_1FFF_FFFF    PCI Express 2 Mem Space         256MB +0xC_0000_0000  0xC_0FFF_FFFF    PCI Express 1 Mem Space         256MB +0x0_0000_0000  0x0_ffff_ffff    DDR                             2GB + + +NOR Flash memory Map +--------------------- + Start          End             Definition                       Size +0xEFF80000      0xEFFFFFFF      u-boot (current bank)            512KB +0xEFF60000      0xEFF7FFFF      u-boot env (current bank)        128KB +0xEFF40000      0xEFF5FFFF      FMAN Ucode (current bank)        128KB +0xED300000      0xEFF3FFFF      rootfs (alt bank)                44MB + 256KB +0xEC800000      0xEC8FFFF       Hardware device tree (alt bank)  1MB +0xEC020000      0xEC7FFFFF      Linux.uImage (alt bank)          7MB + 875KB +0xEC000000      0xEC01FFFF      RCW (alt bank)                   128KB +0xEBF80000      0xEBFFFFFF      u-boot (alt bank)                512KB +0xEBF60000      0xEBF7FFFF      u-boot env (alt bank)            128KB +0xEBF40000      0xEBF5FFFF      FMAN ucode (alt bank)            128KB +0xE9300000      0xEBF3FFFF      rootfs (current bank)            44MB + 256KB +0xE8800000      0xE88FFFFF      Hardware device tree (cur bank)  11MB + 512KB +0xE8020000      0xE86FFFFF      Linux.uImage (current bank)      7MB + 875KB +0xE8000000      0xE801FFFF      RCW (current bank)               128KB + + +Various Software configurations/environment variables/commands +-------------------------------------------------------------- +The below commands apply to the board + +1. U-boot environment variable hwconfig +   The default hwconfig is: +	hwconfig=fsl_ddr:ctlr_intlv=null,bank_intlv=cs0_cs1;usb1: +					dr_mode=host,phy_type=utmi +   Note: For USB gadget set "dr_mode=peripheral" + +2. FMAN Ucode versions +   fsl_fman_ucode_t1040.bin + +3. Switching to alternate bank +   Commands for switching to alternate bank. + +	1. To change from vbank0 to vbank4 +		=> qixis_reset altbank (it will boot using vbank4) + +	2.To change from vbank4 to vbank0 +		=> qixis reset (it will boot using vbank0) diff --git a/board/freescale/t104xrdb/ddr.c b/board/freescale/t104xrdb/ddr.c new file mode 100644 index 000000000..8f58dd683 --- /dev/null +++ b/board/freescale/t104xrdb/ddr.c @@ -0,0 +1,132 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <i2c.h> +#include <hwconfig.h> +#include <asm/mmu.h> +#include <asm/fsl_ddr_sdram.h> +#include <asm/fsl_ddr_dimm_params.h> +#include <asm/fsl_law.h> +#include "ddr.h" + +DECLARE_GLOBAL_DATA_PTR; + +int fsl_ddr_get_dimm_params(dimm_params_t *pdimm, +		unsigned int controller_number, +		unsigned int dimm_number) +{ +	const char dimm_model[] = "RAW timing DDR"; + +	if ((controller_number == 0) && (dimm_number == 0)) { +		memcpy(pdimm, &ddr_raw_timing, sizeof(dimm_params_t)); +		memset(pdimm->mpart, 0, sizeof(pdimm->mpart)); +		memcpy(pdimm->mpart, dimm_model, sizeof(dimm_model) - 1); +	} + +	return 0; +} + +void fsl_ddr_board_options(memctl_options_t *popts, +				dimm_params_t *pdimm, +				unsigned int ctrl_num) +{ +	const struct board_specific_parameters *pbsp, *pbsp_highest = NULL; +	ulong ddr_freq; + +	if (ctrl_num > 1) { +		printf("Not supported controller number %d\n", ctrl_num); +		return; +	} +	if (!pdimm->n_ranks) +		return; + +	pbsp = udimms[0]; + +	/* Get clk_adjust, cpo, write_data_delay,2t, according to the board ddr +	 * freqency and n_banks specified in board_specific_parameters table. +	 */ +	ddr_freq = get_ddr_freq(0) / 1000000; +	while (pbsp->datarate_mhz_high) { +		if (pbsp->n_ranks == pdimm->n_ranks && +		    (pdimm->rank_density >> 30) >= pbsp->rank_gb) { +			if (ddr_freq <= pbsp->datarate_mhz_high) { +				popts->cpo_override = pbsp->cpo; +				popts->write_data_delay = +					pbsp->write_data_delay; +				popts->clk_adjust = pbsp->clk_adjust; +				popts->wrlvl_start = pbsp->wrlvl_start; +				popts->wrlvl_ctl_2 = pbsp->wrlvl_ctl_2; +				popts->wrlvl_ctl_3 = pbsp->wrlvl_ctl_3; +				popts->twot_en = pbsp->force_2t; +				goto found; +			} +			pbsp_highest = pbsp; +		} +		pbsp++; +	} + +	if (pbsp_highest) { +		printf("Error: board specific timing not found\n"); +		printf("for data rate %lu MT/s\n", ddr_freq); +		printf("Trying to use the highest speed (%u) parameters\n", +		       pbsp_highest->datarate_mhz_high); +		popts->cpo_override = pbsp_highest->cpo; +		popts->write_data_delay = pbsp_highest->write_data_delay; +		popts->clk_adjust = pbsp_highest->clk_adjust; +		popts->wrlvl_start = pbsp_highest->wrlvl_start; +		popts->wrlvl_ctl_2 = pbsp->wrlvl_ctl_2; +		popts->wrlvl_ctl_3 = pbsp->wrlvl_ctl_3; +		popts->twot_en = pbsp_highest->force_2t; +	} else { +		panic("DIMM is not supported by this board"); +	} +found: +	debug("Found timing match: n_ranks %d, data rate %d, rank_gb %d\n" +		"\tclk_adjust %d, wrlvl_start %d, wrlvl_ctrl_2 0x%x, " +		"wrlvl_ctrl_3 0x%x\n", +		pbsp->n_ranks, pbsp->datarate_mhz_high, pbsp->rank_gb, +		pbsp->clk_adjust, pbsp->wrlvl_start, pbsp->wrlvl_ctl_2, +		pbsp->wrlvl_ctl_3); + +	/* +	 * Factors to consider for half-strength driver enable: +	 *	- number of DIMMs installed +	 */ +	popts->half_strength_driver_enable = 0; +	/* +	 * Write leveling override +	 */ +	popts->wrlvl_override = 1; +	popts->wrlvl_sample = 0xf; + +	/* +	 * rtt and rtt_wr override +	 */ +	popts->rtt_override = 0; + +	/* Enable ZQ calibration */ +	popts->zq_en = 1; + +	/* DHC_EN =1, ODT = 75 Ohm */ +	popts->ddr_cdr1 = DDR_CDR1_DHC_EN | DDR_CDR1_ODT(DDR_CDR_ODT_75ohm); +	popts->ddr_cdr2 = DDR_CDR2_ODT(DDR_CDR_ODT_75ohm); +} + +phys_size_t initdram(int board_type) +{ +	phys_size_t dram_size; + +	puts("Initializing....using SPD\n"); + +	dram_size = fsl_ddr_sdram(); + +	dram_size = setup_ddr_tlbs(dram_size / 0x100000); +	dram_size *= 0x100000; + +	puts("    DDR: "); +	return dram_size; +} diff --git a/board/freescale/t104xrdb/ddr.h b/board/freescale/t104xrdb/ddr.h new file mode 100644 index 000000000..9276b596a --- /dev/null +++ b/board/freescale/t104xrdb/ddr.h @@ -0,0 +1,76 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef __DDR_H__ +#define __DDR_H__ + +dimm_params_t ddr_raw_timing = { +	.n_ranks = 2, +	.rank_density = 2147483648u, +	.capacity = 4294967296u, +	.primary_sdram_width = 64, +	.ec_sdram_width = 8, +	.registered_dimm = 0, +	.mirrored_dimm = 1, +	.n_row_addr = 15, +	.n_col_addr = 10, +	.n_banks_per_sdram_device = 8, +	.edc_config = 2,	/* ECC */ +	.burst_lengths_bitmask = 0x0c, + +	.tckmin_x_ps = 1071, +	.caslat_x = 0x2fe << 4,	/* 5,6,7,8,9,10,11,13 */ +	.taa_ps = 13910, +	.twr_ps = 15000, +	.trcd_ps = 13910, +	.trrd_ps = 6000, +	.trp_ps = 13910, +	.tras_ps = 34000, +	.trc_ps = 48910, +	.trfc_ps = 260000, +	.twtr_ps = 7500, +	.trtp_ps = 7500, +	.refresh_rate_ps = 7800000, +	.tfaw_ps = 35000, +}; + +struct board_specific_parameters { +	u32 n_ranks; +	u32 datarate_mhz_high; +	u32 rank_gb; +	u32 clk_adjust; +	u32 wrlvl_start; +	u32 wrlvl_ctl_2; +	u32 wrlvl_ctl_3; +	u32 cpo; +	u32 write_data_delay; +	u32 force_2t; +}; + +/* + * These tables contain all valid speeds we want to override with board + * specific parameters. datarate_mhz_high values need to be in ascending order + * for each n_ranks group. + */ + +static const struct board_specific_parameters udimm0[] = { +	/* +	 * memory controller 0 +	 *   num|  hi| rank|  clk| wrlvl |   wrlvl   |  wrlvl | cpo  |wrdata|2T +	 * ranks| mhz| GB  |adjst| start |   ctl2    |  ctl3  |      |delay | +	 */ +	{2,  1066, 4, 8,     4, 0x05070609, 0x08090a08,   0xff,    2,  0}, +	{2,  1350, 4, 4,     8, 0x0809090b, 0x0c0c0d0a,   0xff,    2,  0}, +	{2,  1350, 0, 5,     7, 0x0709090b, 0x0c0c0d09,   0xff,    2,  0}, +	{2,  1666, 4, 4,     8, 0x080a0a0d, 0x0d10100b,   0xff,    2,  0}, +	{2,  1666, 0, 5,     7, 0x080a0a0c, 0x0d0d0e0a,   0xff,    2,  0}, +	{} +}; + +static const struct board_specific_parameters *udimms[] = { +	udimm0, +}; +#endif diff --git a/board/freescale/t104xrdb/law.c b/board/freescale/t104xrdb/law.c new file mode 100644 index 000000000..2362d4324 --- /dev/null +++ b/board/freescale/t104xrdb/law.c @@ -0,0 +1,32 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/fsl_law.h> +#include <asm/mmu.h> + +struct law_entry law_table[] = { +#ifndef CONFIG_SYS_NO_FLASH +	SET_LAW(CONFIG_SYS_FLASH_BASE_PHYS, LAW_SIZE_256M, LAW_TRGT_IF_IFC), +#endif +#ifdef CONFIG_SYS_BMAN_MEM_PHYS +	SET_LAW(CONFIG_SYS_BMAN_MEM_PHYS, LAW_SIZE_32M, LAW_TRGT_IF_BMAN), +#endif +#ifdef CONFIG_SYS_QMAN_MEM_PHYS +	SET_LAW(CONFIG_SYS_QMAN_MEM_PHYS, LAW_SIZE_32M, LAW_TRGT_IF_QMAN), +#endif +#ifdef CONFIG_SYS_CPLD_BASE_PHYS +	SET_LAW(CONFIG_SYS_CPLD_BASE_PHYS, LAW_SIZE_128K, LAW_TRGT_IF_IFC), +#endif +#ifdef CONFIG_SYS_DCSRBAR_PHYS +	SET_LAW(CONFIG_SYS_DCSRBAR_PHYS, LAW_SIZE_4M, LAW_TRGT_IF_DCSR), +#endif +#ifdef CONFIG_SYS_NAND_BASE_PHYS +	SET_LAW(CONFIG_SYS_NAND_BASE_PHYS, LAW_SIZE_64K, LAW_TRGT_IF_IFC), +#endif +}; + +int num_law_entries = ARRAY_SIZE(law_table); diff --git a/board/freescale/t104xrdb/pci.c b/board/freescale/t104xrdb/pci.c new file mode 100644 index 000000000..c53e3b76a --- /dev/null +++ b/board/freescale/t104xrdb/pci.c @@ -0,0 +1,23 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <command.h> +#include <pci.h> +#include <asm/fsl_pci.h> +#include <libfdt.h> +#include <fdt_support.h> +#include <asm/fsl_serdes.h> + +void pci_init_board(void) +{ +	fsl_pcie_init_board(0); +} + +void pci_of_setup(void *blob, bd_t *bd) +{ +	FT_FSL_PCI_SETUP; +} diff --git a/board/freescale/t104xrdb/t104xrdb.c b/board/freescale/t104xrdb/t104xrdb.c new file mode 100644 index 000000000..6e29d6410 --- /dev/null +++ b/board/freescale/t104xrdb/t104xrdb.c @@ -0,0 +1,93 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <command.h> +#include <netdev.h> +#include <linux/compiler.h> +#include <asm/mmu.h> +#include <asm/processor.h> +#include <asm/cache.h> +#include <asm/immap_85xx.h> +#include <asm/fsl_law.h> +#include <asm/fsl_serdes.h> +#include <asm/fsl_portals.h> +#include <asm/fsl_liodn.h> +#include <fm_eth.h> + +#include "t104xrdb.h" + +DECLARE_GLOBAL_DATA_PTR; + +int checkboard(void) +{ +	struct cpu_type *cpu = gd->arch.cpu; + +	printf("Board: %sRDB\n", cpu->name); +	return 0; +} + +int board_early_init_r(void) +{ +#ifdef CONFIG_SYS_FLASH_BASE +	const unsigned int flashbase = CONFIG_SYS_FLASH_BASE; +	const u8 flash_esel = find_tlb_idx((void *)flashbase, 1); + +	/* +	 * Remap Boot flash region to caching-inhibited +	 * so that flash can be erased properly. +	 */ + +	/* Flush d-cache and invalidate i-cache of any FLASH data */ +	flush_dcache(); +	invalidate_icache(); + +	/* invalidate existing TLB entry for flash */ +	disable_tlb(flash_esel); + +	set_tlb(1, flashbase, CONFIG_SYS_FLASH_BASE_PHYS, +		MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		0, flash_esel, BOOKE_PAGESZ_256M, 1); +#endif +	set_liodns(); +#ifdef CONFIG_SYS_DPAA_QBMAN +	setup_portals(); +#endif + +	return 0; +} + +int misc_init_r(void) +{ +	return 0; +} + +void ft_board_setup(void *blob, bd_t *bd) +{ +	phys_addr_t base; +	phys_size_t size; + +	ft_cpu_setup(blob, bd); + +	base = getenv_bootm_low(); +	size = getenv_bootm_size(); + +	fdt_fixup_memory(blob, (u64)base, (u64)size); + +#ifdef CONFIG_PCI +	pci_of_setup(blob, bd); +#endif + +	fdt_fixup_liodn(blob); + +#ifdef CONFIG_HAS_FSL_DR_USB +	fdt_fixup_dr_usb(blob, bd); +#endif + +#ifdef CONFIG_SYS_DPAA_FMAN +	fdt_fixup_fman_ethernet(blob); +#endif +} diff --git a/board/freescale/t104xrdb/t104xrdb.h b/board/freescale/t104xrdb/t104xrdb.h new file mode 100644 index 000000000..e7cc0c7b5 --- /dev/null +++ b/board/freescale/t104xrdb/t104xrdb.h @@ -0,0 +1,13 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef __T104x_RDB_H__ +#define __T104x_RDB_H__ + +void fdt_fixup_board_enet(void *blob); +void pci_of_setup(void *blob, bd_t *bd); + +#endif diff --git a/board/freescale/t104xrdb/tlb.c b/board/freescale/t104xrdb/tlb.c new file mode 100644 index 000000000..84f97a41e --- /dev/null +++ b/board/freescale/t104xrdb/tlb.c @@ -0,0 +1,107 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/mmu.h> + +struct fsl_e_tlb_entry tlb_table[] = { +	/* TLB 0 - for temp stack in cache */ +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR, +		      CONFIG_SYS_INIT_RAM_ADDR_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 4 * 1024, +		      CONFIG_SYS_INIT_RAM_ADDR_PHYS + 4 * 1024, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 8 * 1024, +		      CONFIG_SYS_INIT_RAM_ADDR_PHYS + 8 * 1024, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 0, BOOKE_PAGESZ_4K, 0), +	SET_TLB_ENTRY(0, CONFIG_SYS_INIT_RAM_ADDR + 12 * 1024, +		      CONFIG_SYS_INIT_RAM_ADDR_PHYS + 12 * 1024, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 0, BOOKE_PAGESZ_4K, 0), + +	/* TLB 1 */ +	/* *I*** - Covers boot page */ +#if defined(CONFIG_SYS_RAMBOOT) && defined(CONFIG_SYS_INIT_L3_ADDR) +	/* +	 * *I*G - L3SRAM. When L3 is used as 256K SRAM, the address of the +	 * SRAM is at 0xfffc0000, it covered the 0xfffff000. +	 */ +	SET_TLB_ENTRY(1, CONFIG_SYS_INIT_L3_ADDR, CONFIG_SYS_INIT_L3_ADDR, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 0, BOOKE_PAGESZ_256K, 1), +#else +	SET_TLB_ENTRY(1, 0xfffff000, 0xfffff000, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 0, BOOKE_PAGESZ_4K, 1), +#endif + +	/* *I*G* - CCSRBAR */ +	SET_TLB_ENTRY(1, CONFIG_SYS_CCSRBAR, CONFIG_SYS_CCSRBAR_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 1, BOOKE_PAGESZ_16M, 1), + +	/* *I*G* - Flash, localbus */ +	/* This will be changed to *I*G* after relocation to RAM. */ +	SET_TLB_ENTRY(1, CONFIG_SYS_FLASH_BASE, CONFIG_SYS_FLASH_BASE_PHYS, +		      MAS3_SX|MAS3_SR, MAS2_W|MAS2_G, +		      0, 2, BOOKE_PAGESZ_256M, 1), + +	/* *I*G* - PCI */ +	SET_TLB_ENTRY(1, CONFIG_SYS_PCIE1_MEM_VIRT, CONFIG_SYS_PCIE1_MEM_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 3, BOOKE_PAGESZ_1G, 1), + +	/* *I*G* - PCI I/O */ +	SET_TLB_ENTRY(1, CONFIG_SYS_PCIE1_IO_VIRT, CONFIG_SYS_PCIE1_IO_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 4, BOOKE_PAGESZ_256K, 1), + +	/* Bman/Qman */ +#ifdef CONFIG_SYS_BMAN_MEM_PHYS +	SET_TLB_ENTRY(1, CONFIG_SYS_BMAN_MEM_BASE, CONFIG_SYS_BMAN_MEM_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 5, BOOKE_PAGESZ_16M, 1), +	SET_TLB_ENTRY(1, CONFIG_SYS_BMAN_MEM_BASE + 0x01000000, +		      CONFIG_SYS_BMAN_MEM_PHYS + 0x01000000, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 6, BOOKE_PAGESZ_16M, 1), +#endif +#ifdef CONFIG_SYS_QMAN_MEM_PHYS +	SET_TLB_ENTRY(1, CONFIG_SYS_QMAN_MEM_BASE, CONFIG_SYS_QMAN_MEM_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, 0, +		      0, 7, BOOKE_PAGESZ_16M, 1), +	SET_TLB_ENTRY(1, CONFIG_SYS_QMAN_MEM_BASE + 0x01000000, +		      CONFIG_SYS_QMAN_MEM_PHYS + 0x01000000, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 8, BOOKE_PAGESZ_16M, 1), +#endif +#ifdef CONFIG_SYS_DCSRBAR_PHYS +	SET_TLB_ENTRY(1, CONFIG_SYS_DCSRBAR, CONFIG_SYS_DCSRBAR_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 9, BOOKE_PAGESZ_4M, 1), +#endif +#ifdef CONFIG_SYS_NAND_BASE +	/* +	 * *I*G - NAND +	 * entry 14 and 15 has been used hard coded, they will be disabled +	 * in cpu_init_f, so we use entry 16 for nand. +	 */ +	SET_TLB_ENTRY(1, CONFIG_SYS_NAND_BASE, CONFIG_SYS_NAND_BASE_PHYS, +		      MAS3_SX|MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 10, BOOKE_PAGESZ_64K, 1), +#endif +#ifdef CONFIG_SYS_CPLD_BASE +	SET_TLB_ENTRY(1, CONFIG_SYS_CPLD_BASE, CONFIG_SYS_CPLD_BASE_PHYS, +		      MAS3_SW|MAS3_SR, MAS2_I|MAS2_G, +		      0, 11, BOOKE_PAGESZ_256K, 1), +#endif +}; + +int num_tlb_entries = ARRAY_SIZE(tlb_table); diff --git a/board/gaisler/gr_cpci_ax2000/config.mk b/board/gaisler/gr_cpci_ax2000/config.mk index e9c60286c..309c87948 100644 --- a/board/gaisler/gr_cpci_ax2000/config.mk +++ b/board/gaisler/gr_cpci_ax2000/config.mk @@ -18,5 +18,4 @@ CONFIG_SYS_TEXT_BASE = 0x00000000  # U-BOOT IN SDRAM  #CONFIG_SYS_TEXT_BASE = 0x60000000 -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \ -	-I$(TOPDIR)/board +PLATFORM_CPPFLAGS += -I$(TOPDIR)/board diff --git a/board/gaisler/gr_ep2s60/config.mk b/board/gaisler/gr_ep2s60/config.mk index 6c31a17f8..d57efae15 100644 --- a/board/gaisler/gr_ep2s60/config.mk +++ b/board/gaisler/gr_ep2s60/config.mk @@ -16,5 +16,4 @@ CONFIG_SYS_TEXT_BASE = 0x00000000  # U-BOOT IN SDRAM  #CONFIG_SYS_TEXT_BASE = 0x40000000 -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \ -	-I$(TOPDIR)/board +PLATFORM_CPPFLAGS += -I$(TOPDIR)/board diff --git a/board/gaisler/gr_xc3s_1500/config.mk b/board/gaisler/gr_xc3s_1500/config.mk index 3b59cca5e..e87320be9 100644 --- a/board/gaisler/gr_xc3s_1500/config.mk +++ b/board/gaisler/gr_xc3s_1500/config.mk @@ -15,5 +15,4 @@ CONFIG_SYS_TEXT_BASE = 0x00000000  # U-BOOT IN RAM  #CONFIG_SYS_TEXT_BASE = 0x40000000 -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \ -	-I$(TOPDIR)/board +PLATFORM_CPPFLAGS += -I$(TOPDIR)/board diff --git a/board/gaisler/grsim/config.mk b/board/gaisler/grsim/config.mk index d98ed54c0..df26f82c9 100644 --- a/board/gaisler/grsim/config.mk +++ b/board/gaisler/grsim/config.mk @@ -15,5 +15,4 @@ CONFIG_SYS_TEXT_BASE = 0x00000000  # U-BOOT IN RAM  #CONFIG_SYS_TEXT_BASE = 0x40000000 -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \ -	-I$(TOPDIR)/board +PLATFORM_CPPFLAGS += -I$(TOPDIR)/board diff --git a/board/gaisler/grsim_leon2/config.mk b/board/gaisler/grsim_leon2/config.mk index 59e4e3169..99f9a6872 100644 --- a/board/gaisler/grsim_leon2/config.mk +++ b/board/gaisler/grsim_leon2/config.mk @@ -15,5 +15,4 @@ CONFIG_SYS_TEXT_BASE = 0x00000000  # RUN U-BOOT FROM RAM  #CONFIG_SYS_TEXT_BASE = 0x40000000 -PLATFORM_CPPFLAGS += -DCONFIG_SYS_TEXT_BASE=$(CONFIG_SYS_TEXT_BASE) \ -	-I$(TOPDIR)/board +PLATFORM_CPPFLAGS += -I$(TOPDIR)/board diff --git a/board/genietv/u-boot.lds b/board/genietv/u-boot.lds index e217f0681..70ab702fd 100644 --- a/board/genietv/u-boot.lds +++ b/board/genietv/u-boot.lds @@ -18,11 +18,11 @@ SECTIONS      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    lib/libgeneric.o			(.text*) -    net/libnet.o			(.text*) -    arch/powerpc/cpu/mpc8xx/libmpc8xx.o	(.text*) -    board/genietv/libgenietv.o		(.text*) -    arch/powerpc/lib/libpowerpc.o	(.text*) +    lib/built-in.o			(.text*) +    net/built-in.o			(.text*) +    arch/powerpc/cpu/mpc8xx/built-in.o	(.text*) +    board/genietv/built-in.o		(.text*) +    arch/powerpc/lib/built-in.o		(.text*)      *(.text.do_load_serial*)      *(.text.do_mem_*)      *(.text.do_bootm*) diff --git a/board/hermes/u-boot.lds b/board/hermes/u-boot.lds index 9419f83a7..030986039 100644 --- a/board/hermes/u-boot.lds +++ b/board/hermes/u-boot.lds @@ -17,7 +17,7 @@ SECTIONS      /* the sector layout of our flash chips!	XXX FIXME XXX	*/      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    board/hermes/libhermes.o		(.text*) +    board/hermes/built-in.o		(.text*)      . = env_offset;      common/env_embedded.o		(.text*) diff --git a/board/keymile/km82xx/Makefile b/board/keymile/km82xx/Makefile index b44582fbe..20f193ab1 100644 --- a/board/keymile/km82xx/Makefile +++ b/board/keymile/km82xx/Makefile @@ -5,7 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif  obj-y	:= km82xx.o ../common/common.o ../common/ivm.o diff --git a/board/keymile/km83xx/Makefile b/board/keymile/km83xx/Makefile index 7bdddf3bc..6c3268853 100644 --- a/board/keymile/km83xx/Makefile +++ b/board/keymile/km83xx/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	+= km83xx.o ../common/common.o ../common/ivm.o km83xx_i2c.o diff --git a/board/keymile/km_arm/Makefile b/board/keymile/km_arm/Makefile index 32eaa9357..a17d8d963 100644 --- a/board/keymile/km_arm/Makefile +++ b/board/keymile/km_arm/Makefile @@ -6,10 +6,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= km_arm.o ../common/common.o ../common/ivm.o  ifdef CONFIG_KM_FPGA_CONFIG diff --git a/board/keymile/kmp204x/Makefile b/board/keymile/kmp204x/Makefile index 64eb37c9d..3e69ee2f1 100644 --- a/board/keymile/kmp204x/Makefile +++ b/board/keymile/kmp204x/Makefile @@ -8,9 +8,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif - -obj-y	:= $(BOARD).o ddr.o eth.o tlb.o pci.o law.o \ +obj-y	:= kmp204x.o ddr.o eth.o tlb.o pci.o law.o \  	../common/common.o ../common/ivm.o diff --git a/board/kmc/kzm9g/kzm9g.c b/board/kmc/kzm9g/kzm9g.c index b669ffefe..ea36fa4e1 100644 --- a/board/kmc/kzm9g/kzm9g.c +++ b/board/kmc/kzm9g/kzm9g.c @@ -289,7 +289,6 @@ void adjust_core_voltage(void)  {  	u8 data; -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);  	data = 0x35;  	i2c_set_bus_num(0);  	i2c_write(0x40, 3, 1, &data, 1); diff --git a/board/kup/kup4k/Makefile b/board/kup/kup4k/Makefile index b3ad86ce1..c896fcd64 100644 --- a/board/kup/kup4k/Makefile +++ b/board/kup/kup4k/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= kup4k.o ../common/flash.o ../common/kup.o ../common/load_sernum_ethaddr.o ../common/pcmcia.o diff --git a/board/kup/kup4x/Makefile b/board/kup/kup4x/Makefile index 05a1afc3a..6945943d0 100644 --- a/board/kup/kup4x/Makefile +++ b/board/kup/kup4x/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= kup4x.o ../common/flash.o ../common/kup.o ../common/load_sernum_ethaddr.o ../common/pcmcia.o diff --git a/board/logicpd/am3517evm/am3517evm.c b/board/logicpd/am3517evm/am3517evm.c index b6c68da7a..156990546 100644 --- a/board/logicpd/am3517evm/am3517evm.c +++ b/board/logicpd/am3517evm/am3517evm.c @@ -98,8 +98,8 @@ static void am3517_evm_musb_init(void)   */  int misc_init_r(void)  { -#ifdef CONFIG_DRIVER_OMAP34XX_I2C -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +#ifdef CONFIG_SYS_I2C_OMAP34XX +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  #endif  	dieid_num_r(); diff --git a/board/matrix_vision/mvsmr/u-boot.lds b/board/matrix_vision/mvsmr/u-boot.lds index 08ce014aa..e885b7c16 100644 --- a/board/matrix_vision/mvsmr/u-boot.lds +++ b/board/matrix_vision/mvsmr/u-boot.lds @@ -18,7 +18,7 @@ SECTIONS      /* the first two sectors (=8KB) of our S29GL flash chip */      arch/powerpc/cpu/mpc5xxx/start.o	(.text*)      arch/powerpc/cpu/mpc5xxx/traps.o	(.text*) -    board/matrix_vision/common/libmatrix_vision.o (.text*) +    board/matrix_vision/common/built-in.o	(.text*)      /* This is only needed to force failure if size of above code will ever */      /* increase and grow into reserved space. */ diff --git a/board/mpl/mip405/Makefile b/board/mpl/mip405/Makefile index 509eb591b..5bcf13050 100644 --- a/board/mpl/mip405/Makefile +++ b/board/mpl/mip405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= mip405.o cmd_mip405.o \  		../common/pci.o \  		../common/usb_uhci.o \ diff --git a/board/mpl/pati/Makefile b/board/mpl/pati/Makefile index 67381c108..982208261 100644 --- a/board/mpl/pati/Makefile +++ b/board/mpl/pati/Makefile @@ -5,9 +5,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:=  pati.o cmd_pati.o \  		../common/common_util.o diff --git a/board/mpl/pip405/Makefile b/board/mpl/pip405/Makefile index 3d73cc3f8..0a3d059e9 100644 --- a/board/mpl/pip405/Makefile +++ b/board/mpl/pip405/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	= pip405.o cmd_pip405.o \  		../common/pci.o \  		../common/isa.o \ diff --git a/board/mpl/vcma9/Makefile b/board/mpl/vcma9/Makefile index e0e96691c..175a19fa3 100644 --- a/board/mpl/vcma9/Makefile +++ b/board/mpl/vcma9/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= ../common/common_util.o  obj-y	+= vcma9.o cmd_vcma9.o diff --git a/board/mvblue/u-boot.lds b/board/mvblue/u-boot.lds index 121354bfe..5034a9675 100644 --- a/board/mvblue/u-boot.lds +++ b/board/mvblue/u-boot.lds @@ -14,12 +14,12 @@ SECTIONS    .text      :    {      arch/powerpc/cpu/mpc824x/start.o		(.text*) -    lib/libgeneric.o				(.text*) -    net/libnet.o				(.text*) -    drivers/pci/libpci.o			(.text*) -    arch/powerpc/cpu/mpc824x/libmpc824x.o	(.text*) -    board/mvblue/libmvblue.o			(.text*) -    arch/powerpc/lib/libpowerpc.o		(.text*) +    lib/built-in.o				(.text*) +    net/built-in.o				(.text*) +    drivers/pci/built-in.o			(.text*) +    arch/powerpc/cpu/mpc824x/built-in.o		(.text*) +    board/mvblue/built-in.o			(.text*) +    arch/powerpc/lib/built-in.o			(.text*)      . = DEFINED(env_offset) ? env_offset : .;      common/env_embedded.o	(.ppcenv*) diff --git a/board/nvidia/beaver/Makefile b/board/nvidia/beaver/Makefile index f828f52c2..1f7c31d64 100644 --- a/board/nvidia/beaver/Makefile +++ b/board/nvidia/beaver/Makefile @@ -14,6 +14,4 @@  # along with this program.  If not, see <http://www.gnu.org/licenses/>.  # -$(shell mkdir -p $(obj)../cardhu) -  obj-y	= ../cardhu/cardhu.o diff --git a/board/nvidia/ventana/Makefile b/board/nvidia/ventana/Makefile index 7265cfccc..f67044f2c 100644 --- a/board/nvidia/ventana/Makefile +++ b/board/nvidia/ventana/Makefile @@ -5,6 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)../seaboard) -  obj-y	= ../seaboard/seaboard.o diff --git a/board/overo/overo.c b/board/overo/overo.c index aace42a8b..9ac35d2f4 100644 --- a/board/overo/overo.c +++ b/board/overo/overo.c @@ -92,7 +92,7 @@ int get_board_revision(void)  {  	int revision; -#ifdef CONFIG_DRIVER_OMAP34XX_I2C +#ifdef CONFIG_SYS_I2C_OMAP34XX  	unsigned char data;  	/* board revisions <= R2410 connect 4030 irq_1 to gpio112             */ diff --git a/board/phytec/pcm051/board.c b/board/phytec/pcm051/board.c index dafb1eb8e..034886ad5 100644 --- a/board/phytec/pcm051/board.c +++ b/board/phytec/pcm051/board.c @@ -91,7 +91,7 @@ void set_mux_conf_regs(void)  {  	/* Initalize the board header */  	enable_i2c0_pin_mux(); -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  	enable_board_pin_mux();  } @@ -108,7 +108,7 @@ void sdram_init(void)   */  int board_init(void)  { -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  	gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE + 0x100; diff --git a/board/prodrive/p3mx/Makefile b/board/prodrive/p3mx/Makefile index 43caffbc2..6ddda2296 100644 --- a/board/prodrive/p3mx/Makefile +++ b/board/prodrive/p3mx/Makefile @@ -5,10 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../../Marvell/common) -endif -  obj-y	= misc.o  obj-y	+= p3mx.o mpsc.o mv_eth.o pci.o sdram_init.o serial.o \  		../../Marvell/common/i2c.o ../../Marvell/common/memory.o diff --git a/board/psyent/pci5441/Makefile b/board/psyent/pci5441/Makefile index 9a66cfdfe..364f163e4 100644 --- a/board/psyent/pci5441/Makefile +++ b/board/psyent/pci5441/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= pci5441.o ../common/AMDLV065D.o diff --git a/board/psyent/pci5441/config.mk b/board/psyent/pci5441/config.mk index 00ff743c9..776fa8ab4 100644 --- a/board/psyent/pci5441/config.mk +++ b/board/psyent/pci5441/config.mk @@ -8,7 +8,6 @@  CONFIG_SYS_TEXT_BASE = 0x018e0000  PLATFORM_CPPFLAGS += -mno-hw-div -mno-hw-mul -PLATFORM_CPPFLAGS += -I$(TOPDIR)/board/$(VENDOR)/include  ifeq ($(debug),1)  PLATFORM_CPPFLAGS += -DDEBUG diff --git a/board/psyent/pk1c20/Makefile b/board/psyent/pk1c20/Makefile index 286db94ae..5450f93ac 100644 --- a/board/psyent/pk1c20/Makefile +++ b/board/psyent/pk1c20/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  obj-y	:= pk1c20.o led.o ../common/AMDLV065D.o diff --git a/board/psyent/pk1c20/config.mk b/board/psyent/pk1c20/config.mk index 7b0810a30..83cfadc11 100644 --- a/board/psyent/pk1c20/config.mk +++ b/board/psyent/pk1c20/config.mk @@ -8,7 +8,6 @@  CONFIG_SYS_TEXT_BASE = 0x01fc0000  PLATFORM_CPPFLAGS += -mno-hw-div -mno-hw-mul -PLATFORM_CPPFLAGS += -I$(TOPDIR)/board/$(VENDOR)/include  ifeq ($(debug),1)  PLATFORM_CPPFLAGS += -DDEBUG diff --git a/board/rbc823/u-boot.lds b/board/rbc823/u-boot.lds index 191f9eb83..7676cf43b 100644 --- a/board/rbc823/u-boot.lds +++ b/board/rbc823/u-boot.lds @@ -19,10 +19,10 @@ SECTIONS      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    lib/libgeneric.o			(.text*) -    net/libnet.o			(.text*) -    arch/powerpc/cpu/mpc8xx/libmpc8xx.o	(.text*) -    arch/powerpc/lib/libpowerpc.o	(.text*) +    lib/built-in.o			(.text*) +    net/built-in.o			(.text*) +    arch/powerpc/cpu/mpc8xx/built-in.o	(.text*) +    arch/powerpc/lib/built-in.o		(.text*)      . = env_offset;      common/env_embedded.o		(.text*) diff --git a/board/renesas/ecovec/ecovec.c b/board/renesas/ecovec/ecovec.c index e2d365a18..fb4acf364 100644 --- a/board/renesas/ecovec/ecovec.c +++ b/board/renesas/ecovec/ecovec.c @@ -57,8 +57,7 @@ int board_late_init(void)  	outl(inl(MSTPCR2) & ~0x10000000, MSTPCR2); -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); -	i2c_set_bus_num(CONFIG_SYS_I2C_MODULE); /* Use I2C 1 */ +	i2c_set_bus_num(1); /* Use I2C 1 */  	/* Read MAC address */  	i2c_read(0x50, 0x10, 0, mac, 6); diff --git a/board/sandburst/karef/Makefile b/board/sandburst/karef/Makefile index 05c818791..f890008be 100644 --- a/board/sandburst/karef/Makefile +++ b/board/sandburst/karef/Makefile @@ -9,10 +9,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  # TBS: add for debugging purposes  BUILDUSER := $(shell whoami)  FORCEBUILD := $(shell rm -f karef.o) diff --git a/board/sandburst/metrobox/Makefile b/board/sandburst/metrobox/Makefile index 76dfffc9c..37d91a51a 100644 --- a/board/sandburst/metrobox/Makefile +++ b/board/sandburst/metrobox/Makefile @@ -8,10 +8,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  # TBS: add for debugging purposes  BUILDUSER := $(shell whoami)  FORCEBUILD := $(shell rm -f metrobox.o) diff --git a/board/siemens/common/board.c b/board/siemens/common/board.c index 6279c3281..32d2ee4de 100644 --- a/board/siemens/common/board.c +++ b/board/siemens/common/board.c @@ -42,7 +42,7 @@ void set_mux_conf_regs(void)  {  	/* Initalize the board header */  	enable_i2c0_pin_mux(); -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +	i2c_set_bus_num(0);  	if (read_eeprom() < 0)  		puts("Could not get board ID.\n"); @@ -67,7 +67,7 @@ int board_init(void)  #if defined(CONFIG_HW_WATCHDOG)  	hw_watchdog_init();  #endif /* defined(CONFIG_HW_WATCHDOG) */ -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +	i2c_set_bus_num(0);  	if (read_eeprom() < 0)  		puts("Could not get board ID.\n"); diff --git a/board/siemens/dxr2/Makefile b/board/siemens/dxr2/Makefile index 5129c6e3b..f15993216 100644 --- a/board/siemens/dxr2/Makefile +++ b/board/siemens/dxr2/Makefile @@ -11,10 +11,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  ifdef CONFIG_SPL_BUILD  obj-y	:= mux.o  endif diff --git a/board/siemens/pxm2/Makefile b/board/siemens/pxm2/Makefile index 5129c6e3b..f15993216 100644 --- a/board/siemens/pxm2/Makefile +++ b/board/siemens/pxm2/Makefile @@ -11,10 +11,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  ifdef CONFIG_SPL_BUILD  obj-y	:= mux.o  endif diff --git a/board/siemens/rut/Makefile b/board/siemens/rut/Makefile index 5129c6e3b..f15993216 100644 --- a/board/siemens/rut/Makefile +++ b/board/siemens/rut/Makefile @@ -11,10 +11,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../common) -endif -  ifdef CONFIG_SPL_BUILD  obj-y	:= mux.o  endif diff --git a/board/spd8xx/u-boot.lds b/board/spd8xx/u-boot.lds index 2a68934c3..463af7eaa 100644 --- a/board/spd8xx/u-boot.lds +++ b/board/spd8xx/u-boot.lds @@ -18,8 +18,8 @@ SECTIONS      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    net/libnet.o			(.text*) -    arch/powerpc/cpu/mpc8xx/libmpc8xx.o	(.text*) +    net/built-in.o			(.text*) +    arch/powerpc/cpu/mpc8xx/built-in.o	(.text*)      *(.text.v*printf)      . = DEFINED(env_offset) ? env_offset : .; diff --git a/board/svm_sc8xx/u-boot.lds b/board/svm_sc8xx/u-boot.lds index 49226251b..df564e939 100644 --- a/board/svm_sc8xx/u-boot.lds +++ b/board/svm_sc8xx/u-boot.lds @@ -17,11 +17,11 @@ SECTIONS      /* the sector layout of our flash chips!	XXX FIXME XXX	*/      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    lib/libgeneric.o			(.text*) -    net/libnet.o			(.text*) -    arch/powerpc/cpu/mpc8xx/libmpc8xx.o	(.text*) -    arch/powerpc/lib/libpowerpc.o	(.text*) -    board/svm_sc8xx/libsvm_sc8xx.o	(.text*) +    lib/built-in.o			(.text*) +    net/built-in.o			(.text*) +    arch/powerpc/cpu/mpc8xx/built-in.o	(.text*) +    arch/powerpc/lib/built-in.o		(.text*) +    board/svm_sc8xx/built-in.o		(.text*)      *(.text.*printf)      *(.text.do_mem_*)      *(.text.flash*) diff --git a/board/ti/am335x/board.c b/board/ti/am335x/board.c index 57fedab34..8edd21b11 100644 --- a/board/ti/am335x/board.c +++ b/board/ti/am335x/board.c @@ -397,7 +397,7 @@ const struct dpll_params *get_dpll_ddr_params(void)  	struct am335x_baseboard_id header;  	enable_i2c0_pin_mux(); -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  	if (read_eeprom(&header) < 0)  		puts("Could not get board ID.\n"); diff --git a/board/ti/am335x/u-boot.lds b/board/ti/am335x/u-boot.lds index a173f620e..e77a501f5 100644 --- a/board/ti/am335x/u-boot.lds +++ b/board/ti/am335x/u-boot.lds @@ -35,7 +35,7 @@ SECTIONS  	{  		*(.__image_copy_start)  		CPUDIR/start.o (.text*) -		board/ti/am335x/libam335x.o (.text*) +		board/ti/am335x/built-in.o (.text*)  		*(.text*)  	} diff --git a/board/ti/am3517crane/am3517crane.c b/board/ti/am3517crane/am3517crane.c index 5eb97ff37..a64969725 100644 --- a/board/ti/am3517crane/am3517crane.c +++ b/board/ti/am3517crane/am3517crane.c @@ -43,8 +43,8 @@ int board_init(void)   */  int misc_init_r(void)  { -#ifdef CONFIG_DRIVER_OMAP34XX_I2C -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +#ifdef CONFIG_SYS_I2C_OMAP34XX +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  #endif  	dieid_num_r(); diff --git a/board/ti/beagle/Makefile b/board/ti/beagle/Makefile index 9f55e8f35..7a858be5e 100644 --- a/board/ti/beagle/Makefile +++ b/board/ti/beagle/Makefile @@ -5,5 +5,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-y	:= $(BOARD).o +obj-y	:= beagle.o  obj-$(CONFIG_STATUS_LED) += led.o diff --git a/board/ti/evm/evm.c b/board/ti/evm/evm.c index c71c21852..81dd081d7 100644 --- a/board/ti/evm/evm.c +++ b/board/ti/evm/evm.c @@ -146,8 +146,8 @@ void get_board_mem_timings(struct board_sdrc_timings *timings)  int misc_init_r(void)  { -#ifdef CONFIG_DRIVER_OMAP34XX_I2C -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +#ifdef CONFIG_SYS_I2C_OMAP34XX +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE);  #endif  #if defined(CONFIG_CMD_NET) diff --git a/board/toradex/colibri_t20_iris/Makefile b/board/toradex/colibri_t20_iris/Makefile index 7ca3fe596..ebeac70ea 100644 --- a/board/toradex/colibri_t20_iris/Makefile +++ b/board/toradex/colibri_t20_iris/Makefile @@ -4,9 +4,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)../../nvidia/common) -$(shell mkdir -p $(obj)../colibri_t20-common) -  obj-y	:= ../../nvidia/common/board.o  obj-y	+= ../colibri_t20-common/colibri_t20-common.o  obj-y	+= colibri_t20_iris.o diff --git a/board/tqc/tqm8260/Makefile b/board/tqc/tqm8260/Makefile index dc4a52808..6b8573d9a 100644 --- a/board/tqc/tqm8260/Makefile +++ b/board/tqc/tqm8260/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../tqm8xx/) -endif -  obj-y	= tqm8260.o ../tqm8xx/load_sernum_ethaddr.o diff --git a/board/tqc/tqm8272/Makefile b/board/tqc/tqm8272/Makefile index 09af765f0..8bf02414e 100644 --- a/board/tqc/tqm8272/Makefile +++ b/board/tqc/tqm8272/Makefile @@ -5,8 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../tqm8xx/) -endif -  obj-y	= tqm8272.o ../tqm8xx/load_sernum_ethaddr.o nand.o diff --git a/board/tqc/tqm8xx/u-boot.lds b/board/tqc/tqm8xx/u-boot.lds index cbfc94f57..b77ae56c5 100644 --- a/board/tqc/tqm8xx/u-boot.lds +++ b/board/tqc/tqm8xx/u-boot.lds @@ -18,13 +18,13 @@ SECTIONS      arch/powerpc/cpu/mpc8xx/start.o	(.text*)      arch/powerpc/cpu/mpc8xx/traps.o	(.text*) -    arch/powerpc/cpu/mpc8xx/libmpc8xx.o (.text*) -    arch/powerpc/lib/libpowerpc.o	(.text*) -    board/tqc/tqm8xx/libtqm8xx.o	(.text*) -    disk/libdisk.o			(.text*) -    drivers/net/libnet.o		(.text*) -    drivers/libdrivers.o		(.text.pcmcia_on) -    drivers/libdrivers.o		(.text.pcmcia_hardware_enable) +    arch/powerpc/cpu/mpc8xx/built-in.o	(.text*) +    arch/powerpc/lib/built-in.o		(.text*) +    board/tqc/tqm8xx/built-in.o		(.text*) +    disk/built-in.o			(.text*) +    drivers/net/built-in.o		(.text*) +    drivers/built-in.o			(.text.pcmcia_on) +    drivers/built-in.o			(.text.pcmcia_hardware_enable)      . = DEFINED(env_offset) ? env_offset : .;      common/env_embedded.o	(.ppcenv*) diff --git a/board/vpac270/u-boot-spl.lds b/board/vpac270/u-boot-spl.lds index 7eac4975b..c9b50e9f4 100644 --- a/board/vpac270/u-boot-spl.lds +++ b/board/vpac270/u-boot-spl.lds @@ -20,8 +20,8 @@ SECTIONS  	.text.0	:  	{  		arch/arm/cpu/pxa/start.o		(.text*) -		board/vpac270/libvpac270.o		(.text*) -		drivers/mtd/onenand/libonenand.o	(.text*) +		board/vpac270/built-in.o		(.text*) +		drivers/mtd/onenand/built-in.o		(.text*)  	} diff --git a/board/xilinx/ppc405-generic/Makefile b/board/xilinx/ppc405-generic/Makefile index 1562f1775..c9da87065 100644 --- a/board/xilinx/ppc405-generic/Makefile +++ b/board/xilinx/ppc405-generic/Makefile @@ -9,8 +9,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../../xilinx/ppc405-generic) -endif -  obj-y	+= ../../xilinx/ppc405-generic/xilinx_ppc405_generic.o diff --git a/board/xilinx/ppc440-generic/Makefile b/board/xilinx/ppc440-generic/Makefile index b2227c58a..0acd95d6e 100644 --- a/board/xilinx/ppc440-generic/Makefile +++ b/board/xilinx/ppc440-generic/Makefile @@ -9,9 +9,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifneq ($(OBJTREE),$(SRCTREE)) -$(shell mkdir -p $(obj)../../xilinx/ppc440-generic) -endif -  obj-y	+= ../../xilinx/ppc440-generic/xilinx_ppc440_generic.o  extra-y 	+= ../../xilinx/ppc440-generic/init.o diff --git a/boards.cfg b/boards.cfg index caba64e43..e74274628 100644 --- a/boards.cfg +++ b/boards.cfg @@ -963,6 +963,8 @@ Active  powerpc     mpc85xx        -           freescale       t4qds  Active  powerpc     mpc85xx        -           freescale       t4qds               T4240QDS_SPIFLASH                    T4240QDS:PPC_T4240,RAMBOOT_PBL,SPIFLASH,SYS_TEXT_BASE=0xFFF80000                                                                  -  Active  powerpc     mpc85xx        -           freescale       t4qds               T4240QDS_SRIO_PCIE_BOOT              T4240QDS:PPC_T4240,SRIO_PCIE_BOOT_SLAVE,SYS_TEXT_BASE=0xFFF80000                                                                  -  Active  powerpc     mpc85xx        -           freescale       t1040qds            T1040QDS                             T1040QDS:PPC_T1040                                                                                                                Naveen Burmi <NaveenBurmi@freescale.com> +Active  powerpc     mpc85xx        -           freescale       t104xrdb            T1040RDB                             T1040RDB:PPC_T1040                                                                                                             Poonam Aggrwal  <poonam.aggrwal@freescale.com> +Active  powerpc     mpc85xx        -           freescale       t104xrdb            T1042RDB_PI                          T1042RDB_PI:PPC_T1042                                                                                                          Poonam Aggrwal  <poonam.aggrwal@freescale.com>  Active  powerpc     mpc85xx        -           gdsys           p1022               controlcenterd_36BIT_SDCARD          controlcenterd:36BIT,SDCARD                                                                                                       Dirk Eibach <eibach@gdsys.de>  Active  powerpc     mpc85xx        -           gdsys           p1022               controlcenterd_36BIT_SDCARD_DEVELOP  controlcenterd:36BIT,SDCARD,DEVELOP                                                                                               Dirk Eibach <eibach@gdsys.de>  Active  powerpc     mpc85xx        -           gdsys           p1022               controlcenterd_TRAILBLAZER           controlcenterd:TRAILBLAZER,SPIFLASH                                                                                               Dirk Eibach <eibach@gdsys.de> diff --git a/common/cmd_eeprom.c b/common/cmd_eeprom.c index ef694d8f8..02539c40a 100644 --- a/common/cmd_eeprom.c +++ b/common/cmd_eeprom.c @@ -161,7 +161,7 @@ int eeprom_read (unsigned dev_addr, unsigned offset, uchar *buffer, unsigned cnt  #if defined(CONFIG_SPI) && !defined(CONFIG_ENV_EEPROM_IS_ON_I2C)  		spi_read (addr, alen, buffer, len);  #else -		if (i2c_read (addr[0], offset, alen-1, buffer, len) != 0) +		if (i2c_read (addr[0], addr[1], alen-1, buffer, len) != 0)  			rcode = 1;  #endif  		buffer += len; @@ -339,7 +339,7 @@ int eeprom_write (unsigned dev_addr, unsigned offset, uchar *buffer, unsigned cn  		/* Write is enabled ... now write eeprom value.  		 */  #endif -		if (i2c_write (addr[0], offset, alen-1, buffer, len) != 0) +		if (i2c_write (addr[0], addr[1], alen-1, buffer, len) != 0)  			rcode = 1;  #endif @@ -13,12 +13,6 @@ SHELL := $(shell if [ -x "$$BASH" ]; then echo $$BASH; \  export	SHELL -ifeq ($(CONFIG_TPL_BUILD),y) -SPL_BIN := u-boot-tpl -else -SPL_BIN := u-boot-spl -endif -  ifeq ($(CURDIR),$(SRCTREE))  dir :=  else diff --git a/doc/README.p1010rdb b/doc/README.p1010rdb deleted file mode 100644 index 6b2b5ff3f..000000000 --- a/doc/README.p1010rdb +++ /dev/null @@ -1,198 +0,0 @@ -Overview -========= -The P1010RDB is a Freescale reference design board that hosts the P1010 SoC. - -The P1010 is a cost-effective, low-power, highly integrated host processor -based on a Power Architecture e500v2 core (maximum core frequency 800/1000 MHz), -that addresses the requirements of several routing, gateways, storage, consumer, -and industrial applications. Applications of interest include the main CPUs and -I/O processors in network attached storage (NAS), the voice over IP (VoIP) -router/gateway, and wireless LAN (WLAN) and industrial controllers. - -The P1010RDB board features are as follows: -Memory subsystem: -	- 1Gbyte unbuffered DDR3 SDRAM discrete devices (32-bit bus) -	- 32 Mbyte NOR flash single-chip memory -	- 32 Mbyte NAND flash memory -	- 256 Kbit M24256 I2C EEPROM -	- 16 Mbyte SPI memory -	- I2C Board EEPROM 128x8 bit memory -	- SD/MMC connector to interface with the SD memory card -Interfaces: -	- PCIe: -		- Lane0: x1 mini-PCIe slot -		- Lane1: x1 PCIe standard slot -	- SATA: -		- 1 internal SATA connector to 2.5" 160G SATA2 HDD -		- 1 eSATA connector to rear panel -	- 10/100/1000 BaseT Ethernet ports: -		- eTSEC1, RGMII: one 10/100/1000 port using Vitesse VSC8641XKO -		- eTSEC2, SGMII: one 10/100/1000 port using Vitesse VSC8221 -		- eTSEC3, SGMII: one 10/100/1000 port using Vitesse VSC8221 -	- USB 2.0 port: -		- x1 USB2.0 port: via an ULPI PHY to micro-AB connector -		- x1 USB2.0 poort via an internal PHY to micro-AB connector -	- FlexCAN ports: -		- x2 DB-9 female connectors for FlexCAN bus(revision 2.0B) -		   interface; -	- DUART interface: -		- DUART interface: supports two UARTs up to 115200 bps for -		  console display -		- J45 connectors are used for these 2 UART ports. -	- TDM -		- 2 FXS ports connected via an external SLIC to the TDM -		   interface. SLIC is controllled via SPI. -		- 1 FXO port connected via a relay to FXS for switchover to -		   POTS -Board connectors: -	- Mini-ITX power supply connector -	- JTAG/COP for debugging -IEEE Std. 1588 signals for test and measurement -Real-time clock on I2C bus -POR -	- support critical POR setting changed via switch on board -PCB -	- 6-layer routing (4-layer signals, 2-layer power and ground) - - -Serial Port Configuration on P1010RDB -===================================== -Configure the serial port of the attached computer with the following values: -	-Data rate: 115200 bps -	-Number of data bits: 8 -	-Parity: None -	-Number of Stop bits: 1 -	-Flow Control: Hardware/None - - -Settings of DIP-switch -====================== -  SW4[1:4]= 1111 and SW6[4]=0 for boot from 16bit NOR flash -  SW4[1:4]= 1000 and SW6[4]=1 for boot from 8bit NAND flash -  SW4[1:4]= 0110 and SW6[4]=0 for boot from SPI flash -Note: 1 stands for 'on', 0 stands for 'off' - - -Setting of hwconfig -=================== -If FlexCAN or TDM is needed, please set "fsl_p1010mux:tdm_can=can" or -"fsl_p1010mux:tdm_can=tdm" explicitly in u-booot prompt as below for example: -setenv hwconfig "fsl_p1010mux:tdm_can=tdm;usb1:dr_mode=host,phy_type=utmi" -By default, don't set fsl_p1010mux:tdm_can, in this case, spi chip selection -is set to spi-flash instead of to SLIC/TDM/DAC and tdm_can_sel is set to TDM -instead of to CAN/UART1. - - -Build and burn u-boot to NOR flash -================================== -1. Build u-boot.bin image -	export ARCH=powerpc -	export CROSS_COMPILE=/your_path/powerpc-linux-gnu- -	make P1010RDB_NOR - -2. Burn u-boot.bin into NOR flash -	=> tftp $loadaddr $uboot -	=> protect off eff80000 +$filesize -	=> erase eff80000 +$filesize -	=> cp.b $loadaddr eff80000 $filesize - -3. Check SW4[1:4]= 1111 and SW6[4]=0, then power on. - - -Alternate NOR bank -============================ -1. Burn u-boot.bin into alternate NOR bank -	=> tftp $loadaddr $uboot -	=> protect off eef80000 +$filesize -	=> erase eef80000 +$filesize -	=> cp.b $loadaddr eef80000 $filesize - -2. Switch to alternate NOR bank -	=> mw.b ffb00009 1 -	=> reset -	or set SW1[8]= ON - -SW1[8]= OFF: Upper bank used for booting start -SW1[8]= ON:  Lower bank used for booting start -CPLD NOR bank selection register address 0xFFB00009 Bit[0]: -0 - boot from upper 4 sectors -1 - boot from lower 4 sectors - - -Build and burn u-boot to NAND flash -=================================== -1. Build u-boot.bin image -	export ARCH=powerpc -	export CROSS_COMPILE=/your_path/powerpc-linux-gnu- -	make P1010RDB_NAND - -2. Burn u-boot-nand.bin into NAND flash -	=> tftp $loadaddr $uboot-nand -	=> nand erase 0 $filesize -	=> nand write $loadaddr 0 $filesize - -3. Check SW4[1:4]= 1000 and SW6[4]=1, then power on. - - - -Build and burn u-boot to SPI flash -================================== -1. Build u-boot-spi.bin image -	make P1010RDB_SPIFLASH_config; make -	Boot up kernel with rootfs.ext2.gz.uboot.p1010rdb -	Download u-boot.bin to linux and you can find some config files -	under /usr/share such as config_xx.dat. Do below command: -	boot_format config_ddr3_1gb_p1010rdb_800M.dat u-boot.bin -spi \ -			u-boot-spi.bin -	to generate u-boot-spi.bin. - -2. Burn u-boot-spi.bin into SPI flash -	=> tftp $loadaddr $uboot-spi -	=> sf erase 0 100000 -	=> sf write $loadaddr 0 $filesize - -3. Check SW4[1:4]= 0110 and SW6[4]=0, then power on. - - - -CPLD POR setting registers -========================== -1. Set POR switch selection register (addr 0xFFB00011) to 0. -2. Write CPLD POR registers (BCSR0~BCSR3, addr 0xFFB00014~0xFFB00017) with -   proper values. -   If change boot ROM location to NOR or NAND flash, need write the IFC_CS0 -   switch command by I2C. -3. Send reset command. -   After reset, the new POR setting will be implemented. - -Two examples are given in below: -Switch from NOR to NAND boot with default frequency: -	=> i2c dev 0 -	=> i2c mw 18 1 f9 -	=> i2c mw 18 3 f0 -	=> mw.b ffb00011 0 -	=> mw.b ffb00017 1 -	=> reset -Switch from NAND to NOR boot with Core/CCB/DDR (800/400/667 MHz): -	=> i2c dev 0 -	=> i2c mw 18 1 f1 -	=> i2c mw 18 3 f0 -	=> mw.b ffb00011 0 -	=> mw.b ffb00014 2 -	=> mw.b ffb00015 5 -	=> mw.b ffb00016 3 -	=> mw.b ffb00017 f -	=> reset - - -Boot Linux from network using TFTP on P1010RDB -============================================== -Place uImage, p1010rdb.dtb and rootfs files in the TFTP disk area. -	=> tftp 1000000 uImage -	=> tftp 2000000 p1010rdb.dtb -	=> tftp 3000000 rootfs.ext2.gz.uboot.p1010rdb -	=> bootm 1000000 3000000 2000000 - - -Please contact your local field applications engineer or sales representative -to obtain related documents, such as P1010-RDB User Guide for details. diff --git a/doc/README.scrapyard b/doc/README.scrapyard index c3182e4d9..f045f433f 100644 --- a/doc/README.scrapyard +++ b/doc/README.scrapyard @@ -103,3 +103,4 @@ CPCI440          powerpc     440GP          b568fd2     2007-12-27  Matthias Fuc  PCIPPC2          powerpc     MPC740/MPC750  7c9e89b     2013-02-07  Wolfgang Denk <wd@denx.de>  PCIPPC6          powerpc     MPC740/MPC750  -           -           Wolfgang Denk <wd@denx.de>  omap2420h4       arm         omap24xx       -           2013-06-04  Richard Woodruff <r-woodruff2@ti.com> +eNET             x86         x86            7e8c53d     2013-02-14  Graeme Russ <graeme.russ@gmail.com> diff --git a/drivers/Makefile b/drivers/Makefile index 9cec2ba6f..5d03f37a1 100644 --- a/drivers/Makefile +++ b/drivers/Makefile @@ -1,8 +1,8 @@ -obj-y += bios_emulator/ +obj-$(CONFIG_BIOSEMU) += bios_emulator/  obj-y += block/  obj-$(CONFIG_BOOTCOUNT_LIMIT) += bootcount/  obj-y += crypto/ -obj-y += fpga/ +obj-$(CONFIG_FPGA) += fpga/  obj-y += hwmon/  obj-y += misc/  obj-y += pcmcia/ @@ -13,3 +13,4 @@ obj-y += tpm/  obj-y += twserial/  obj-y += video/  obj-y += watchdog/ +obj-$(CONFIG_QE) += qe/ diff --git a/drivers/bios_emulator/Makefile b/drivers/bios_emulator/Makefile index dd42e0f76..6f74fdc23 100644 --- a/drivers/bios_emulator/Makefile +++ b/drivers/bios_emulator/Makefile @@ -1,8 +1,6 @@  X86DIR  = x86emu -$(shell mkdir -p $(obj)$(X86DIR)) - -obj-$(CONFIG_BIOSEMU)	= atibios.o biosemu.o besys.o bios.o \ +obj-y = atibios.o biosemu.o besys.o bios.o \  	$(X86DIR)/decode.o \  	$(X86DIR)/ops2.o \  	$(X86DIR)/ops.o \ diff --git a/drivers/fpga/Makefile b/drivers/fpga/Makefile index 4fcdf40fd..dfb2e7fc7 100644 --- a/drivers/fpga/Makefile +++ b/drivers/fpga/Makefile @@ -5,7 +5,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifdef CONFIG_FPGA  obj-y += fpga.o  obj-$(CONFIG_FPGA_SPARTAN2) += spartan2.o  obj-$(CONFIG_FPGA_SPARTAN3) += spartan3.o @@ -19,4 +18,3 @@ obj-$(CONFIG_FPGA_ACEX1K) += ACEX1K.o  obj-$(CONFIG_FPGA_CYCLON2) += cyclon2.o  obj-$(CONFIG_FPGA_STRATIX_II) += stratixII.o  endif -endif diff --git a/drivers/i2c/Makefile b/drivers/i2c/Makefile index 5280bb3fe..553b519cc 100644 --- a/drivers/i2c/Makefile +++ b/drivers/i2c/Makefile @@ -11,21 +11,20 @@ obj-$(CONFIG_DW_I2C) += designware_i2c.o  obj-$(CONFIG_I2C_MVTWSI) += mvtwsi.o  obj-$(CONFIG_I2C_MV) += mv_i2c.o  obj-$(CONFIG_I2C_MXS) += mxs_i2c.o -obj-$(CONFIG_DRIVER_OMAP1510_I2C) += omap1510_i2c.o -obj-$(CONFIG_DRIVER_OMAP24XX_I2C) += omap24xx_i2c.o -obj-$(CONFIG_DRIVER_OMAP34XX_I2C) += omap24xx_i2c.o  obj-$(CONFIG_PCA9564_I2C) += pca9564_i2c.o  obj-$(CONFIG_DRIVER_S3C24X0_I2C) += s3c24x0_i2c.o  obj-$(CONFIG_TSI108_I2C) += tsi108_i2c.o  obj-$(CONFIG_U8500_I2C) += u8500_i2c.o -obj-$(CONFIG_SH_I2C) += sh_i2c.o  obj-$(CONFIG_SH_SH7734_I2C) += sh_sh7734_i2c.o  obj-$(CONFIG_SYS_I2C) += i2c_core.o  obj-$(CONFIG_SYS_I2C_FSL) += fsl_i2c.o  obj-$(CONFIG_SYS_I2C_FTI2C010) += fti2c010.o  obj-$(CONFIG_SYS_I2C_MXC) += mxc_i2c.o +obj-$(CONFIG_SYS_I2C_OMAP24XX) += omap24xx_i2c.o +obj-$(CONFIG_SYS_I2C_OMAP34XX) += omap24xx_i2c.o  obj-$(CONFIG_SYS_I2C_PPC4XX) += ppc4xx_i2c.o  obj-$(CONFIG_SYS_I2C_RCAR) += rcar_i2c.o +obj-$(CONFIG_SYS_I2C_SH) += sh_i2c.o  obj-$(CONFIG_SYS_I2C_SOFT) += soft_i2c.o  obj-$(CONFIG_SYS_I2C_TEGRA) += tegra_i2c.o -obj-$(CONFIG_ZYNQ_I2C) += zynq_i2c.o +obj-$(CONFIG_SYS_I2C_ZYNQ) += zynq_i2c.o diff --git a/drivers/i2c/designware_i2c.c b/drivers/i2c/designware_i2c.c index c2f06627d..cb2ac04b6 100644 --- a/drivers/i2c/designware_i2c.c +++ b/drivers/i2c/designware_i2c.c @@ -151,7 +151,19 @@ void i2c_init(int speed, int slaveadd)   */  static void i2c_setaddress(unsigned int i2c_addr)  { +	unsigned int enbl; + +	/* Disable i2c */ +	enbl = readl(&i2c_regs_p->ic_enable); +	enbl &= ~IC_ENABLE_0B; +	writel(enbl, &i2c_regs_p->ic_enable); +  	writel(i2c_addr, &i2c_regs_p->ic_tar); + +	/* Enable i2c */ +	enbl = readl(&i2c_regs_p->ic_enable); +	enbl |= IC_ENABLE_0B; +	writel(enbl, &i2c_regs_p->ic_enable);  }  /* @@ -237,9 +249,6 @@ static int i2c_xfer_finish(void)  	i2c_flush_rxfifo(); -	/* Wait for read/write operation to complete on actual memory */ -	udelay(10000); -  	return 0;  } diff --git a/drivers/i2c/mxs_i2c.c b/drivers/i2c/mxs_i2c.c index 46106b771..a298c95e1 100644 --- a/drivers/i2c/mxs_i2c.c +++ b/drivers/i2c/mxs_i2c.c @@ -150,6 +150,7 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  {  	struct mxs_i2c_regs *i2c_regs = (struct mxs_i2c_regs *)MXS_I2C0_BASE;  	uint32_t tmp = 0; +	int timeout = MXS_I2C_MAX_TIMEOUT;  	int ret;  	int i; @@ -169,9 +170,17 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  	for (i = 0; i < len; i++) {  		if (!(i & 3)) { -			while (readl(&i2c_regs->hw_i2c_queuestat) & -				I2C_QUEUESTAT_RD_QUEUE_EMPTY) -				; +			while (--timeout) { +				tmp = readl(&i2c_regs->hw_i2c_queuestat); +				if (!(tmp & I2C_QUEUESTAT_RD_QUEUE_EMPTY)) +					break; +			} + +			if (!timeout) { +				debug("MXS I2C: Failed receiving data!\n"); +				return -ETIMEDOUT; +			} +  			tmp = readl(&i2c_regs->hw_i2c_queuedata);  		}  		buffer[i] = tmp & 0xff; diff --git a/drivers/i2c/omap1510_i2c.c b/drivers/i2c/omap1510_i2c.c deleted file mode 100644 index f91ee8884..000000000 --- a/drivers/i2c/omap1510_i2c.c +++ /dev/null @@ -1,277 +0,0 @@ -/* - * Basic I2C functions - * - * Copyright (c) 2003 Texas Instruments - * - * This package is free software;  you can redistribute it and/or - * modify it under the terms of the license found in the file - * named COPYING that should have accompanied this file. - * - * THIS PACKAGE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR - * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED - * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. - * - * Author: Jian Zhang jzhang@ti.com, Texas Instruments - * - * Copyright (c) 2003 Wolfgang Denk, wd@denx.de - * Rewritten to fit into the current U-Boot framework - * - */ - -#include <common.h> - -static void wait_for_bb (void); -static u16 wait_for_pin (void); - -void i2c_init (int speed, int slaveadd) -{ -	u16 scl; - -	if (inw (I2C_CON) & I2C_CON_EN) { -		outw (0, I2C_CON); -		udelay (5000); -	} - -	/* 12MHz I2C module clock */ -	outw (0, I2C_PSC); -	outw (I2C_CON_EN, I2C_CON); -	outw (0, I2C_SYSTEST); -	/* have to enable intrrupts or OMAP i2c module doesn't work */ -	outw (I2C_IE_XRDY_IE | I2C_IE_RRDY_IE | I2C_IE_ARDY_IE | -	      I2C_IE_NACK_IE | I2C_IE_AL_IE, I2C_IE); -	scl = (12000000 / 2) / speed - 6; -	outw (scl, I2C_SCLL); -	outw (scl, I2C_SCLH); -	/* own address */ -	outw (slaveadd, I2C_OA); -	outw (0, I2C_CNT); -	udelay (1000); -} - -static int i2c_read_byte (u8 devaddr, u8 regoffset, u8 * value) -{ -	int i2c_error = 0; -	u16 status; - -	/* wait until bus not busy */ -	wait_for_bb (); - -	/* one byte only */ -	outw (1, I2C_CNT); -	/* set slave address */ -	outw (devaddr, I2C_SA); -	/* no stop bit needed here */ -	outw (I2C_CON_EN | I2C_CON_MST | I2C_CON_STT | I2C_CON_TRX, I2C_CON); - -	status = wait_for_pin (); - -	if (status & I2C_STAT_XRDY) { -		/* Important: have to use byte access */ -		*(volatile u8 *) (I2C_DATA) = regoffset; -		udelay (20000); -		if (inw (I2C_STAT) & I2C_STAT_NACK) { -			i2c_error = 1; -		} -	} else { -		i2c_error = 1; -	} - -	if (!i2c_error) { -		/* free bus, otherwise we can't use a combined transction */ -		outw (0, I2C_CON); -		while (inw (I2C_STAT) || (inw (I2C_CON) & I2C_CON_MST)) { -			udelay (10000); -			/* Have to clear pending interrupt to clear I2C_STAT */ -			inw (I2C_IV); -		} - -		wait_for_bb (); -		/* set slave address */ -		outw (devaddr, I2C_SA); -		/* read one byte from slave */ -		outw (1, I2C_CNT); -		/* need stop bit here */ -		outw (I2C_CON_EN | I2C_CON_MST | I2C_CON_STT | I2C_CON_STP, -		      I2C_CON); - -		status = wait_for_pin (); -		if (status & I2C_STAT_RRDY) { -			*value = inw (I2C_DATA); -			udelay (20000); -		} else { -			i2c_error = 1; -		} - -		if (!i2c_error) { -			outw (I2C_CON_EN, I2C_CON); -			while (inw (I2C_STAT) -			       || (inw (I2C_CON) & I2C_CON_MST)) { -				udelay (10000); -				inw (I2C_IV); -			} -		} -	} - -	return i2c_error; -} - -static int i2c_write_byte (u8 devaddr, u8 regoffset, u8 value) -{ -	int i2c_error = 0; -	u16 status; - -	/* wait until bus not busy */ -	wait_for_bb (); - -	/* two bytes */ -	outw (2, I2C_CNT); -	/* set slave address */ -	outw (devaddr, I2C_SA); -	/* stop bit needed here */ -	outw (I2C_CON_EN | I2C_CON_MST | I2C_CON_STT | I2C_CON_TRX | -	      I2C_CON_STP, I2C_CON); - -	/* wait until state change */ -	status = wait_for_pin (); - -	if (status & I2C_STAT_XRDY) { -		/* send out two bytes */ -		outw ((value << 8) + regoffset, I2C_DATA); -		/* must have enough delay to allow BB bit to go low */ -		udelay (30000); -		if (inw (I2C_STAT) & I2C_STAT_NACK) { -			i2c_error = 1; -		} -	} else { -		i2c_error = 1; -	} - -	if (!i2c_error) { -		outw (I2C_CON_EN, I2C_CON); -		while (inw (I2C_STAT) || (inw (I2C_CON) & I2C_CON_MST)) { -			udelay (1000); -			/* have to read to clear intrrupt */ -			inw (I2C_IV); -		} -	} - -	return i2c_error; -} - -int i2c_probe (uchar chip) -{ -	int res = 1; - -	if (chip == inw (I2C_OA)) { -		return res; -	} - -	/* wait until bus not busy */ -	wait_for_bb (); - -	/* try to read one byte */ -	outw (1, I2C_CNT); -	/* set slave address */ -	outw (chip, I2C_SA); -	/* stop bit needed here */ -	outw (I2C_CON_EN | I2C_CON_MST | I2C_CON_STT | I2C_CON_STP, I2C_CON); -	/* enough delay for the NACK bit set */ -	udelay (2000); -	if (!(inw (I2C_STAT) & I2C_STAT_NACK)) { -		res = 0; -	} else { -		outw (inw (I2C_CON) | I2C_CON_STP, I2C_CON); -		udelay (20); -		wait_for_bb (); -	} - -	return res; -} - -int i2c_read (uchar chip, uint addr, int alen, uchar * buffer, int len) -{ -	int i; - -	if (alen > 1) { -		printf ("I2C read: addr len %d not supported\n", alen); -		return 1; -	} - -	if (addr + len > 256) { -		printf ("I2C read: address out of range\n"); -		return 1; -	} - -	for (i = 0; i < len; i++) { -		if (i2c_read_byte (chip, addr + i, &buffer[i])) { -			printf ("I2C read: I/O error\n"); -			i2c_init (CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); -			return 1; -		} -	} - -	return 0; -} - -int i2c_write (uchar chip, uint addr, int alen, uchar * buffer, int len) -{ -	int i; - -	if (alen > 1) { -		printf ("I2C read: addr len %d not supported\n", alen); -		return 1; -	} - -	if (addr + len > 256) { -		printf ("I2C read: address out of range\n"); -		return 1; -	} - -	for (i = 0; i < len; i++) { -		if (i2c_write_byte (chip, addr + i, buffer[i])) { -			printf ("I2C read: I/O error\n"); -			i2c_init (CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); -			return 1; -		} -	} - -	return 0; -} - -static void wait_for_bb (void) -{ -	int timeout = 10; - -	while ((inw (I2C_STAT) & I2C_STAT_BB) && timeout--) { -		inw (I2C_IV); -		udelay (1000); -	} - -	if (timeout <= 0) { -		printf ("timed out in wait_for_bb: I2C_STAT=%x\n", -			inw (I2C_STAT)); -	} -} - -static u16 wait_for_pin (void) -{ -	u16 status, iv; -	int timeout = 10; - -	do { -		udelay (1000); -		status = inw (I2C_STAT); -		iv = inw (I2C_IV); -	} while (!iv && -		 !(status & -		   (I2C_STAT_ROVR | I2C_STAT_XUDF | I2C_STAT_XRDY | -		    I2C_STAT_RRDY | I2C_STAT_ARDY | I2C_STAT_NACK | -		    I2C_STAT_AL)) && timeout--); - -	if (timeout <= 0) { -		printf ("timed out in wait_for_pin: I2C_STAT=%x\n", -			inw (I2C_STAT)); -	} - -	return status; -} diff --git a/drivers/i2c/omap24xx_i2c.c b/drivers/i2c/omap24xx_i2c.c index ef38d7172..3d38c035b 100644 --- a/drivers/i2c/omap24xx_i2c.c +++ b/drivers/i2c/omap24xx_i2c.c @@ -35,6 +35,7 @@   */  #include <common.h> +#include <i2c.h>  #include <asm/arch/i2c.h>  #include <asm/io.h> @@ -48,22 +49,14 @@ DECLARE_GLOBAL_DATA_PTR;  /* Absolutely safe for status update at 100 kHz I2C: */  #define I2C_WAIT	200 -static int wait_for_bb(void); -static u16 wait_for_event(void); -static void flush_fifo(void); +static int wait_for_bb(struct i2c_adapter *adap); +static struct i2c *omap24_get_base(struct i2c_adapter *adap); +static u16 wait_for_event(struct i2c_adapter *adap); +static void flush_fifo(struct i2c_adapter *adap); -/* - * For SPL boot some boards need i2c before SDRAM is initialised so force - * variables to live in SRAM - */ -static struct i2c __attribute__((section (".data"))) *i2c_base = -					(struct i2c *)I2C_DEFAULT_BASE; -static unsigned int __attribute__((section (".data"))) bus_initialized[I2C_BUS_MAX] = -					{ [0 ... (I2C_BUS_MAX-1)] = 0 }; -static unsigned int __attribute__((section (".data"))) current_bus = 0; - -void i2c_init(int speed, int slaveadd) +static void omap24_i2c_init(struct i2c_adapter *adap, int speed, int slaveadd)  { +	struct i2c *i2c_base = omap24_get_base(adap);  	int psc, fsscll, fssclh;  	int hsscll = 0, hssclh = 0;  	u32 scll, sclh; @@ -163,16 +156,15 @@ void i2c_init(int speed, int slaveadd)  	       I2C_IE_NACK_IE | I2C_IE_AL_IE, &i2c_base->ie);  #endif  	udelay(1000); -	flush_fifo(); +	flush_fifo(adap);  	writew(0xFFFF, &i2c_base->stat);  	writew(0, &i2c_base->cnt); - -	if (gd->flags & GD_FLG_RELOC) -		bus_initialized[current_bus] = 1;  } -static void flush_fifo(void) -{	u16 stat; +static void flush_fifo(struct i2c_adapter *adap) +{ +	struct i2c *i2c_base = omap24_get_base(adap); +	u16 stat;  	/* note: if you try and read data when its not there or ready  	 * you get a bus error @@ -192,8 +184,9 @@ static void flush_fifo(void)   * i2c_probe: Use write access. Allows to identify addresses that are   *            write-only (like the config register of dual-port EEPROMs)   */ -int i2c_probe(uchar chip) +static int omap24_i2c_probe(struct i2c_adapter *adap, uchar chip)  { +	struct i2c *i2c_base = omap24_get_base(adap);  	u16 status;  	int res = 1; /* default = fail */ @@ -201,7 +194,7 @@ int i2c_probe(uchar chip)  		return res;  	/* Wait until bus is free */ -	if (wait_for_bb()) +	if (wait_for_bb(adap))  		return res;  	/* No data transfer, slave addr only */ @@ -212,7 +205,7 @@ int i2c_probe(uchar chip)  	writew(I2C_CON_EN | I2C_CON_MST | I2C_CON_STT | I2C_CON_TRX |  	       I2C_CON_STP, &i2c_base->con); -	status = wait_for_event(); +	status = wait_for_event(adap);  	if ((status & ~I2C_STAT_XRDY) == 0 || (status & I2C_STAT_AL)) {  		/* @@ -223,7 +216,7 @@ int i2c_probe(uchar chip)  		 */  		if (status == I2C_STAT_XRDY)  			printf("i2c_probe: pads on bus %d probably not configured (status=0x%x)\n", -			       current_bus, status); +			       adap->hwadapnr, status);  		goto pr_exit;  	} @@ -239,7 +232,7 @@ int i2c_probe(uchar chip)  		       I2C_CON_STP, &i2c_base->con);		/* STP */  	}  pr_exit: -	flush_fifo(); +	flush_fifo(adap);  	writew(0xFFFF, &i2c_base->stat);  	writew(0, &i2c_base->cnt);  	return res; @@ -258,8 +251,10 @@ pr_exit:   *           or that do not need a register address at all (such as some clock   *           distributors).   */ -int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len) +static int omap24_i2c_read(struct i2c_adapter *adap, uchar chip, uint addr, +			   int alen, uchar *buffer, int len)  { +	struct i2c *i2c_base = omap24_get_base(adap);  	int i2c_error = 0;  	u16 status; @@ -287,7 +282,7 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  	}  	/* Wait until bus not busy */ -	if (wait_for_bb()) +	if (wait_for_bb(adap))  		return 1;  	/* Zero, one or two bytes reg address (offset) */ @@ -308,12 +303,12 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  #endif  		/* Send register offset */  		while (1) { -			status = wait_for_event(); +			status = wait_for_event(adap);  			/* Try to identify bus that is not padconf'd for I2C */  			if (status == I2C_STAT_XRDY) {  				i2c_error = 2;  				printf("i2c_read (addr phase): pads on bus %d probably not configured (status=0x%x)\n", -				       current_bus, status); +				       adap->hwadapnr, status);  				goto rd_exit;  			}  			if (status == 0 || status & I2C_STAT_NACK) { @@ -348,7 +343,7 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  	/* Receive data */  	while (1) { -		status = wait_for_event(); +		status = wait_for_event(adap);  		/*  		 * Try to identify bus that is not padconf'd for I2C. This  		 * state could be left over from previous transactions if @@ -357,7 +352,7 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  		if (status == I2C_STAT_XRDY) {  			i2c_error = 2;  			printf("i2c_read (data phase): pads on bus %d probably not configured (status=0x%x)\n", -			       current_bus, status); +			       adap->hwadapnr, status);  			goto rd_exit;  		}  		if (status == 0 || status & I2C_STAT_NACK) { @@ -375,15 +370,17 @@ int i2c_read(uchar chip, uint addr, int alen, uchar *buffer, int len)  	}  rd_exit: -	flush_fifo(); +	flush_fifo(adap);  	writew(0xFFFF, &i2c_base->stat);  	writew(0, &i2c_base->cnt);  	return i2c_error;  }  /* i2c_write: Address (reg offset) may be 0, 1 or 2 bytes long. */ -int i2c_write(uchar chip, uint addr, int alen, uchar *buffer, int len) +static int omap24_i2c_write(struct i2c_adapter *adap, uchar chip, uint addr, +			    int alen, uchar *buffer, int len)  { +	struct i2c *i2c_base = omap24_get_base(adap);  	int i;  	u16 status;  	int i2c_error = 0; @@ -415,7 +412,7 @@ int i2c_write(uchar chip, uint addr, int alen, uchar *buffer, int len)  	}  	/* Wait until bus not busy */ -	if (wait_for_bb()) +	if (wait_for_bb(adap))  		return 1;  	/* Start address phase - will write regoffset + len bytes data */ @@ -428,12 +425,12 @@ int i2c_write(uchar chip, uint addr, int alen, uchar *buffer, int len)  	while (alen) {  		/* Must write reg offset (one or two bytes) */ -		status = wait_for_event(); +		status = wait_for_event(adap);  		/* Try to identify bus that is not padconf'd for I2C */  		if (status == I2C_STAT_XRDY) {  			i2c_error = 2;  			printf("i2c_write: pads on bus %d probably not configured (status=0x%x)\n", -			       current_bus, status); +			       adap->hwadapnr, status);  			goto wr_exit;  		}  		if (status == 0 || status & I2C_STAT_NACK) { @@ -455,7 +452,7 @@ int i2c_write(uchar chip, uint addr, int alen, uchar *buffer, int len)  	}  	/* Address phase is over, now write data */  	for (i = 0; i < len; i++) { -		status = wait_for_event(); +		status = wait_for_event(adap);  		if (status == 0 || status & I2C_STAT_NACK) {  			i2c_error = 1;  			printf("i2c_write: error waiting for data ACK (status=0x%x)\n", @@ -474,7 +471,7 @@ int i2c_write(uchar chip, uint addr, int alen, uchar *buffer, int len)  	}  wr_exit: -	flush_fifo(); +	flush_fifo(adap);  	writew(0xFFFF, &i2c_base->stat);  	writew(0, &i2c_base->cnt);  	return i2c_error; @@ -484,8 +481,9 @@ wr_exit:   * Wait for the bus to be free by checking the Bus Busy (BB)   * bit to become clear   */ -static int wait_for_bb(void) +static int wait_for_bb(struct i2c_adapter *adap)  { +	struct i2c *i2c_base = omap24_get_base(adap);  	int timeout = I2C_TIMEOUT;  	u16 stat; @@ -514,8 +512,9 @@ static int wait_for_bb(void)   * Wait for the I2C controller to complete current action   * and update status   */ -static u16 wait_for_event(void) +static u16 wait_for_event(struct i2c_adapter *adap)  { +	struct i2c *i2c_base = omap24_get_base(adap);  	u16 status;  	int timeout = I2C_TIMEOUT; @@ -540,7 +539,7 @@ static u16 wait_for_event(void)  		 * not been configured for I2C, and/or pull-ups are missing.  		 */  		printf("Check if pads/pull-ups of bus %d are properly configured\n", -		       current_bus); +		       adap->hwadapnr);  		writew(0xFFFF, &i2c_base->stat);  		status = 0;  	} @@ -548,48 +547,93 @@ static u16 wait_for_event(void)  	return status;  } -int i2c_set_bus_num(unsigned int bus) +static struct i2c *omap24_get_base(struct i2c_adapter *adap)  { -	if (bus >= I2C_BUS_MAX) { -		printf("Bad bus: %x\n", bus); -		return -1; -	} - -	switch (bus) { -	default: -		bus = 0;	/* Fall through */ +	switch (adap->hwadapnr) {  	case 0: -		i2c_base = (struct i2c *)I2C_BASE1; +		return (struct i2c *)I2C_BASE1;  		break;  	case 1: -		i2c_base = (struct i2c *)I2C_BASE2; +		return (struct i2c *)I2C_BASE2;  		break;  #if (I2C_BUS_MAX > 2)  	case 2: -		i2c_base = (struct i2c *)I2C_BASE3; +		return (struct i2c *)I2C_BASE3;  		break;  #if (I2C_BUS_MAX > 3)  	case 3: -		i2c_base = (struct i2c *)I2C_BASE4; +		return (struct i2c *)I2C_BASE4;  		break;  #if (I2C_BUS_MAX > 4)  	case 4: -		i2c_base = (struct i2c *)I2C_BASE5; +		return (struct i2c *)I2C_BASE5;  		break;  #endif  #endif  #endif +	default: +		printf("wrong hwadapnr: %d\n", adap->hwadapnr); +		break;  	} +	return NULL; +} -	current_bus = bus; +#if !defined(CONFIG_SYS_OMAP24_I2C_SPEED1) +#define CONFIG_SYS_OMAP24_I2C_SPEED1 CONFIG_SYS_OMAP24_I2C_SPEED +#endif +#if !defined(CONFIG_SYS_OMAP24_I2C_SLAVE1) +#define CONFIG_SYS_OMAP24_I2C_SLAVE1 CONFIG_SYS_OMAP24_I2C_SLAVE +#endif -	if (!bus_initialized[current_bus]) -		i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE); +U_BOOT_I2C_ADAP_COMPLETE(omap24_0, omap24_i2c_init, omap24_i2c_probe, +			 omap24_i2c_read, omap24_i2c_write, NULL, +			 CONFIG_SYS_OMAP24_I2C_SPEED, +			 CONFIG_SYS_OMAP24_I2C_SLAVE, +			 0) +U_BOOT_I2C_ADAP_COMPLETE(omap24_1, omap24_i2c_init, omap24_i2c_probe, +			 omap24_i2c_read, omap24_i2c_write, NULL, +			 CONFIG_SYS_OMAP24_I2C_SPEED1, +			 CONFIG_SYS_OMAP24_I2C_SLAVE1, +			 1) +#if (I2C_BUS_MAX > 2) +#if !defined(CONFIG_SYS_OMAP24_I2C_SPEED2) +#define CONFIG_SYS_OMAP24_I2C_SPEED2 CONFIG_SYS_OMAP24_I2C_SPEED +#endif +#if !defined(CONFIG_SYS_OMAP24_I2C_SLAVE2) +#define CONFIG_SYS_OMAP24_I2C_SLAVE2 CONFIG_SYS_OMAP24_I2C_SLAVE +#endif -	return 0; -} +U_BOOT_I2C_ADAP_COMPLETE(omap24_2, omap24_i2c_init, omap24_i2c_probe, +			 omap24_i2c_read, omap24_i2c_write, NULL, +			 CONFIG_SYS_OMAP24_I2C_SPEED2, +			 CONFIG_SYS_OMAP24_I2C_SLAVE2, +			 2) +#if (I2C_BUS_MAX > 3) +#if !defined(CONFIG_SYS_OMAP24_I2C_SPEED3) +#define CONFIG_SYS_OMAP24_I2C_SPEED3 CONFIG_SYS_OMAP24_I2C_SPEED +#endif +#if !defined(CONFIG_SYS_OMAP24_I2C_SLAVE3) +#define CONFIG_SYS_OMAP24_I2C_SLAVE3 CONFIG_SYS_OMAP24_I2C_SLAVE +#endif -int i2c_get_bus_num(void) -{ -	return (int) current_bus; -} +U_BOOT_I2C_ADAP_COMPLETE(omap24_3, omap24_i2c_init, omap24_i2c_probe, +			 omap24_i2c_read, omap24_i2c_write, NULL, +			 CONFIG_SYS_OMAP24_I2C_SPEED3, +			 CONFIG_SYS_OMAP24_I2C_SLAVE3, +			 3) +#if (I2C_BUS_MAX > 4) +#if !defined(CONFIG_SYS_OMAP24_I2C_SPEED4) +#define CONFIG_SYS_OMAP24_I2C_SPEED4 CONFIG_SYS_OMAP24_I2C_SPEED +#endif +#if !defined(CONFIG_SYS_OMAP24_I2C_SLAVE4) +#define CONFIG_SYS_OMAP24_I2C_SLAVE4 CONFIG_SYS_OMAP24_I2C_SLAVE +#endif + +U_BOOT_I2C_ADAP_COMPLETE(omap24_4, omap24_i2c_init, omap24_i2c_probe, +			 omap24_i2c_read, omap24_i2c_write, NULL, +			 CONFIG_SYS_OMAP24_I2C_SPEED4, +			 CONFIG_SYS_OMAP24_I2C_SLAVE4, +			 4) +#endif +#endif +#endif diff --git a/drivers/i2c/sh_i2c.c b/drivers/i2c/sh_i2c.c index 808202c29..cc1910075 100644 --- a/drivers/i2c/sh_i2c.c +++ b/drivers/i2c/sh_i2c.c @@ -6,6 +6,7 @@   */  #include <common.h> +#include <i2c.h>  #include <asm/io.h>  DECLARE_GLOBAL_DATA_PTR; @@ -22,8 +23,6 @@ struct sh_i2c {  };  #undef ureg -static struct sh_i2c *base; -  /* ICCR */  #define SH_I2C_ICCR_ICE		(1 << 7)  #define SH_I2C_ICCR_RACK	(1 << 6) @@ -43,202 +42,165 @@ static struct sh_i2c *base;  #define SH_I2C_ICIC_ICCHB8	(1 << 6)  #endif +static const struct sh_i2c *i2c_dev[CONFIG_SYS_I2C_SH_NUM_CONTROLLERS] = { +	(struct sh_i2c *)CONFIG_SYS_I2C_SH_BASE0, +#ifdef CONFIG_SYS_I2C_SH_BASE1 +	(struct sh_i2c *)CONFIG_SYS_I2C_SH_BASE1, +#endif +#ifdef CONFIG_SYS_I2C_SH_BASE2 +	(struct sh_i2c *)CONFIG_SYS_I2C_SH_BASE2, +#endif +#ifdef CONFIG_SYS_I2C_SH_BASE3 +	(struct sh_i2c *)CONFIG_SYS_I2C_SH_BASE3, +#endif +#ifdef CONFIG_SYS_I2C_SH_BASE4 +	(struct sh_i2c *)CONFIG_SYS_I2C_SH_BASE4, +#endif +}; +  static u16 iccl, icch;  #define IRQ_WAIT 1000 -static void irq_dte(struct sh_i2c *base) +static void sh_irq_dte(struct sh_i2c *dev)  {  	int i; -	for (i = 0 ; i < IRQ_WAIT ; i++) { -		if (SH_IC_DTE & readb(&base->icsr)) +	for (i = 0; i < IRQ_WAIT; i++) { +		if (SH_IC_DTE & readb(&dev->icsr))  			break;  		udelay(10);  	}  } -static int irq_dte_with_tack(struct sh_i2c *base) +static int sh_irq_dte_with_tack(struct sh_i2c *dev)  {  	int i; -	for (i = 0 ; i < IRQ_WAIT ; i++) { -		if (SH_IC_DTE & readb(&base->icsr)) +	for (i = 0; i < IRQ_WAIT; i++) { +		if (SH_IC_DTE & readb(&dev->icsr))  			break; -		if (SH_IC_TACK & readb(&base->icsr)) +		if (SH_IC_TACK & readb(&dev->icsr))  			return -1;  		udelay(10);  	}  	return 0;  } -static void irq_busy(struct sh_i2c *base) +static void sh_irq_busy(struct sh_i2c *dev)  {  	int i; -	for (i = 0 ; i < IRQ_WAIT ; i++) { -		if (!(SH_IC_BUSY & readb(&base->icsr))) +	for (i = 0; i < IRQ_WAIT; i++) { +		if (!(SH_IC_BUSY & readb(&dev->icsr)))  			break;  		udelay(10);  	}  } -static int i2c_set_addr(struct sh_i2c *base, u8 id, u8 reg, int stop) +static int sh_i2c_set_addr(struct sh_i2c *dev, u8 chip, u8 addr, int stop)  {  	u8 icic = SH_IC_TACK; -	clrbits_8(&base->iccr, SH_I2C_ICCR_ICE); -	setbits_8(&base->iccr, SH_I2C_ICCR_ICE); +	debug("%s: chip: %x, addr: %x iccl: %x, icch %x\n", +				__func__, chip, addr, iccl, icch); +	clrbits_8(&dev->iccr, SH_I2C_ICCR_ICE); +	setbits_8(&dev->iccr, SH_I2C_ICCR_ICE); -	writeb(iccl & 0xff, &base->iccl); -	writeb(icch & 0xff, &base->icch); +	writeb(iccl & 0xff, &dev->iccl); +	writeb(icch & 0xff, &dev->icch);  #ifdef CONFIG_SH_I2C_8BIT  	if (iccl > 0xff)  		icic |= SH_I2C_ICIC_ICCLB8;  	if (icch > 0xff)  		icic |= SH_I2C_ICIC_ICCHB8;  #endif -	writeb(icic, &base->icic); +	writeb(icic, &dev->icic); -	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RTS|SH_I2C_ICCR_BUSY), &base->iccr); -	irq_dte(base); +	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RTS|SH_I2C_ICCR_BUSY), &dev->iccr); +	sh_irq_dte(dev); -	clrbits_8(&base->icsr, SH_IC_TACK); -	writeb(id << 1, &base->icdr); -	if (irq_dte_with_tack(base) != 0) +	clrbits_8(&dev->icsr, SH_IC_TACK); +	writeb(chip << 1, &dev->icdr); +	if (sh_irq_dte_with_tack(dev) != 0)  		return -1; -	writeb(reg, &base->icdr); +	writeb(addr, &dev->icdr);  	if (stop) -		writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RTS), &base->iccr); +		writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RTS), &dev->iccr); -	if (irq_dte_with_tack(base) != 0) +	if (sh_irq_dte_with_tack(dev) != 0)  		return -1;  	return 0;  } -static void i2c_finish(struct sh_i2c *base) +static void sh_i2c_finish(struct sh_i2c *dev)  { -	writeb(0, &base->icsr); -	clrbits_8(&base->iccr, SH_I2C_ICCR_ICE); +	writeb(0, &dev->icsr); +	clrbits_8(&dev->iccr, SH_I2C_ICCR_ICE);  } -static int i2c_raw_write(struct sh_i2c *base, u8 id, u8 reg, u8 val) +static int +sh_i2c_raw_write(struct sh_i2c *dev, u8 chip, uint addr, u8 val)  {  	int ret = -1; -	if (i2c_set_addr(base, id, reg, 0) != 0) +	if (sh_i2c_set_addr(dev, chip, addr, 0) != 0)  		goto exit0;  	udelay(10); -	writeb(val, &base->icdr); -	if (irq_dte_with_tack(base) != 0) +	writeb(val, &dev->icdr); +	if (sh_irq_dte_with_tack(dev) != 0)  		goto exit0; -	writeb((SH_I2C_ICCR_ICE | SH_I2C_ICCR_RTS), &base->iccr); -	if (irq_dte_with_tack(base) != 0) +	writeb((SH_I2C_ICCR_ICE | SH_I2C_ICCR_RTS), &dev->iccr); +	if (sh_irq_dte_with_tack(dev) != 0)  		goto exit0; -	irq_busy(base); +	sh_irq_busy(dev);  	ret = 0; +  exit0: -	i2c_finish(base); +	sh_i2c_finish(dev);  	return ret;  } -static int i2c_raw_read(struct sh_i2c *base, u8 id, u8 reg) +static int sh_i2c_raw_read(struct sh_i2c *dev, u8 chip, u8 addr)  {  	int ret = -1;  #if defined(CONFIG_SH73A0) -	if (i2c_set_addr(base, id, reg, 0) != 0) +	if (sh_i2c_set_addr(dev, chip, addr, 0) != 0)  		goto exit0;  #else -	if (i2c_set_addr(base, id, reg, 1) != 0) +	if (sh_i2c_set_addr(dev, chip, addr, 1) != 0)  		goto exit0;  	udelay(100);  #endif -	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RTS|SH_I2C_ICCR_BUSY), &base->iccr); -	irq_dte(base); +	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RTS|SH_I2C_ICCR_BUSY), &dev->iccr); +	sh_irq_dte(dev); -	writeb(id << 1 | 0x01, &base->icdr); -	if (irq_dte_with_tack(base) != 0) +	writeb(chip << 1 | 0x01, &dev->icdr); +	if (sh_irq_dte_with_tack(dev) != 0)  		goto exit0; -	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_SCP), &base->iccr); -	if (irq_dte_with_tack(base) != 0) +	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_SCP), &dev->iccr); +	if (sh_irq_dte_with_tack(dev) != 0)  		goto exit0; -	ret = readb(&base->icdr) & 0xff; +	ret = readb(&dev->icdr) & 0xff; + +	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RACK), &dev->iccr); +	readb(&dev->icdr); /* Dummy read */ +	sh_irq_busy(dev); -	writeb((SH_I2C_ICCR_ICE|SH_I2C_ICCR_RACK), &base->iccr); -	readb(&base->icdr); /* Dummy read */ -	irq_busy(base);  exit0: -	i2c_finish(base); +	sh_i2c_finish(dev);  	return ret;  } -#ifdef CONFIG_I2C_MULTI_BUS -static unsigned int current_bus; - -/** - * i2c_set_bus_num - change active I2C bus - *	@bus: bus index, zero based - *	@returns: 0 on success, non-0 on failure - */ -int i2c_set_bus_num(unsigned int bus) -{ -	if ((bus < 0) || (bus >= CONFIG_SYS_MAX_I2C_BUS)) { -		printf("Bad bus: %d\n", bus); -		return -1; -	} - -	switch (bus) { -	case 0: -		base = (void *)CONFIG_SH_I2C_BASE0; -		break; -	case 1: -		base = (void *)CONFIG_SH_I2C_BASE1; -		break; -#ifdef CONFIG_SH_I2C_BASE2 -	case 2: -		base = (void *)CONFIG_SH_I2C_BASE2; -		break; -#endif -#ifdef CONFIG_SH_I2C_BASE3 -	case 3: -		base = (void *)CONFIG_SH_I2C_BASE3; -		break; -#endif -#ifdef CONFIG_SH_I2C_BASE4 -	case 4: -		base = (void *)CONFIG_SH_I2C_BASE4; -		break; -#endif -	default: -		return -1; -	} -	current_bus = bus; - -	return 0; -} - -/** - * i2c_get_bus_num - returns index of active I2C bus - */ -unsigned int i2c_get_bus_num(void) -{ -	return current_bus; -} -#endif - -#define SH_I2C_ICCL_CALC(clk, date, t_low, t_high) \ -		((clk / rate) * (t_low / t_low + t_high)) -#define SH_I2C_ICCH_CALC(clk, date, t_low, t_high) \ -		((clk / rate) * (t_high / t_low + t_high)) - -void i2c_init(int speed, int slaveaddr) +static void +sh_i2c_init(struct i2c_adapter *adap, int speed, int slaveadd)  {  	int num, denom, tmp; @@ -246,11 +208,6 @@ void i2c_init(int speed, int slaveaddr)  	if (!(gd->flags & GD_FLG_RELOC))  		return; -#ifdef CONFIG_I2C_MULTI_BUS -	current_bus = 0; -#endif -	base = (struct sh_i2c *)CONFIG_SH_I2C_BASE0; -  	/*  	 * Calculate the value for iccl. From the data sheet:  	 * iccl = (p-clock / transfer-rate) * (L / (L + H)) @@ -272,67 +229,78 @@ void i2c_init(int speed, int slaveaddr)  		icch = (u16)((num/denom) + 1);  	else  		icch = (u16)(num/denom); + +	debug("clock: %d, speed %d, iccl: %x, icch: %x\n", +			CONFIG_SH_I2C_CLOCK, speed, iccl, icch);  } -/* - * i2c_read: - Read multiple bytes from an i2c device - * - * The higher level routines take into account that this function is only - * called with len < page length of the device (see configuration file) - * - * @chip:   address of the chip which is to be read - * @addr:   i2c data address within the chip - * @alen:   length of the i2c data address (1..2 bytes) - * @buffer: where to write the data - * @len:    how much byte do we want to read - * @return: 0 in case of success - */ -int i2c_read(u8 chip, u32 addr, int alen, u8 *buffer, int len) +static int sh_i2c_read(struct i2c_adapter *adap, uint8_t chip, +				uint addr, int alen, u8 *data, int len)  { -	int ret; -	int i = 0; -	for (i = 0 ; i < len ; i++) { -		ret = i2c_raw_read(base, chip, addr + i); +	int ret, i; +	struct sh_i2c *dev = (struct sh_i2c *)i2c_dev[adap->hwadapnr]; + +	for (i = 0; i < len; i++) { +		ret = sh_i2c_raw_read(dev, chip, addr + i);  		if (ret < 0)  			return -1; -		buffer[i] = ret & 0xff; + +		data[i] = ret & 0xff; +		debug("%s: data[%d]: %02x\n", __func__, i, data[i]);  	} +  	return 0;  } -/* - * i2c_write: -  Write multiple bytes to an i2c device - * - * The higher level routines take into account that this function is only - * called with len < page length of the device (see configuration file) - * - * @chip:   address of the chip which is to be written - * @addr:   i2c data address within the chip - * @alen:   length of the i2c data address (1..2 bytes) - * @buffer: where to find the data to be written - * @len:    how much byte do we want to read - * @return: 0 in case of success - */ -int i2c_write(u8 chip, u32 addr, int alen, u8 *buffer, int len) +static int sh_i2c_write(struct i2c_adapter *adap, uint8_t chip, uint addr, +				int alen, u8 *data, int len)  { -	int i = 0; -	for (i = 0; i < len ; i++) -		if (i2c_raw_write(base, chip, addr + i, buffer[i]) != 0) +	struct sh_i2c *dev = (struct sh_i2c *)i2c_dev[adap->hwadapnr]; +	int i; + +	for (i = 0; i < len; i++) { +		debug("%s: data[%d]: %02x\n", __func__, i, data[i]); +		if (sh_i2c_raw_write(dev, chip, addr + i, data[i]) != 0)  			return -1; +	}  	return 0;  } -/* - * i2c_probe: - Test if a chip answers for a given i2c address - * - * @chip:   address of the chip which is searched for - * @return: 0 if a chip was found, -1 otherwhise - */ -int i2c_probe(u8 chip) +static int +sh_i2c_probe(struct i2c_adapter *adap, u8 dev)  { -	int ret; +	return sh_i2c_read(adap, dev, 0, 0, NULL, 0); +} -	ret = i2c_set_addr(base, chip, 0, 1); -	i2c_finish(base); -	return ret; +static unsigned int sh_i2c_set_bus_speed(struct i2c_adapter *adap, +			unsigned int speed) +{ +	struct sh_i2c *dev = (struct sh_i2c *)i2c_dev[adap->hwadapnr]; + +	sh_i2c_finish(dev); +	sh_i2c_init(adap, speed, 0); + +	return 0;  } + +/* + * Register RCAR i2c adapters + */ +U_BOOT_I2C_ADAP_COMPLETE(sh_0, sh_i2c_init, sh_i2c_probe, sh_i2c_read, +	sh_i2c_write, sh_i2c_set_bus_speed, CONFIG_SYS_I2C_SH_SPEED0, 0, 0) +#ifdef CONFIG_SYS_I2C_SH_BASE1 +U_BOOT_I2C_ADAP_COMPLETE(sh_1, sh_i2c_init, sh_i2c_probe, sh_i2c_read, +	sh_i2c_write, sh_i2c_set_bus_speed, CONFIG_SYS_I2C_SH_SPEED1, 0, 1) +#endif +#ifdef CONFIG_SYS_I2C_SH_BASE2 +U_BOOT_I2C_ADAP_COMPLETE(sh_2, sh_i2c_init, sh_i2c_probe, sh_i2c_read, +	sh_i2c_write, sh_i2c_set_bus_speed, CONFIG_SYS_I2C_SH_SPEED2, 0, 2) +#endif +#ifdef CONFIG_SYS_I2C_SH_BASE3 +U_BOOT_I2C_ADAP_COMPLETE(sh_3, sh_i2c_init, sh_i2c_probe, sh_i2c_read, +	sh_i2c_write, sh_i2c_set_bus_speed, CONFIG_SYS_I2C_SH_SPEED3, 0, 3) +#endif +#ifdef CONFIG_SYS_I2C_SH_BASE4 +U_BOOT_I2C_ADAP_COMPLETE(sh_4, sh_i2c_init, sh_i2c_probe, sh_i2c_read, +	sh_i2c_write, sh_i2c_set_bus_speed, CONFIG_SYS_I2C_SH_SPEED4, 0, 4) +#endif diff --git a/drivers/i2c/zynq_i2c.c b/drivers/i2c/zynq_i2c.c index ce2d23f72..70a9aeafd 100644 --- a/drivers/i2c/zynq_i2c.c +++ b/drivers/i2c/zynq_i2c.c @@ -74,7 +74,8 @@ static struct zynq_i2c_registers *zynq_i2c =  	(struct zynq_i2c_registers *)ZYNQ_I2C_BASE;  /* I2C init called by cmd_i2c when doing 'i2c reset'. */ -void i2c_init(int requested_speed, int slaveadd) +static void zynq_i2c_init(struct i2c_adapter *adap, int requested_speed, +			  int slaveadd)  {  	/* 111MHz / ( (3 * 17) * 22 ) = ~100KHz */  	writel((16 << ZYNQ_I2C_CONTROL_DIV_B_SHIFT) | @@ -151,7 +152,7 @@ static u32 zynq_i2c_wait(u32 mask)   * I2C probe called by cmd_i2c when doing 'i2c probe'.   * Begin read, nak data byte, end.   */ -int i2c_probe(u8 dev) +static int zynq_i2c_probe(struct i2c_adapter *adap, u8 dev)  {  	/* Attempt to read a byte */  	setbits_le32(&zynq_i2c->control, ZYNQ_I2C_CONTROL_CLR_FIFO | @@ -170,7 +171,8 @@ int i2c_probe(u8 dev)   * I2C read called by cmd_i2c when doing 'i2c read' and by cmd_eeprom.c   * Begin write, send address byte(s), begin read, receive data bytes, end.   */ -int i2c_read(u8 dev, uint addr, int alen, u8 *data, int length) +static int zynq_i2c_read(struct i2c_adapter *adap, u8 dev, uint addr, +			 int alen, u8 *data, int length)  {  	u32 status;  	u32 i = 0; @@ -235,7 +237,8 @@ int i2c_read(u8 dev, uint addr, int alen, u8 *data, int length)   * I2C write called by cmd_i2c when doing 'i2c write' and by cmd_eeprom.c   * Begin write, send address byte(s), send data bytes, end.   */ -int i2c_write(u8 dev, uint addr, int alen, u8 *data, int length) +static int zynq_i2c_write(struct i2c_adapter *adap, u8 dev, uint addr, +			  int alen, u8 *data, int length)  {  	u8 *cur_data = data; @@ -275,16 +278,16 @@ int i2c_write(u8 dev, uint addr, int alen, u8 *data, int length)  	return 0;  } -int i2c_set_bus_num(unsigned int bus) +static unsigned int zynq_i2c_set_bus_speed(struct i2c_adapter *adap, +			unsigned int speed)  { -	/* Only support bus 0 */ -	if (bus > 0) -		return -1; -	return 0; -} +	if (speed != 1000000) +		return -EINVAL; -unsigned int i2c_get_bus_num(void) -{ -	/* Only support bus 0 */  	return 0;  } + +U_BOOT_I2C_ADAP_COMPLETE(zynq_0, zynq_i2c_init, zynq_i2c_probe, zynq_i2c_read, +			 zynq_i2c_write, zynq_i2c_set_bus_speed, +			 CONFIG_SYS_I2C_ZYNQ_SPEED, CONFIG_SYS_I2C_ZYNQ_SLAVE, +			 0) diff --git a/drivers/net/fm/Makefile b/drivers/net/fm/Makefile index bec86c16c..d0fd7fcce 100644 --- a/drivers/net/fm/Makefile +++ b/drivers/net/fm/Makefile @@ -4,7 +4,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifdef CONFIG_FMAN_ENET  obj-y += dtsec.o  obj-y += eth.o  obj-y += fm.o @@ -26,8 +25,10 @@ obj-$(CONFIG_PPC_P4080) += p4080.o  obj-$(CONFIG_PPC_P5020) += p5020.o  obj-$(CONFIG_PPC_P5040) += p5040.o  obj-$(CONFIG_PPC_T1040) += t1040.o +obj-$(CONFIG_PPC_T1042)	+= t1040.o +obj-$(CONFIG_PPC_T1020)	+= t1040.o +obj-$(CONFIG_PPC_T1022)	+= t1040.o  obj-$(CONFIG_PPC_T4240) += t4240.o  obj-$(CONFIG_PPC_T4160) += t4240.o  obj-$(CONFIG_PPC_B4420) += b4860.o  obj-$(CONFIG_PPC_B4860) += b4860.o -endif diff --git a/drivers/net/npe/Makefile b/drivers/net/npe/Makefile index 7fa5ea635..e36c0bbd6 100644 --- a/drivers/net/npe/Makefile +++ b/drivers/net/npe/Makefile @@ -10,7 +10,7 @@ CFLAGS  += $(LOCAL_CFLAGS)  CPPFLAGS  += $(LOCAL_CFLAGS) # needed for depend  HOSTCFLAGS  += $(LOCAL_CFLAGS) -obj-$(CONFIG_IXP4XX_NPE) := npe.o \ +obj-y := npe.o \  	miiphy.o \  	IxOsalBufferMgt.o \  	IxOsalIoMem.o \ diff --git a/drivers/qe/Makefile b/drivers/qe/Makefile index b8c15f8e1..7f1bd0692 100644 --- a/drivers/qe/Makefile +++ b/drivers/qe/Makefile @@ -4,5 +4,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(and $(CONFIG_QE),$(CONFIG_OF_LIBFDT)) += fdt.o -obj-$(CONFIG_QE) += qe.o uccf.o uec.o uec_phy.o +obj-y := qe.o uccf.o uec.o uec_phy.o +obj-$(CONFIG_OF_LIBFDT) += fdt.o diff --git a/drivers/tpm/Makefile b/drivers/tpm/Makefile index 4b8cbecaf..2f2353f80 100644 --- a/drivers/tpm/Makefile +++ b/drivers/tpm/Makefile @@ -3,8 +3,6 @@  # SPDX-License-Identifier:	GPL-2.0+  # -$(shell mkdir -p $(obj)slb9635_i2c) -  # TODO: Merge tpm_tis_lpc.c with tpm.c  obj-$(CONFIG_TPM_ATMEL_TWI) += tpm_atmel_twi.o  obj-$(CONFIG_TPM_TIS_I2C) += tpm.o diff --git a/drivers/tpm/tis_i2c.c b/drivers/tpm/tis_i2c.c deleted file mode 100644 index 22554e145..000000000 --- a/drivers/tpm/tis_i2c.c +++ /dev/null @@ -1,185 +0,0 @@ -/* - * Copyright (c) 2012 The Chromium OS Authors. All rights reserved. - * Use of this source code is governed by a BSD-style license that can be - * found in the LICENSE file. - */ - -#include <config.h> -#include <common.h> -#include <fdtdec.h> -#include <i2c.h> -#include "slb9635_i2c/tpm.h" - -DECLARE_GLOBAL_DATA_PTR; - -/* TPM configuration */ -struct tpm { -	int i2c_bus; -	int slave_addr; -	char inited; -	int old_bus; -} tpm; - - -static int tpm_select(void) -{ -	int ret; - -	tpm.old_bus = i2c_get_bus_num(); -	if (tpm.old_bus != tpm.i2c_bus) { -		ret = i2c_set_bus_num(tpm.i2c_bus); -		if (ret) { -			debug("%s: Fail to set i2c bus %d\n", __func__, -			      tpm.i2c_bus); -			return -1; -		} -	} -	return 0; -} - -static int tpm_deselect(void) -{ -	int ret; - -	if (tpm.old_bus != i2c_get_bus_num()) { -		ret = i2c_set_bus_num(tpm.old_bus); -		if (ret) { -			debug("%s: Fail to restore i2c bus %d\n", -			      __func__, tpm.old_bus); -			return -1; -		} -	} -	tpm.old_bus = -1; -	return 0; -} - -/** - * Decode TPM configuration. - * - * @param dev	Returns a configuration of TPM device - * @return 0 if ok, -1 on error - */ -static int tpm_decode_config(struct tpm *dev) -{ -#ifdef CONFIG_OF_CONTROL -	const void *blob = gd->fdt_blob; -	int node, parent; -	int i2c_bus; - -	node = fdtdec_next_compatible(blob, 0, COMPAT_INFINEON_SLB9635_TPM); -	if (node < 0) { -		node = fdtdec_next_compatible(blob, 0, -					      COMPAT_INFINEON_SLB9645_TPM); -	} -	if (node < 0) { -		debug("%s: Node not found\n", __func__); -		return -1; -	} -	parent = fdt_parent_offset(blob, node); -	if (parent < 0) { -		debug("%s: Cannot find node parent\n", __func__); -		return -1; -	} -	i2c_bus = i2c_get_bus_num_fdt(parent); -	if (i2c_bus < 0) -		return -1; -	dev->i2c_bus = i2c_bus; -	dev->slave_addr = fdtdec_get_addr(blob, node, "reg"); -#else -	dev->i2c_bus = CONFIG_INFINEON_TPM_I2C_BUS; -	dev->slave_addr = CONFIG_INFINEON_TPM_I2C_ADDR; -#endif -	return 0; -} - -int tis_init(void) -{ -	if (tpm.inited) -		return 0; - -	if (tpm_decode_config(&tpm)) -		return -1; - -	if (tpm_select()) -		return -1; - -	/* -	 * Probe TPM twice; the first probing might fail because TPM is asleep, -	 * and the probing can wake up TPM. -	 */ -	if (i2c_probe(tpm.slave_addr) && i2c_probe(tpm.slave_addr)) { -		debug("%s: fail to probe i2c addr 0x%x\n", __func__, -		      tpm.slave_addr); -		return -1; -	} - -	tpm_deselect(); - -	tpm.inited = 1; - -	return 0; -} - -int tis_open(void) -{ -	int rc; - -	if (!tpm.inited) -		return -1; - -	if (tpm_select()) -		return -1; - -	rc = tpm_open(tpm.slave_addr); - -	tpm_deselect(); - -	return rc; -} - -int tis_close(void) -{ -	if (!tpm.inited) -		return -1; - -	if (tpm_select()) -		return -1; - -	tpm_close(); - -	tpm_deselect(); - -	return 0; -} - -int tis_sendrecv(const uint8_t *sendbuf, size_t sbuf_size, -		uint8_t *recvbuf, size_t *rbuf_len) -{ -	int len; -	uint8_t buf[4096]; - -	if (!tpm.inited) -		return -1; - -	if (sizeof(buf) < sbuf_size) -		return -1; - -	memcpy(buf, sendbuf, sbuf_size); - -	if (tpm_select()) -		return -1; - -	len = tpm_transmit(buf, sbuf_size); - -	tpm_deselect(); - -	if (len < 10) { -		*rbuf_len = 0; -		return -1; -	} - -	memcpy(recvbuf, buf, len); -	*rbuf_len = len; - -	return 0; -} diff --git a/examples/standalone/Makefile b/examples/standalone/Makefile index 4afedea06..93469217e 100644 --- a/examples/standalone/Makefile +++ b/examples/standalone/Makefile @@ -8,7 +8,6 @@  include $(TOPDIR)/config.mk  ELF-$(ARCH)  := -ELF-$(BOARD) :=  ELF-$(CPU)   :=  ELF-y        := hello_world @@ -20,14 +19,13 @@ ELF-mpc5xxx                      += interrupt  ELF-mpc8xx                       += test_burst timer  ELF-mpc8260                      += mem_to_mem_idma2intr  ELF-ppc                          += sched -ELF-oxc                          += eepro100_eeprom  #  # Some versions of make do not handle trailing white spaces properly;  # leading to build failures. The problem was found with GNU Make 3.80.  # Using 'strip' as a workaround for the problem.  # -ELF := $(strip $(ELF-y) $(ELF-$(ARCH)) $(ELF-$(BOARD)) $(ELF-$(CPU))) +ELF := $(strip $(ELF-y) $(ELF-$(ARCH)) $(ELF-$(CPU)))  SREC := $(addsuffix .srec,$(ELF))  BIN  := $(addsuffix .bin,$(ELF)) diff --git a/examples/standalone/eepro100_eeprom.c b/examples/standalone/eepro100_eeprom.c deleted file mode 100644 index 3c7f38097..000000000 --- a/examples/standalone/eepro100_eeprom.c +++ /dev/null @@ -1,214 +0,0 @@ -/* - * Copyright 1998-2001 by Donald Becker. - * This software may be used and distributed according to the terms of - * the GNU General Public License (GPL), incorporated herein by reference. - * Contact the author for use under other terms. - * - * This program must be compiled with "-O"! - * See the bottom of this file for the suggested compile-command. - * - * The author may be reached as becker@scyld.com, or C/O - *  Scyld Computing Corporation - *  410 Severn Ave., Suite 210 - *  Annapolis MD 21403 - * - * Common-sense licensing statement: Using any portion of this program in - * your own program means that you must give credit to the original author - * and release the resulting code under the GPL. - */ - -/* avoid unnecessary memcpy function */ -#define _PPC_STRING_H_ - -#include <common.h> -#include <exports.h> - -static int reset_eeprom(unsigned long ioaddr, unsigned char *hwaddr); - -int eepro100_eeprom(int argc, char * const argv[]) -{ -	int ret = 0; - -	unsigned char hwaddr1[6] = { 0x00, 0x00, 0x02, 0x03, 0x04, 0x05 }; -	unsigned char hwaddr2[6] = { 0x00, 0x00, 0x02, 0x03, 0x04, 0x06 }; - -	app_startup(argv); - -#if defined(CONFIG_OXC) -	ret |= reset_eeprom(0x80000000, hwaddr1); -	ret |= reset_eeprom(0x81000000, hwaddr2); -#endif - -	return ret; -} - -/* Default EEPROM for i82559 */ -static unsigned short default_eeprom[64] = { -	0x0100, 0x0302, 0x0504, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0x40c0, 0x0000, 0x0000, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, -	0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff, 0xffff -}; - -static unsigned short eeprom[256]; - -static int eeprom_size = 64; -static int eeprom_addr_size = 6; - -static int debug = 0; - -static inline unsigned short swap16(unsigned short x) -{ -	return (((x & 0xff) << 8) | ((x & 0xff00) >> 8)); -} - -static inline void outw(short data, long addr) -{ -	*(volatile short *)(addr) = swap16(data); -} - -static inline short inw(long addr) -{ -	return swap16(*(volatile short *)(addr)); -} - -void *memcpy(void *dst, const void *src, unsigned int len) -{ -	char *ret = dst; -	while (len-- > 0) { -		*ret++ = *((char *)src); -		src++; -	} -	return (void *)ret; -} - -/* The EEPROM commands include the alway-set leading bit. */ -#define EE_WRITE_CMD	(5) -#define EE_READ_CMD		(6) -#define EE_ERASE_CMD	(7) - -/* Serial EEPROM section. */ -#define EE_SHIFT_CLK	0x01	/* EEPROM shift clock. */ -#define EE_CS			0x02	/* EEPROM chip select. */ -#define EE_DATA_WRITE	0x04	/* EEPROM chip data in. */ -#define EE_DATA_READ	0x08	/* EEPROM chip data out. */ -#define EE_ENB			(0x4800 | EE_CS) -#define EE_WRITE_0		0x4802 -#define EE_WRITE_1		0x4806 -#define EE_OFFSET		14 - -/* Delay between EEPROM clock transitions. */ -#define eeprom_delay(ee_addr)	inw(ee_addr) - -/* Wait for the EEPROM to finish the previous operation. */ -static int eeprom_busy_poll(long ee_ioaddr) -{ -	int i; -	outw(EE_ENB, ee_ioaddr); -	for (i = 0; i < 10000; i++)			/* Typical 2000 ticks */ -		if (inw(ee_ioaddr) & EE_DATA_READ) -			break; -	return i; -} - -/* This executes a generic EEPROM command, typically a write or write enable. -   It returns the data output from the EEPROM, and thus may also be used for -   reads. */ -static int do_eeprom_cmd(long ioaddr, int cmd, int cmd_len) -{ -	unsigned retval = 0; -	long ee_addr = ioaddr + EE_OFFSET; - -	if (debug > 1) -		printf(" EEPROM op 0x%x: ", cmd); - -	outw(EE_ENB | EE_SHIFT_CLK, ee_addr); - -	/* Shift the command bits out. */ -	do { -		short dataval = (cmd & (1 << cmd_len)) ? EE_WRITE_1 : EE_WRITE_0; -		outw(dataval, ee_addr); -		eeprom_delay(ee_addr); -		if (debug > 2) -			printf("%X", inw(ee_addr) & 15); -		outw(dataval | EE_SHIFT_CLK, ee_addr); -		eeprom_delay(ee_addr); -		retval = (retval << 1) | ((inw(ee_addr) & EE_DATA_READ) ? 1 : 0); -	} while (--cmd_len >= 0); -#if 0 -	outw(EE_ENB, ee_addr); -#endif -	/* Terminate the EEPROM access. */ -	outw(EE_ENB & ~EE_CS, ee_addr); -	if (debug > 1) -		printf(" EEPROM result is 0x%5.5x.\n", retval); -	return retval; -} - -static int read_eeprom(long ioaddr, int location, int addr_len) -{ -	return do_eeprom_cmd(ioaddr, ((EE_READ_CMD << addr_len) | location) -		<< 16 , 3 + addr_len + 16) & 0xffff; -} - -static void write_eeprom(long ioaddr, int index, int value, int addr_len) -{ -	long ee_ioaddr = ioaddr + EE_OFFSET; -	int i; - -	/* Poll for previous op finished. */ -	eeprom_busy_poll(ee_ioaddr);			/* Typical 0 ticks */ -	/* Enable programming modes. */ -	do_eeprom_cmd(ioaddr, (0x4f << (addr_len-4)), 3 + addr_len); -	/* Do the actual write. */ -	do_eeprom_cmd(ioaddr, -				  (((EE_WRITE_CMD<<addr_len) | index)<<16) | (value & 0xffff), -				  3 + addr_len + 16); -	/* Poll for write finished. */ -	i = eeprom_busy_poll(ee_ioaddr);			/* Typical 2000 ticks */ -	if (debug) -		printf(" Write finished after %d ticks.\n", i); -	/* Disable programming. This command is not instantaneous, so we check -	   for busy before the next op. */ -	do_eeprom_cmd(ioaddr, (0x40 << (addr_len-4)), 3 + addr_len); -	eeprom_busy_poll(ee_ioaddr); -} - -static int reset_eeprom(unsigned long ioaddr, unsigned char *hwaddr) -{ -	unsigned short checksum = 0; -	int size_test; -	int i; - -	printf("Resetting i82559 EEPROM @ 0x%08lX ... ", ioaddr); - -	size_test = do_eeprom_cmd(ioaddr, (EE_READ_CMD << 8) << 16, 27); -	eeprom_addr_size = (size_test & 0xffe0000) == 0xffe0000 ? 8 : 6; -	eeprom_size = 1 << eeprom_addr_size; - -	memcpy(eeprom, default_eeprom, sizeof default_eeprom); - -	for (i = 0; i < 3; i++) -		eeprom[i] = (hwaddr[i*2+1]<<8) + hwaddr[i*2]; - -	/* Recalculate the checksum. */ -	for (i = 0; i < eeprom_size - 1; i++) -		checksum += eeprom[i]; -	eeprom[i] = 0xBABA - checksum; - -	for (i = 0; i < eeprom_size; i++) -		write_eeprom(ioaddr, i, eeprom[i], eeprom_addr_size); - -	for (i = 0; i < eeprom_size; i++) -		if (read_eeprom(ioaddr, i, eeprom_addr_size) != eeprom[i]) { -			printf("failed\n"); -			return 1; -		} - -	printf("done\n"); -	return 0; -} diff --git a/fs/Makefile b/fs/Makefile index bdcd74631..34dc0351e 100644 --- a/fs/Makefile +++ b/fs/Makefile @@ -6,15 +6,20 @@  # SPDX-License-Identifier:	GPL-2.0+  # +ifdef CONFIG_SPL_BUILD +obj-$(CONFIG_SPL_FAT_SUPPORT) += fat/ +else  obj-y				+= fs.o -obj-y += cbfs/ -obj-y += cramfs/ -obj-y += ext4/ -obj-y += fdos/ -obj-y += jffs2/ -obj-y += reiserfs/ -obj-y += sandbox/ -obj-y += ubifs/ -obj-y += yaffs2/ -obj-y += zfs/ +obj-$(CONFIG_CMD_CBFS) += cbfs/ +obj-$(CONFIG_CMD_CRAMFS) += cramfs/ +obj-$(CONFIG_FS_EXT4) += ext4/ +obj-y += fat/ +obj-$(CONFIG_CMD_FDOS) += fdos/ +obj-$(CONFIG_CMD_JFFS2) += jffs2/ +obj-$(CONFIG_CMD_REISER) += reiserfs/ +obj-$(CONFIG_SANDBOX) += sandbox/ +obj-$(CONFIG_CMD_UBIFS) += ubifs/ +obj-$(CONFIG_YAFFS2) += yaffs2/ +obj-$(CONFIG_CMD_ZFS) += zfs/ +endif diff --git a/fs/cbfs/Makefile b/fs/cbfs/Makefile index 6f33d2813..a106e05dd 100644 --- a/fs/cbfs/Makefile +++ b/fs/cbfs/Makefile @@ -3,4 +3,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_CMD_CBFS)	:= cbfs.o +obj-y	:= cbfs.o diff --git a/fs/cramfs/Makefile b/fs/cramfs/Makefile index e2b2c7366..12d73a375 100644 --- a/fs/cramfs/Makefile +++ b/fs/cramfs/Makefile @@ -5,5 +5,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_CMD_CRAMFS) := cramfs.o -obj-$(CONFIG_CMD_CRAMFS) += uncompress.o +obj-y := cramfs.o +obj-y += uncompress.o diff --git a/fs/ext4/Makefile b/fs/ext4/Makefile index 0f5d3995c..8d15bdad6 100644 --- a/fs/ext4/Makefile +++ b/fs/ext4/Makefile @@ -9,5 +9,5 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_FS_EXT4) := ext4fs.o ext4_common.o dev.o +obj-y := ext4fs.o ext4_common.o dev.o  obj-$(CONFIG_EXT4_WRITE) += ext4_write.o ext4_journal.o crc16.o diff --git a/fs/fdos/Makefile b/fs/fdos/Makefile index 95480af3e..2f8b5addd 100644 --- a/fs/fdos/Makefile +++ b/fs/fdos/Makefile @@ -10,4 +10,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_CMD_FDOS) := fat.o vfat.o dev.o fdos.o fs.o subdir.o +obj-y := fat.o vfat.o dev.o fdos.o fs.o subdir.o diff --git a/fs/jffs2/Makefile b/fs/jffs2/Makefile index 02e481f3c..4cb0600cf 100644 --- a/fs/jffs2/Makefile +++ b/fs/jffs2/Makefile @@ -5,11 +5,9 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifdef CONFIG_CMD_JFFS2  obj-$(CONFIG_JFFS2_LZO) += compr_lzo.o  obj-y += compr_rtime.o  obj-y += compr_rubin.o  obj-y += compr_zlib.o  obj-y += jffs2_1pass.o  obj-y += mini_inflate.o -endif diff --git a/fs/reiserfs/Makefile b/fs/reiserfs/Makefile index 55f70b1a9..5a692f0ee 100644 --- a/fs/reiserfs/Makefile +++ b/fs/reiserfs/Makefile @@ -9,4 +9,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_CMD_REISER) := reiserfs.o dev.o mode_string.o +obj-y := reiserfs.o dev.o mode_string.o diff --git a/fs/sandbox/Makefile b/fs/sandbox/Makefile index faa7c16ba..ca238f6d7 100644 --- a/fs/sandbox/Makefile +++ b/fs/sandbox/Makefile @@ -10,4 +10,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_SANDBOX) := sandboxfs.o +obj-y := sandboxfs.o diff --git a/fs/ubifs/Makefile b/fs/ubifs/Makefile index 47d5a8fb0..389b0e37e 100644 --- a/fs/ubifs/Makefile +++ b/fs/ubifs/Makefile @@ -9,10 +9,10 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_CMD_UBIFS) := ubifs.o io.o super.o sb.o master.o lpt.o -obj-$(CONFIG_CMD_UBIFS) += lpt_commit.o scan.o lprops.o -obj-$(CONFIG_CMD_UBIFS) += tnc.o tnc_misc.o debug.o crc16.o budget.o -obj-$(CONFIG_CMD_UBIFS) += log.o orphan.o recovery.o replay.o +obj-y := ubifs.o io.o super.o sb.o master.o lpt.o +obj-y += lpt_commit.o scan.o lprops.o +obj-y += tnc.o tnc_misc.o debug.o crc16.o budget.o +obj-y += log.o orphan.o recovery.o replay.o  # SEE README.arm-unaligned-accesses  $(obj)super.o: CFLAGS += $(PLATFORM_NO_UNALIGNED) diff --git a/fs/yaffs2/Makefile b/fs/yaffs2/Makefile index 077af7834..d811287dd 100644 --- a/fs/yaffs2/Makefile +++ b/fs/yaffs2/Makefile @@ -16,7 +16,7 @@  #  # $Id: Makefile,v 1.15 2007/07/18 19:40:38 charles Exp $ -obj-$(CONFIG_YAFFS2) := \ +obj-y := \  	yaffs_allocator.o yaffs_attribs.o yaffs_bitmap.o yaffs_uboot_glue.o\  	yaffs_checkptrw.o yaffs_ecc.o yaffs_error.o \  	yaffsfs.o yaffs_guts.o yaffs_nameval.o yaffs_nand.o\ diff --git a/fs/zfs/Makefile b/fs/zfs/Makefile index 7090416b8..fa58b7fcd 100644 --- a/fs/zfs/Makefile +++ b/fs/zfs/Makefile @@ -5,4 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_CMD_ZFS) := dev.o zfs.o zfs_fletcher.o zfs_sha256.o zfs_lzjb.o +obj-y := dev.o zfs.o zfs_fletcher.o zfs_sha256.o zfs_lzjb.o diff --git a/include/configs/T1040QDS.h b/include/configs/T1040QDS.h index 2738242c5..7c6bec8f7 100644 --- a/include/configs/T1040QDS.h +++ b/include/configs/T1040QDS.h @@ -32,6 +32,8 @@  #ifdef CONFIG_RAMBOOT_PBL  #define CONFIG_RAMBOOT_TEXT_BASE	CONFIG_SYS_TEXT_BASE  #define CONFIG_RESET_VECTOR_ADDRESS	0xfffffffc +#define CONFIG_PBLPBI_CONFIG $(SRCTREE)/board/freescale/t1040qds/t1040_pbi.cfg +#define CONFIG_PBLRCW_CONFIG $(SRCTREE)/board/freescale/t1040qds/t1040_rcw.cfg  #endif  /* High Level Configuration Options */ diff --git a/include/configs/T1040RDB.h b/include/configs/T1040RDB.h new file mode 100644 index 000000000..620387fcd --- /dev/null +++ b/include/configs/T1040RDB.h @@ -0,0 +1,690 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ + +#ifndef __CONFIG_H +#define __CONFIG_H + +/* + * T1040 RDB board configuration file + */ +#define CONFIG_T104xRDB +#define CONFIG_T1040RDB +#define CONFIG_PHYS_64BIT + +#ifdef CONFIG_RAMBOOT_PBL +#define CONFIG_RAMBOOT_TEXT_BASE	CONFIG_SYS_TEXT_BASE +#define CONFIG_RESET_VECTOR_ADDRESS	0xfffffffc +#endif + +/* High Level Configuration Options */ +#define CONFIG_BOOKE +#define CONFIG_E500			/* BOOKE e500 family */ +#define CONFIG_E500MC			/* BOOKE e500mc family */ +#define CONFIG_SYS_BOOK3E_HV		/* Category E.HV supported */ +#define CONFIG_MPC85xx			/* MPC85xx/PQ3 platform */ +#define CONFIG_MP			/* support multiple processors */ + +#ifndef CONFIG_SYS_TEXT_BASE +#define CONFIG_SYS_TEXT_BASE	0xeff80000 +#endif + +#ifndef CONFIG_RESET_VECTOR_ADDRESS +#define CONFIG_RESET_VECTOR_ADDRESS	0xeffffffc +#endif + +#define CONFIG_SYS_FSL_CPC		/* Corenet Platform Cache */ +#define CONFIG_SYS_NUM_CPC		CONFIG_NUM_DDR_CONTROLLERS +#define CONFIG_FSL_IFC			/* Enable IFC Support */ +#define CONFIG_PCI			/* Enable PCI/PCIE */ +#define CONFIG_PCI_INDIRECT_BRIDGE +#define CONFIG_PCIE1			/* PCIE controler 1 */ +#define CONFIG_PCIE2			/* PCIE controler 2 */ +#define CONFIG_PCIE3			/* PCIE controler 3 */ +#define CONFIG_PCIE4			/* PCIE controler 4 */ + +#define CONFIG_FSL_PCI_INIT		/* Use common FSL init code */ +#define CONFIG_SYS_PCI_64BIT		/* enable 64-bit PCI resources */ + +#define CONFIG_FSL_LAW			/* Use common FSL init code */ + +#define CONFIG_ENV_OVERWRITE + +#ifdef CONFIG_SYS_NO_FLASH +#define CONFIG_ENV_IS_NOWHERE +#else +#define CONFIG_FLASH_CFI_DRIVER +#define CONFIG_SYS_FLASH_CFI +#define CONFIG_SYS_FLASH_USE_BUFFER_WRITE +#endif + +#ifndef CONFIG_SYS_NO_FLASH +#if defined(CONFIG_SPIFLASH) +#define CONFIG_SYS_EXTRA_ENV_RELOC +#define CONFIG_ENV_IS_IN_SPI_FLASH +#define CONFIG_ENV_SPI_BUS              0 +#define CONFIG_ENV_SPI_CS               0 +#define CONFIG_ENV_SPI_MAX_HZ           10000000 +#define CONFIG_ENV_SPI_MODE             0 +#define CONFIG_ENV_SIZE                 0x2000          /* 8KB */ +#define CONFIG_ENV_OFFSET               0x100000        /* 1MB */ +#define CONFIG_ENV_SECT_SIZE            0x10000 +#elif defined(CONFIG_SDCARD) +#define CONFIG_SYS_EXTRA_ENV_RELOC +#define CONFIG_ENV_IS_IN_MMC +#define CONFIG_SYS_MMC_ENV_DEV          0 +#define CONFIG_ENV_SIZE			0x2000 +#define CONFIG_ENV_OFFSET		(512 * 1105) +#elif defined(CONFIG_NAND) +#define CONFIG_SYS_EXTRA_ENV_RELOC +#define CONFIG_ENV_IS_IN_NAND +#define CONFIG_ENV_SIZE			CONFIG_SYS_NAND_BLOCK_SIZE +#define CONFIG_ENV_OFFSET		(5 * CONFIG_SYS_NAND_BLOCK_SIZE) +#else +#define CONFIG_ENV_IS_IN_FLASH +#define CONFIG_ENV_ADDR		(CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SECT_SIZE) +#define CONFIG_ENV_SIZE		0x2000 +#define CONFIG_ENV_SECT_SIZE	0x20000 /* 128K (one sector) */ +#endif +#else /* CONFIG_SYS_NO_FLASH */ +#define CONFIG_ENV_SIZE                0x2000 +#define CONFIG_ENV_SECT_SIZE   0x20000 /* 128K (one sector) */ +#endif + +#define CONFIG_SYS_CLK_FREQ	100000000 +#define CONFIG_DDR_CLK_FREQ	66666666 + +/* + * These can be toggled for performance analysis, otherwise use default. + */ +#define CONFIG_SYS_CACHE_STASHING +#define CONFIG_BACKSIDE_L2_CACHE +#define CONFIG_SYS_INIT_L2CSR0		L2CSR0_L2E +#define CONFIG_BTB			/* toggle branch predition */ +#define CONFIG_DDR_ECC +#ifdef CONFIG_DDR_ECC +#define CONFIG_ECC_INIT_VIA_DDRCONTROLLER +#define CONFIG_MEM_INIT_VALUE		0xdeadbeef +#endif + +#define CONFIG_ENABLE_36BIT_PHYS + +#define CONFIG_ADDR_MAP +#define CONFIG_SYS_NUM_ADDR_MAP		64	/* number of TLB1 entries */ + +#define CONFIG_SYS_MEMTEST_START	0x00200000	/* memtest works on */ +#define CONFIG_SYS_MEMTEST_END		0x00400000 +#define CONFIG_SYS_ALT_MEMTEST +#define CONFIG_PANIC_HANG	/* do not reset board on panic */ + +/* + *  Config the L3 Cache as L3 SRAM + */ +#define CONFIG_SYS_INIT_L3_ADDR		0xFFFC0000 + +#define CONFIG_SYS_DCSRBAR		0xf0000000 +#define CONFIG_SYS_DCSRBAR_PHYS		0xf00000000ull + +/* + * DDR Setup + */ +#define CONFIG_VERY_BIG_RAM +#define CONFIG_SYS_DDR_SDRAM_BASE	0x00000000 +#define CONFIG_SYS_SDRAM_BASE		CONFIG_SYS_DDR_SDRAM_BASE + +/* CONFIG_NUM_DDR_CONTROLLERS is defined in include/asm/config_mpc85xx.h */ +#define CONFIG_DIMM_SLOTS_PER_CTLR	1 +#define CONFIG_CHIP_SELECTS_PER_CTRL	(4 * CONFIG_DIMM_SLOTS_PER_CTLR) + +#define CONFIG_DDR_SPD +#define CONFIG_SYS_DDR_RAW_TIMING +#define CONFIG_FSL_DDR3 + +#define CONFIG_SYS_SPD_BUS_NUM	0 +#define SPD_EEPROM_ADDRESS	0x51 + +#define CONFIG_SYS_SDRAM_SIZE	4096	/* for fixed parameter use */ + +/* + * IFC Definitions + */ +#define CONFIG_SYS_FLASH_BASE	0xe8000000 +#define CONFIG_SYS_FLASH_BASE_PHYS	(0xf00000000ull | CONFIG_SYS_FLASH_BASE) + +#define CONFIG_SYS_NOR_CSPR_EXT	(0xf) +#define CONFIG_SYS_NOR_CSPR	(CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE) | \ +				CSPR_PORT_SIZE_16 | \ +				CSPR_MSEL_NOR | \ +				CSPR_V) +#define CONFIG_SYS_NOR_AMASK	IFC_AMASK(128*1024*1024) +/* NOR Flash Timing Params */ +#define CONFIG_SYS_NOR_CSOR	CSOR_NAND_TRHZ_80 +#define CONFIG_SYS_NOR_FTIM0	(FTIM0_NOR_TACSE(0x4) | \ +				FTIM0_NOR_TEADC(0x5) | \ +				FTIM0_NOR_TEAHC(0x5)) +#define CONFIG_SYS_NOR_FTIM1	(FTIM1_NOR_TACO(0x35) | \ +				FTIM1_NOR_TRAD_NOR(0x1A) |\ +				FTIM1_NOR_TSEQRAD_NOR(0x13)) +#define CONFIG_SYS_NOR_FTIM2	(FTIM2_NOR_TCS(0x4) | \ +				FTIM2_NOR_TCH(0x4) | \ +				FTIM2_NOR_TWPH(0x0E) | \ +				FTIM2_NOR_TWP(0x1c)) +#define CONFIG_SYS_NOR_FTIM3	0x0 + +#define CONFIG_SYS_FLASH_QUIET_TEST +#define CONFIG_FLASH_SHOW_PROGRESS	45 /* count down from 45/5: 9..1 */ + +#define CONFIG_SYS_MAX_FLASH_BANKS	2	/* number of banks */ +#define CONFIG_SYS_MAX_FLASH_SECT	1024	/* sectors per device */ +#define CONFIG_SYS_FLASH_ERASE_TOUT	60000	/* Flash Erase Timeout (ms) */ +#define CONFIG_SYS_FLASH_WRITE_TOUT	500	/* Flash Write Timeout (ms) */ + +#define CONFIG_SYS_FLASH_EMPTY_INFO +#define CONFIG_SYS_FLASH_BANKS_LIST	{CONFIG_SYS_FLASH_BASE_PHYS} + +/* CPLD on IFC */ +#define CONFIG_SYS_CPLD_BASE	0xffdf0000 +#define CONFIG_SYS_CPLD_BASE_PHYS	(0xf00000000ull | CONFIG_SYS_CPLD_BASE) +#define CONFIG_SYS_CSPR2	(CSPR_PHYS_ADDR(CONFIG_SYS_CPLD_BASE_PHYS) \ +				| CSPR_PORT_SIZE_8 \ +				| CSPR_MSEL_GPCM \ +				| CSPR_V) +#define CONFIG_SYS_AMASK2	IFC_AMASK(64*1024) +#define CONFIG_SYS_CSOR2	0x0 +/* CPLD Timing parameters for IFC CS2 */ +#define CONFIG_SYS_CS2_FTIM0		(FTIM0_GPCM_TACSE(0x0e) | \ +					FTIM0_GPCM_TEADC(0x0e) | \ +					FTIM0_GPCM_TEAHC(0x0e)) +#define CONFIG_SYS_CS2_FTIM1		(FTIM1_GPCM_TACO(0x0e) | \ +					FTIM1_GPCM_TRAD(0x1f)) +#define CONFIG_SYS_CS2_FTIM2		(FTIM2_GPCM_TCS(0x0e) | \ +					FTIM2_GPCM_TCH(0x0) | \ +					FTIM2_GPCM_TWP(0x1f)) +#define CONFIG_SYS_CS2_FTIM3		0x0 + +/* NAND Flash on IFC */ +#define CONFIG_NAND_FSL_IFC +#define CONFIG_SYS_NAND_BASE		0xff800000 +#define CONFIG_SYS_NAND_BASE_PHYS	(0xf00000000ull | CONFIG_SYS_NAND_BASE) + +#define CONFIG_SYS_NAND_CSPR_EXT	(0xf) +#define CONFIG_SYS_NAND_CSPR	(CSPR_PHYS_ADDR(CONFIG_SYS_NAND_BASE_PHYS) \ +				| CSPR_PORT_SIZE_8 /* Port Size = 8 bit */ \ +				| CSPR_MSEL_NAND	/* MSEL = NAND */ \ +				| CSPR_V) +#define CONFIG_SYS_NAND_AMASK	IFC_AMASK(64*1024) + +#define CONFIG_SYS_NAND_CSOR    (CSOR_NAND_ECC_ENC_EN   /* ECC on encode */ \ +				| CSOR_NAND_ECC_DEC_EN  /* ECC on decode */ \ +				| CSOR_NAND_ECC_MODE_4  /* 4-bit ECC */ \ +				| CSOR_NAND_RAL_3	/* RAL = 3Byes */ \ +				| CSOR_NAND_PGS_4K	/* Page Size = 4K */ \ +				| CSOR_NAND_SPRZ_224/* Spare size = 224 */ \ +				| CSOR_NAND_PB(64))	/*Pages Per Block = 64*/ + +#define CONFIG_SYS_NAND_ONFI_DETECTION + +/* ONFI NAND Flash mode0 Timing Params */ +#define CONFIG_SYS_NAND_FTIM0		(FTIM0_NAND_TCCST(0x07) | \ +					FTIM0_NAND_TWP(0x18)   | \ +					FTIM0_NAND_TWCHT(0x07) | \ +					FTIM0_NAND_TWH(0x0a)) +#define CONFIG_SYS_NAND_FTIM1		(FTIM1_NAND_TADLE(0x32) | \ +					FTIM1_NAND_TWBE(0x39)  | \ +					FTIM1_NAND_TRR(0x0e)   | \ +					FTIM1_NAND_TRP(0x18)) +#define CONFIG_SYS_NAND_FTIM2		(FTIM2_NAND_TRAD(0x0f) | \ +					FTIM2_NAND_TREH(0x0a) | \ +					FTIM2_NAND_TWHRE(0x1e)) +#define CONFIG_SYS_NAND_FTIM3		0x0 + +#define CONFIG_SYS_NAND_DDR_LAW		11 +#define CONFIG_SYS_NAND_BASE_LIST	{ CONFIG_SYS_NAND_BASE } +#define CONFIG_SYS_MAX_NAND_DEVICE	1 +#define CONFIG_MTD_NAND_VERIFY_WRITE +#define CONFIG_CMD_NAND + +#define CONFIG_SYS_NAND_BLOCK_SIZE	(512 * 1024) + +#if defined(CONFIG_NAND) +#define CONFIG_SYS_CSPR0_EXT		CONFIG_SYS_NAND_CSPR_EXT +#define CONFIG_SYS_CSPR0		CONFIG_SYS_NAND_CSPR +#define CONFIG_SYS_AMASK0		CONFIG_SYS_NAND_AMASK +#define CONFIG_SYS_CSOR0		CONFIG_SYS_NAND_CSOR +#define CONFIG_SYS_CS0_FTIM0		CONFIG_SYS_NAND_FTIM0 +#define CONFIG_SYS_CS0_FTIM1		CONFIG_SYS_NAND_FTIM1 +#define CONFIG_SYS_CS0_FTIM2		CONFIG_SYS_NAND_FTIM2 +#define CONFIG_SYS_CS0_FTIM3		CONFIG_SYS_NAND_FTIM3 +#define CONFIG_SYS_CSPR1_EXT		CONFIG_SYS_NOR_CSPR_EXT +#define CONFIG_SYS_CSPR1		CONFIG_SYS_NOR_CSPR +#define CONFIG_SYS_AMASK1		CONFIG_SYS_NOR_AMASK +#define CONFIG_SYS_CSOR1		CONFIG_SYS_NOR_CSOR +#define CONFIG_SYS_CS1_FTIM0		CONFIG_SYS_NOR_FTIM0 +#define CONFIG_SYS_CS1_FTIM1		CONFIG_SYS_NOR_FTIM1 +#define CONFIG_SYS_CS1_FTIM2		CONFIG_SYS_NOR_FTIM2 +#define CONFIG_SYS_CS1_FTIM3		CONFIG_SYS_NOR_FTIM3 +#else +#define CONFIG_SYS_CSPR0_EXT		CONFIG_SYS_NOR_CSPR_EXT +#define CONFIG_SYS_CSPR0		CONFIG_SYS_NOR_CSPR +#define CONFIG_SYS_AMASK0		CONFIG_SYS_NOR_AMASK +#define CONFIG_SYS_CSOR0		CONFIG_SYS_NOR_CSOR +#define CONFIG_SYS_CS0_FTIM0		CONFIG_SYS_NOR_FTIM0 +#define CONFIG_SYS_CS0_FTIM1		CONFIG_SYS_NOR_FTIM1 +#define CONFIG_SYS_CS0_FTIM2		CONFIG_SYS_NOR_FTIM2 +#define CONFIG_SYS_CS0_FTIM3		CONFIG_SYS_NOR_FTIM3 +#define CONFIG_SYS_CSPR1_EXT		CONFIG_SYS_NAND_CSPR_EXT +#define CONFIG_SYS_CSPR1		CONFIG_SYS_NAND_CSPR +#define CONFIG_SYS_AMASK1		CONFIG_SYS_NAND_AMASK +#define CONFIG_SYS_CSOR1		CONFIG_SYS_NAND_CSOR +#define CONFIG_SYS_CS1_FTIM0		CONFIG_SYS_NAND_FTIM0 +#define CONFIG_SYS_CS1_FTIM1		CONFIG_SYS_NAND_FTIM1 +#define CONFIG_SYS_CS1_FTIM2		CONFIG_SYS_NAND_FTIM2 +#define CONFIG_SYS_CS1_FTIM3		CONFIG_SYS_NAND_FTIM3 +#endif + +#define CONFIG_SYS_MONITOR_BASE		CONFIG_SYS_TEXT_BASE + +#if defined(CONFIG_RAMBOOT_PBL) +#define CONFIG_SYS_RAMBOOT +#endif + +#define CONFIG_BOARD_EARLY_INIT_R +#define CONFIG_MISC_INIT_R + +#define CONFIG_HWCONFIG + +/* define to use L1 as initial stack */ +#define CONFIG_L1_INIT_RAM +#define CONFIG_SYS_INIT_RAM_LOCK +#define CONFIG_SYS_INIT_RAM_ADDR	0xfdd00000	/* Initial L1 address */ +#define CONFIG_SYS_INIT_RAM_ADDR_PHYS_HIGH	0xf +#define CONFIG_SYS_INIT_RAM_ADDR_PHYS_LOW	0xfe0ec000 +/* The assembler doesn't like typecast */ +#define CONFIG_SYS_INIT_RAM_ADDR_PHYS \ +	((CONFIG_SYS_INIT_RAM_ADDR_PHYS_HIGH * 1ull << 32) | \ +	  CONFIG_SYS_INIT_RAM_ADDR_PHYS_LOW) +#define CONFIG_SYS_INIT_RAM_SIZE		0x00004000 + +#define CONFIG_SYS_GBL_DATA_OFFSET	(CONFIG_SYS_INIT_RAM_SIZE - \ +					GENERATED_GBL_DATA_SIZE) +#define CONFIG_SYS_INIT_SP_OFFSET	CONFIG_SYS_GBL_DATA_OFFSET + +#define CONFIG_SYS_MONITOR_LEN		(512 * 1024) +#define CONFIG_SYS_MALLOC_LEN		(4 * 1024 * 1024) + +/* Serial Port - controlled on board with jumper J8 + * open - index 2 + * shorted - index 1 + */ +#define CONFIG_CONS_INDEX	1 +#define CONFIG_SYS_NS16550 +#define CONFIG_SYS_NS16550_SERIAL +#define CONFIG_SYS_NS16550_REG_SIZE	1 +#define CONFIG_SYS_NS16550_CLK		(get_bus_freq(0)/2) + +#define CONFIG_SYS_BAUDRATE_TABLE	\ +	{300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200} + +#define CONFIG_SYS_NS16550_COM1	(CONFIG_SYS_CCSRBAR+0x11C500) +#define CONFIG_SYS_NS16550_COM2	(CONFIG_SYS_CCSRBAR+0x11C600) +#define CONFIG_SYS_NS16550_COM3	(CONFIG_SYS_CCSRBAR+0x11D500) +#define CONFIG_SYS_NS16550_COM4	(CONFIG_SYS_CCSRBAR+0x11D600) +#define CONFIG_SERIAL_MULTI		/* Enable both serial ports */ +#define CONFIG_SYS_CONSOLE_IS_IN_ENV	/* determine from environment */ + +/* Use the HUSH parser */ +#define CONFIG_SYS_HUSH_PARSER +#define CONFIG_SYS_PROMPT_HUSH_PS2 "> " + +/* pass open firmware flat tree */ +#define CONFIG_OF_LIBFDT +#define CONFIG_OF_BOARD_SETUP +#define CONFIG_OF_STDOUT_VIA_ALIAS + +/* new uImage format support */ +#define CONFIG_FIT +#define CONFIG_FIT_VERBOSE	/* enable fit_format_{error,warning}() */ + +/* I2C */ +#define CONFIG_SYS_I2C +#define CONFIG_SYS_I2C_FSL		/* Use FSL common I2C driver */ +#define CONFIG_SYS_FSL_I2C_SPEED	400000	/* I2C speed in Hz */ +#define CONFIG_SYS_FSL_I2C_SLAVE	0x7F +#define CONFIG_SYS_FSL_I2C2_SPEED	400000	/* I2C speed in Hz */ +#define CONFIG_SYS_FSL_I2C2_SLAVE	0x7F +#define CONFIG_SYS_FSL_I2C_OFFSET	0x118000 +#define CONFIG_SYS_FSL_I2C2_OFFSET	0x119000 + +/* I2C bus multiplexer */ +#define I2C_MUX_PCA_ADDR                0x70 +#define I2C_MUX_CH_DEFAULT      0x8 + + +/* + * eSPI - Enhanced SPI + */ +#define CONFIG_FSL_ESPI +#define CONFIG_SPI_FLASH +#define CONFIG_SPI_FLASH_STMICRO +#define CONFIG_CMD_SF +#define CONFIG_SF_DEFAULT_SPEED         10000000 +#define CONFIG_SF_DEFAULT_MODE          0 + +/* + * General PCI + * Memory space is mapped 1-1, but I/O space must start from 0. + */ + +#ifdef CONFIG_PCI +/* controller 1, direct to uli, tgtid 3, Base address 20000 */ +#ifdef CONFIG_PCIE1 +#define	CONFIG_SYS_PCIE1_MEM_VIRT	0x80000000 +#define	CONFIG_SYS_PCIE1_MEM_BUS	0xe0000000 +#define	CONFIG_SYS_PCIE1_MEM_PHYS	0xc00000000ull +#define CONFIG_SYS_PCIE1_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE1_IO_VIRT	0xf8000000 +#define CONFIG_SYS_PCIE1_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE1_IO_PHYS	0xff8000000ull +#define CONFIG_SYS_PCIE1_IO_SIZE	0x00010000	/* 64k */ +#endif + +/* controller 2, Slot 2, tgtid 2, Base address 201000 */ +#ifdef CONFIG_PCIE2 +#define CONFIG_SYS_PCIE2_MEM_VIRT	0x90000000 +#define CONFIG_SYS_PCIE2_MEM_BUS	0xe0000000 +#define CONFIG_SYS_PCIE2_MEM_PHYS	0xc10000000ull +#define CONFIG_SYS_PCIE2_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE2_IO_VIRT	0xf8010000 +#define CONFIG_SYS_PCIE2_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE2_IO_PHYS	0xff8010000ull +#define CONFIG_SYS_PCIE2_IO_SIZE	0x00010000	/* 64k */ +#endif + +/* controller 3, Slot 1, tgtid 1, Base address 202000 */ +#ifdef CONFIG_PCIE3 +#define CONFIG_SYS_PCIE3_MEM_VIRT	0xa0000000 +#define CONFIG_SYS_PCIE3_MEM_BUS	0xe0000000 +#define CONFIG_SYS_PCIE3_MEM_PHYS	0xc20000000ull +#define CONFIG_SYS_PCIE3_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE3_IO_VIRT	0xf8020000 +#define CONFIG_SYS_PCIE3_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE3_IO_PHYS	0xff8020000ull +#define CONFIG_SYS_PCIE3_IO_SIZE	0x00010000	/* 64k */ +#endif + +/* controller 4, Base address 203000 */ +#ifdef CONFIG_PCIE4 +#define CONFIG_SYS_PCIE4_MEM_VIRT	0xb0000000 +#define CONFIG_SYS_PCIE4_MEM_BUS	0xe0000000 +#define CONFIG_SYS_PCIE4_MEM_PHYS	0xc30000000ull +#define CONFIG_SYS_PCIE4_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE4_IO_VIRT	0xf8030000 +#define CONFIG_SYS_PCIE4_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE4_IO_PHYS	0xff8030000ull +#define CONFIG_SYS_PCIE4_IO_SIZE	0x00010000	/* 64k */ +#endif + +#define CONFIG_PCI_PNP			/* do pci plug-and-play */ +#define CONFIG_E1000 + +#define CONFIG_PCI_SCAN_SHOW		/* show pci devices on startup */ +#define CONFIG_DOS_PARTITION +#endif	/* CONFIG_PCI */ + +/* SATA */ +#define CONFIG_FSL_SATA_V2 +#ifdef CONFIG_FSL_SATA_V2 +#define CONFIG_LIBATA +#define CONFIG_FSL_SATA + +#define CONFIG_SYS_SATA_MAX_DEVICE	1 +#define CONFIG_SATA1 +#define CONFIG_SYS_SATA1		CONFIG_SYS_MPC85xx_SATA1_ADDR +#define CONFIG_SYS_SATA1_FLAGS		FLAGS_DMA + +#define CONFIG_LBA48 +#define CONFIG_CMD_SATA +#define CONFIG_DOS_PARTITION +#define CONFIG_CMD_EXT2 +#endif + +/* +* USB +*/ +#define CONFIG_HAS_FSL_DR_USB + +#ifdef CONFIG_HAS_FSL_DR_USB +#define CONFIG_USB_EHCI + +#ifdef CONFIG_USB_EHCI +#define CONFIG_CMD_USB +#define CONFIG_USB_STORAGE +#define CONFIG_USB_EHCI_FSL +#define CONFIG_EHCI_HCD_INIT_AFTER_RESET +#define CONFIG_CMD_EXT2 +#endif +#endif + +#define CONFIG_MMC + +#ifdef CONFIG_MMC +#define CONFIG_FSL_ESDHC +#define CONFIG_SYS_FSL_ESDHC_ADDR       CONFIG_SYS_MPC85xx_ESDHC_ADDR +#define CONFIG_CMD_MMC +#define CONFIG_GENERIC_MMC +#define CONFIG_CMD_EXT2 +#define CONFIG_CMD_FAT +#define CONFIG_DOS_PARTITION +#endif + +/* Qman/Bman */ +#ifndef CONFIG_NOBQFMAN +#define CONFIG_SYS_DPAA_QBMAN		/* Support Q/Bman */ +#define CONFIG_SYS_BMAN_NUM_PORTALS	25 +#define CONFIG_SYS_BMAN_MEM_BASE	0xf4000000 +#define CONFIG_SYS_BMAN_MEM_PHYS	0xff4000000ull +#define CONFIG_SYS_BMAN_MEM_SIZE	0x02000000 +#define CONFIG_SYS_QMAN_NUM_PORTALS	25 +#define CONFIG_SYS_QMAN_MEM_BASE	0xf6000000 +#define CONFIG_SYS_QMAN_MEM_PHYS	0xff6000000ull +#define CONFIG_SYS_QMAN_MEM_SIZE	0x02000000 + +#define CONFIG_SYS_DPAA_FMAN +#define CONFIG_SYS_DPAA_PME + +/* Default address of microcode for the Linux Fman driver */ +#if defined(CONFIG_SPIFLASH) +/* + * env is stored at 0x100000, sector size is 0x10000, ucode is stored after + * env, so we got 0x110000. + */ +#define CONFIG_SYS_QE_FW_IN_SPIFLASH +#define CONFIG_SYS_QE_FMAN_FW_ADDR	0x110000 +#elif defined(CONFIG_SDCARD) +/* + * PBL SD boot image should stored at 0x1000(8 blocks), the size of the image is + * about 545KB (1089 blocks), Env is stored after the image, and the env size is + * 0x2000 (16 blocks), 8 + 1089 + 16 = 1113, enlarge it to 1130. + */ +#define CONFIG_SYS_QE_FMAN_FW_IN_MMC +#define CONFIG_SYS_QE_FMAN_FW_ADDR	(512 * 1130) +#elif defined(CONFIG_NAND) +#define CONFIG_SYS_QE_FMAN_FW_IN_NAND +#define CONFIG_SYS_QE_FMAN_FW_ADDR	(6 * CONFIG_SYS_NAND_BLOCK_SIZE) +#else +#define CONFIG_SYS_QE_FMAN_FW_IN_NOR +#define CONFIG_SYS_QE_FMAN_FW_ADDR		0xEFF40000 +#endif +#define CONFIG_SYS_QE_FMAN_FW_LENGTH	0x10000 +#define CONFIG_SYS_FDT_PAD		(0x3000 + CONFIG_SYS_QE_FMAN_FW_LENGTH) +#endif /* CONFIG_NOBQFMAN */ + +#ifdef CONFIG_SYS_DPAA_FMAN +#define CONFIG_FMAN_ENET +#define CONFIG_PHY_VITESSE +#define CONFIG_PHY_REALTEK +#endif + +#ifdef CONFIG_FMAN_ENET +#define CONFIG_SYS_FM1_DTSEC1_RISER_PHY_ADDR    0x1c +#define CONFIG_SYS_FM1_DTSEC2_RISER_PHY_ADDR    0x1d +#define CONFIG_SYS_FM1_DTSEC3_RISER_PHY_ADDR    0x1e +#define CONFIG_SYS_FM1_DTSEC4_RISER_PHY_ADDR    0x1f + +#define CONFIG_MII		/* MII PHY management */ +#define CONFIG_ETHPRIME		"FM1@DTSEC1" +#define CONFIG_PHY_GIGE		/* Include GbE speed/duplex detection */ +#endif + +/* + * Environment + */ +#define CONFIG_LOADS_ECHO		/* echo on for serial download */ +#define CONFIG_SYS_LOADS_BAUD_CHANGE	/* allow baudrate change */ + +/* + * Command line configuration. + */ +#include <config_cmd_default.h> + +#define CONFIG_CMD_DHCP +#define CONFIG_CMD_ELF +#define CONFIG_CMD_ERRATA +#define CONFIG_CMD_GREPENV +#define CONFIG_CMD_IRQ +#define CONFIG_CMD_I2C +#define CONFIG_CMD_MII +#define CONFIG_CMD_PING +#define CONFIG_CMD_REGINFO +#define CONFIG_CMD_SETEXPR + +#ifdef CONFIG_PCI +#define CONFIG_CMD_PCI +#define CONFIG_CMD_NET +#endif + +/* + * Miscellaneous configurable options + */ +#define CONFIG_SYS_LONGHELP			/* undef to save memory	*/ +#define CONFIG_CMDLINE_EDITING			/* Command-line editing */ +#define CONFIG_AUTO_COMPLETE			/* add autocompletion support */ +#define CONFIG_SYS_LOAD_ADDR	0x2000000	/* default load address */ +#define CONFIG_SYS_PROMPT	"=> "		/* Monitor Command Prompt */ +#ifdef CONFIG_CMD_KGDB +#define CONFIG_SYS_CBSIZE	1024		/* Console I/O Buffer Size */ +#else +#define CONFIG_SYS_CBSIZE	256		/* Console I/O Buffer Size */ +#endif +#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) +#define CONFIG_SYS_MAXARGS	16		/* max number of command args */ +#define CONFIG_SYS_BARGSIZE	CONFIG_SYS_CBSIZE/* Boot Argument Buffer Size */ +#define CONFIG_SYS_HZ		1000		/* decrementer freq: 1ms ticks*/ + +/* + * For booting Linux, the board info and command line data + * have to be in the first 64 MB of memory, since this is + * the maximum mapped by the Linux kernel during initialization. + */ +#define CONFIG_SYS_BOOTMAPSZ	(64 << 20)	/* Initial map for Linux*/ +#define CONFIG_SYS_BOOTM_LEN	(64 << 20)	/* Increase max gunzip size */ + +#ifdef CONFIG_CMD_KGDB +#define CONFIG_KGDB_BAUDRATE	230400	/* speed to run kgdb serial port */ +#define CONFIG_KGDB_SER_INDEX	2	/* which serial port to use */ +#endif + +/* + * Environment Configuration + */ +#define CONFIG_ROOTPATH		"/opt/nfsroot" +#define CONFIG_BOOTFILE		"uImage" +#define CONFIG_UBOOTPATH	"u-boot.bin"	/* U-Boot image on TFTP server*/ + +/* default location for tftp and bootm */ +#define CONFIG_LOADADDR		1000000 + +#define CONFIG_BOOTDELAY	10	/*-1 disables auto-boot*/ + +#define CONFIG_BAUDRATE	115200 + +#define __USB_PHY_TYPE	utmi + +#define	CONFIG_EXTRA_ENV_SETTINGS				\ +	"hwconfig=fsl_ddr:ctlr_intlv=cacheline,"		\ +	"bank_intlv=cs0_cs1;"					\ +	"usb1:dr_mode=host,phy_type=" __stringify(__USB_PHY_TYPE) "\0"\ +	"netdev=eth0\0"						\ +	"uboot=" __stringify(CONFIG_UBOOTPATH) "\0"		\ +	"ubootaddr=" __stringify(CONFIG_SYS_TEXT_BASE) "\0"	\ +	"tftpflash=tftpboot $loadaddr $uboot && "		\ +	"protect off $ubootaddr +$filesize && "			\ +	"erase $ubootaddr +$filesize && "			\ +	"cp.b $loadaddr $ubootaddr $filesize && "		\ +	"protect on $ubootaddr +$filesize && "			\ +	"cmp.b $loadaddr $ubootaddr $filesize\0"		\ +	"consoledev=ttyS0\0"					\ +	"ramdiskaddr=2000000\0"					\ +	"ramdiskfile=t1040rdb/ramdisk.uboot\0"			\ +	"fdtaddr=c00000\0"					\ +	"fdtfile=t1040rdb/t1040rdb.dtb\0"			\ +	"bdev=sda3\0"						\ +	"c=ffe\0" + +#define CONFIG_LINUX                       \ +	"setenv bootargs root=/dev/ram rw "            \ +	"console=$consoledev,$baudrate $othbootargs;"  \ +	"setenv ramdiskaddr 0x02000000;"               \ +	"setenv fdtaddr 0x00c00000;"		       \ +	"setenv loadaddr 0x1000000;"		       \ +	"bootm $loadaddr $ramdiskaddr $fdtaddr" + +#define CONFIG_HDBOOT					\ +	"setenv bootargs root=/dev/$bdev rw "		\ +	"console=$consoledev,$baudrate $othbootargs;"	\ +	"tftp $loadaddr $bootfile;"			\ +	"tftp $fdtaddr $fdtfile;"			\ +	"bootm $loadaddr - $fdtaddr" + +#define CONFIG_NFSBOOTCOMMAND			\ +	"setenv bootargs root=/dev/nfs rw "	\ +	"nfsroot=$serverip:$rootpath "		\ +	"ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:$netdev:off " \ +	"console=$consoledev,$baudrate $othbootargs;"	\ +	"tftp $loadaddr $bootfile;"		\ +	"tftp $fdtaddr $fdtfile;"		\ +	"bootm $loadaddr - $fdtaddr" + +#define CONFIG_RAMBOOTCOMMAND				\ +	"setenv bootargs root=/dev/ram rw "		\ +	"console=$consoledev,$baudrate $othbootargs;"	\ +	"tftp $ramdiskaddr $ramdiskfile;"		\ +	"tftp $loadaddr $bootfile;"			\ +	"tftp $fdtaddr $fdtfile;"			\ +	"bootm $loadaddr $ramdiskaddr $fdtaddr" + +#define CONFIG_BOOTCOMMAND		CONFIG_LINUX + +#ifdef CONFIG_SECURE_BOOT +#include <asm/fsl_secure_boot.h> +#endif + +#endif	/* __CONFIG_H */ diff --git a/include/configs/T1042RDB_PI.h b/include/configs/T1042RDB_PI.h new file mode 100644 index 000000000..4b023f9e8 --- /dev/null +++ b/include/configs/T1042RDB_PI.h @@ -0,0 +1,694 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * See file CREDITS for list of people who contributed to this + * project. + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ + +#ifndef __CONFIG_H +#define __CONFIG_H + +/* + * T1042RDB_PI board configuration file + */ +#define CONFIG_T104xRDB +#define CONFIG_T1042RDB_PI +#define CONFIG_PHYS_64BIT + +#ifdef CONFIG_RAMBOOT_PBL +#define CONFIG_RAMBOOT_TEXT_BASE	CONFIG_SYS_TEXT_BASE +#define CONFIG_RESET_VECTOR_ADDRESS	0xfffffffc +#endif + +/* High Level Configuration Options */ +#define CONFIG_BOOKE +#define CONFIG_E500			/* BOOKE e500 family */ +#define CONFIG_E500MC			/* BOOKE e500mc family */ +#define CONFIG_SYS_BOOK3E_HV		/* Category E.HV supported */ +#define CONFIG_MPC85xx			/* MPC85xx/PQ3 platform */ +#define CONFIG_MP			/* support multiple processors */ + +#ifndef CONFIG_SYS_TEXT_BASE +#define CONFIG_SYS_TEXT_BASE	0xeff80000 +#endif + +#ifndef CONFIG_RESET_VECTOR_ADDRESS +#define CONFIG_RESET_VECTOR_ADDRESS	0xeffffffc +#endif + +#define CONFIG_SYS_FSL_CPC		/* Corenet Platform Cache */ +#define CONFIG_SYS_NUM_CPC		CONFIG_NUM_DDR_CONTROLLERS +#define CONFIG_FSL_IFC			/* Enable IFC Support */ +#define CONFIG_PCI			/* Enable PCI/PCIE */ +#define CONFIG_PCI_INDIRECT_BRIDGE +#define CONFIG_PCIE1			/* PCIE controler 1 */ +#define CONFIG_PCIE2			/* PCIE controler 2 */ +#define CONFIG_PCIE3			/* PCIE controler 3 */ +#define CONFIG_PCIE4			/* PCIE controler 4 */ + +#define CONFIG_FSL_PCI_INIT		/* Use common FSL init code */ +#define CONFIG_SYS_PCI_64BIT		/* enable 64-bit PCI resources */ + +#define CONFIG_FSL_LAW			/* Use common FSL init code */ + +#define CONFIG_ENV_OVERWRITE + +#ifdef CONFIG_SYS_NO_FLASH +#define CONFIG_ENV_IS_NOWHERE +#else +#define CONFIG_FLASH_CFI_DRIVER +#define CONFIG_SYS_FLASH_CFI +#define CONFIG_SYS_FLASH_USE_BUFFER_WRITE +#endif + +#ifndef CONFIG_SYS_NO_FLASH +#if defined(CONFIG_SPIFLASH) +#define CONFIG_SYS_EXTRA_ENV_RELOC +#define CONFIG_ENV_IS_IN_SPI_FLASH +#define CONFIG_ENV_SPI_BUS              0 +#define CONFIG_ENV_SPI_CS               0 +#define CONFIG_ENV_SPI_MAX_HZ           10000000 +#define CONFIG_ENV_SPI_MODE             0 +#define CONFIG_ENV_SIZE                 0x2000          /* 8KB */ +#define CONFIG_ENV_OFFSET               0x100000        /* 1MB */ +#define CONFIG_ENV_SECT_SIZE            0x10000 +#elif defined(CONFIG_SDCARD) +#define CONFIG_SYS_EXTRA_ENV_RELOC +#define CONFIG_ENV_IS_IN_MMC +#define CONFIG_SYS_MMC_ENV_DEV          0 +#define CONFIG_ENV_SIZE			0x2000 +#define CONFIG_ENV_OFFSET		(512 * 1105) +#elif defined(CONFIG_NAND) +#define CONFIG_SYS_EXTRA_ENV_RELOC +#define CONFIG_ENV_IS_IN_NAND +#define CONFIG_ENV_SIZE			CONFIG_SYS_NAND_BLOCK_SIZE +#define CONFIG_ENV_OFFSET		(5 * CONFIG_SYS_NAND_BLOCK_SIZE) +#else +#define CONFIG_ENV_IS_IN_FLASH +#define CONFIG_ENV_ADDR		(CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SECT_SIZE) +#define CONFIG_ENV_SIZE		0x2000 +#define CONFIG_ENV_SECT_SIZE	0x20000 /* 128K (one sector) */ +#endif +#else /* CONFIG_SYS_NO_FLASH */ +#define CONFIG_ENV_SIZE                0x2000 +#define CONFIG_ENV_SECT_SIZE   0x20000 /* 128K (one sector) */ +#endif + +#define CONFIG_SYS_CLK_FREQ	100000000 +#define CONFIG_DDR_CLK_FREQ	66666666 + +/* + * These can be toggled for performance analysis, otherwise use default. + */ +#define CONFIG_SYS_CACHE_STASHING +#define CONFIG_BACKSIDE_L2_CACHE +#define CONFIG_SYS_INIT_L2CSR0		L2CSR0_L2E +#define CONFIG_BTB			/* toggle branch predition */ +#define CONFIG_DDR_ECC +#ifdef CONFIG_DDR_ECC +#define CONFIG_ECC_INIT_VIA_DDRCONTROLLER +#define CONFIG_MEM_INIT_VALUE		0xdeadbeef +#endif + +#define CONFIG_ENABLE_36BIT_PHYS + +#define CONFIG_ADDR_MAP +#define CONFIG_SYS_NUM_ADDR_MAP		64	/* number of TLB1 entries */ + +#define CONFIG_SYS_MEMTEST_START	0x00200000	/* memtest works on */ +#define CONFIG_SYS_MEMTEST_END		0x00400000 +#define CONFIG_SYS_ALT_MEMTEST +#define CONFIG_PANIC_HANG	/* do not reset board on panic */ + +/* + *  Config the L3 Cache as L3 SRAM + */ +#define CONFIG_SYS_INIT_L3_ADDR		0xFFFC0000 + +#define CONFIG_SYS_DCSRBAR		0xf0000000 +#define CONFIG_SYS_DCSRBAR_PHYS		0xf00000000ull + +/* + * DDR Setup + */ +#define CONFIG_VERY_BIG_RAM +#define CONFIG_SYS_DDR_SDRAM_BASE	0x00000000 +#define CONFIG_SYS_SDRAM_BASE		CONFIG_SYS_DDR_SDRAM_BASE + +/* CONFIG_NUM_DDR_CONTROLLERS is defined in include/asm/config_mpc85xx.h */ +#define CONFIG_DIMM_SLOTS_PER_CTLR	1 +#define CONFIG_CHIP_SELECTS_PER_CTRL	(4 * CONFIG_DIMM_SLOTS_PER_CTLR) + +#define CONFIG_DDR_SPD +#define CONFIG_SYS_DDR_RAW_TIMING +#define CONFIG_FSL_DDR3 + +#define CONFIG_SYS_SPD_BUS_NUM	0 +#define SPD_EEPROM_ADDRESS	0x51 + +#define CONFIG_SYS_SDRAM_SIZE	4096	/* for fixed parameter use */ + +/* + * IFC Definitions + */ +#define CONFIG_SYS_FLASH_BASE	0xe8000000 +#define CONFIG_SYS_FLASH_BASE_PHYS	(0xf00000000ull | CONFIG_SYS_FLASH_BASE) + +#define CONFIG_SYS_NOR_CSPR_EXT	(0xf) +#define CONFIG_SYS_NOR_CSPR	(CSPR_PHYS_ADDR(CONFIG_SYS_FLASH_BASE) | \ +				CSPR_PORT_SIZE_16 | \ +				CSPR_MSEL_NOR | \ +				CSPR_V) +#define CONFIG_SYS_NOR_AMASK	IFC_AMASK(128*1024*1024) +/* NOR Flash Timing Params */ +#define CONFIG_SYS_NOR_CSOR	CSOR_NAND_TRHZ_80 +#define CONFIG_SYS_NOR_FTIM0	(FTIM0_NOR_TACSE(0x4) | \ +				FTIM0_NOR_TEADC(0x5) | \ +				FTIM0_NOR_TEAHC(0x5)) +#define CONFIG_SYS_NOR_FTIM1	(FTIM1_NOR_TACO(0x35) | \ +				FTIM1_NOR_TRAD_NOR(0x1A) |\ +				FTIM1_NOR_TSEQRAD_NOR(0x13)) +#define CONFIG_SYS_NOR_FTIM2	(FTIM2_NOR_TCS(0x4) | \ +				FTIM2_NOR_TCH(0x4) | \ +				FTIM2_NOR_TWPH(0x0E) | \ +				FTIM2_NOR_TWP(0x1c)) +#define CONFIG_SYS_NOR_FTIM3	0x0 + +#define CONFIG_SYS_FLASH_QUIET_TEST +#define CONFIG_FLASH_SHOW_PROGRESS	45 /* count down from 45/5: 9..1 */ + +#define CONFIG_SYS_MAX_FLASH_BANKS	2	/* number of banks */ +#define CONFIG_SYS_MAX_FLASH_SECT	1024	/* sectors per device */ +#define CONFIG_SYS_FLASH_ERASE_TOUT	60000	/* Flash Erase Timeout (ms) */ +#define CONFIG_SYS_FLASH_WRITE_TOUT	500	/* Flash Write Timeout (ms) */ + +#define CONFIG_SYS_FLASH_EMPTY_INFO +#define CONFIG_SYS_FLASH_BANKS_LIST	{CONFIG_SYS_FLASH_BASE_PHYS} + +/* CPLD on IFC */ +#define CONFIG_SYS_CPLD_BASE	0xffdf0000 +#define CONFIG_SYS_CPLD_BASE_PHYS	(0xf00000000ull | CONFIG_SYS_CPLD_BASE) +#define CONFIG_SYS_CSPR2	(CSPR_PHYS_ADDR(CONFIG_SYS_CPLD_BASE_PHYS) \ +				| CSPR_PORT_SIZE_8 \ +				| CSPR_MSEL_GPCM \ +				| CSPR_V) +#define CONFIG_SYS_AMASK2	IFC_AMASK(64*1024) +#define CONFIG_SYS_CSOR2	0x0 +/* CPLD Timing parameters for IFC CS2 */ +#define CONFIG_SYS_CS2_FTIM0		(FTIM0_GPCM_TACSE(0x0e) | \ +					FTIM0_GPCM_TEADC(0x0e) | \ +					FTIM0_GPCM_TEAHC(0x0e)) +#define CONFIG_SYS_CS2_FTIM1		(FTIM1_GPCM_TACO(0x0e) | \ +					FTIM1_GPCM_TRAD(0x1f)) +#define CONFIG_SYS_CS2_FTIM2		(FTIM2_GPCM_TCS(0x0e) | \ +					FTIM2_GPCM_TCH(0x0) | \ +					FTIM2_GPCM_TWP(0x1f)) +#define CONFIG_SYS_CS2_FTIM3		0x0 + +/* NAND Flash on IFC */ +#define CONFIG_NAND_FSL_IFC +#define CONFIG_SYS_NAND_BASE		0xff800000 +#define CONFIG_SYS_NAND_BASE_PHYS	(0xf00000000ull | CONFIG_SYS_NAND_BASE) + +#define CONFIG_SYS_NAND_CSPR_EXT	(0xf) +#define CONFIG_SYS_NAND_CSPR	(CSPR_PHYS_ADDR(CONFIG_SYS_NAND_BASE_PHYS) \ +				| CSPR_PORT_SIZE_8 /* Port Size = 8 bit */ \ +				| CSPR_MSEL_NAND	/* MSEL = NAND */ \ +				| CSPR_V) +#define CONFIG_SYS_NAND_AMASK	IFC_AMASK(64*1024) + +#define CONFIG_SYS_NAND_CSOR    (CSOR_NAND_ECC_ENC_EN   /* ECC on encode */ \ +				| CSOR_NAND_ECC_DEC_EN  /* ECC on decode */ \ +				| CSOR_NAND_ECC_MODE_4  /* 4-bit ECC */ \ +				| CSOR_NAND_RAL_3	/* RAL = 3Byes */ \ +				| CSOR_NAND_PGS_4K	/* Page Size = 4K */ \ +				| CSOR_NAND_SPRZ_224/* Spare size = 224 */ \ +				| CSOR_NAND_PB(64))	/*Pages Per Block = 64*/ + +#define CONFIG_SYS_NAND_ONFI_DETECTION + +/* ONFI NAND Flash mode0 Timing Params */ +#define CONFIG_SYS_NAND_FTIM0		(FTIM0_NAND_TCCST(0x07) | \ +					FTIM0_NAND_TWP(0x18)   | \ +					FTIM0_NAND_TWCHT(0x07) | \ +					FTIM0_NAND_TWH(0x0a)) +#define CONFIG_SYS_NAND_FTIM1		(FTIM1_NAND_TADLE(0x32) | \ +					FTIM1_NAND_TWBE(0x39)  | \ +					FTIM1_NAND_TRR(0x0e)   | \ +					FTIM1_NAND_TRP(0x18)) +#define CONFIG_SYS_NAND_FTIM2		(FTIM2_NAND_TRAD(0x0f) | \ +					FTIM2_NAND_TREH(0x0a) | \ +					FTIM2_NAND_TWHRE(0x1e)) +#define CONFIG_SYS_NAND_FTIM3		0x0 + +#define CONFIG_SYS_NAND_DDR_LAW		11 +#define CONFIG_SYS_NAND_BASE_LIST	{ CONFIG_SYS_NAND_BASE } +#define CONFIG_SYS_MAX_NAND_DEVICE	1 +#define CONFIG_MTD_NAND_VERIFY_WRITE +#define CONFIG_CMD_NAND + +#define CONFIG_SYS_NAND_BLOCK_SIZE	(512 * 1024) + +#if defined(CONFIG_NAND) +#define CONFIG_SYS_CSPR0_EXT		CONFIG_SYS_NAND_CSPR_EXT +#define CONFIG_SYS_CSPR0		CONFIG_SYS_NAND_CSPR +#define CONFIG_SYS_AMASK0		CONFIG_SYS_NAND_AMASK +#define CONFIG_SYS_CSOR0		CONFIG_SYS_NAND_CSOR +#define CONFIG_SYS_CS0_FTIM0		CONFIG_SYS_NAND_FTIM0 +#define CONFIG_SYS_CS0_FTIM1		CONFIG_SYS_NAND_FTIM1 +#define CONFIG_SYS_CS0_FTIM2		CONFIG_SYS_NAND_FTIM2 +#define CONFIG_SYS_CS0_FTIM3		CONFIG_SYS_NAND_FTIM3 +#define CONFIG_SYS_CSPR1_EXT		CONFIG_SYS_NOR_CSPR_EXT +#define CONFIG_SYS_CSPR1		CONFIG_SYS_NOR_CSPR +#define CONFIG_SYS_AMASK1		CONFIG_SYS_NOR_AMASK +#define CONFIG_SYS_CSOR1		CONFIG_SYS_NOR_CSOR +#define CONFIG_SYS_CS1_FTIM0		CONFIG_SYS_NOR_FTIM0 +#define CONFIG_SYS_CS1_FTIM1		CONFIG_SYS_NOR_FTIM1 +#define CONFIG_SYS_CS1_FTIM2		CONFIG_SYS_NOR_FTIM2 +#define CONFIG_SYS_CS1_FTIM3		CONFIG_SYS_NOR_FTIM3 +#else +#define CONFIG_SYS_CSPR0_EXT		CONFIG_SYS_NOR_CSPR_EXT +#define CONFIG_SYS_CSPR0		CONFIG_SYS_NOR_CSPR +#define CONFIG_SYS_AMASK0		CONFIG_SYS_NOR_AMASK +#define CONFIG_SYS_CSOR0		CONFIG_SYS_NOR_CSOR +#define CONFIG_SYS_CS0_FTIM0		CONFIG_SYS_NOR_FTIM0 +#define CONFIG_SYS_CS0_FTIM1		CONFIG_SYS_NOR_FTIM1 +#define CONFIG_SYS_CS0_FTIM2		CONFIG_SYS_NOR_FTIM2 +#define CONFIG_SYS_CS0_FTIM3		CONFIG_SYS_NOR_FTIM3 +#define CONFIG_SYS_CSPR1_EXT		CONFIG_SYS_NAND_CSPR_EXT +#define CONFIG_SYS_CSPR1		CONFIG_SYS_NAND_CSPR +#define CONFIG_SYS_AMASK1		CONFIG_SYS_NAND_AMASK +#define CONFIG_SYS_CSOR1		CONFIG_SYS_NAND_CSOR +#define CONFIG_SYS_CS1_FTIM0		CONFIG_SYS_NAND_FTIM0 +#define CONFIG_SYS_CS1_FTIM1		CONFIG_SYS_NAND_FTIM1 +#define CONFIG_SYS_CS1_FTIM2		CONFIG_SYS_NAND_FTIM2 +#define CONFIG_SYS_CS1_FTIM3		CONFIG_SYS_NAND_FTIM3 +#endif + +#define CONFIG_SYS_MONITOR_BASE		CONFIG_SYS_TEXT_BASE + +#if defined(CONFIG_RAMBOOT_PBL) +#define CONFIG_SYS_RAMBOOT +#endif + +#define CONFIG_BOARD_EARLY_INIT_R +#define CONFIG_MISC_INIT_R + +#define CONFIG_HWCONFIG + +/* define to use L1 as initial stack */ +#define CONFIG_L1_INIT_RAM +#define CONFIG_SYS_INIT_RAM_LOCK +#define CONFIG_SYS_INIT_RAM_ADDR	0xfdd00000	/* Initial L1 address */ +#define CONFIG_SYS_INIT_RAM_ADDR_PHYS_HIGH	0xf +#define CONFIG_SYS_INIT_RAM_ADDR_PHYS_LOW	0xfe0ec000 +/* The assembler doesn't like typecast */ +#define CONFIG_SYS_INIT_RAM_ADDR_PHYS \ +	((CONFIG_SYS_INIT_RAM_ADDR_PHYS_HIGH * 1ull << 32) | \ +	  CONFIG_SYS_INIT_RAM_ADDR_PHYS_LOW) +#define CONFIG_SYS_INIT_RAM_SIZE		0x00004000 + +#define CONFIG_SYS_GBL_DATA_OFFSET	(CONFIG_SYS_INIT_RAM_SIZE - \ +					GENERATED_GBL_DATA_SIZE) +#define CONFIG_SYS_INIT_SP_OFFSET	CONFIG_SYS_GBL_DATA_OFFSET + +#define CONFIG_SYS_MONITOR_LEN		(512 * 1024) +#define CONFIG_SYS_MALLOC_LEN		(4 * 1024 * 1024) + +/* Serial Port - controlled on board with jumper J8 + * open - index 2 + * shorted - index 1 + */ +#define CONFIG_CONS_INDEX	1 +#define CONFIG_SYS_NS16550 +#define CONFIG_SYS_NS16550_SERIAL +#define CONFIG_SYS_NS16550_REG_SIZE	1 +#define CONFIG_SYS_NS16550_CLK		(get_bus_freq(0)/2) + +#define CONFIG_SYS_BAUDRATE_TABLE	\ +	{300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200} + +#define CONFIG_SYS_NS16550_COM1	(CONFIG_SYS_CCSRBAR+0x11C500) +#define CONFIG_SYS_NS16550_COM2	(CONFIG_SYS_CCSRBAR+0x11C600) +#define CONFIG_SYS_NS16550_COM3	(CONFIG_SYS_CCSRBAR+0x11D500) +#define CONFIG_SYS_NS16550_COM4	(CONFIG_SYS_CCSRBAR+0x11D600) +#define CONFIG_SERIAL_MULTI		/* Enable both serial ports */ +#define CONFIG_SYS_CONSOLE_IS_IN_ENV	/* determine from environment */ + +/* Use the HUSH parser */ +#define CONFIG_SYS_HUSH_PARSER +#define CONFIG_SYS_PROMPT_HUSH_PS2 "> " + +/* pass open firmware flat tree */ +#define CONFIG_OF_LIBFDT +#define CONFIG_OF_BOARD_SETUP +#define CONFIG_OF_STDOUT_VIA_ALIAS + +/* new uImage format support */ +#define CONFIG_FIT +#define CONFIG_FIT_VERBOSE	/* enable fit_format_{error,warning}() */ + +/* I2C */ +#define CONFIG_SYS_I2C +#define CONFIG_SYS_I2C_FSL		/* Use FSL common I2C driver */ +#define CONFIG_SYS_FSL_I2C_SPEED	400000	/* I2C speed in Hz */ +#define CONFIG_SYS_FSL_I2C_SLAVE	0x7F +#define CONFIG_SYS_FSL_I2C2_SPEED	400000	/* I2C speed in Hz */ +#define CONFIG_SYS_FSL_I2C2_SLAVE	0x7F +#define CONFIG_SYS_FSL_I2C_OFFSET	0x118000 +#define CONFIG_SYS_FSL_I2C2_OFFSET	0x119000 + +/* I2C bus multiplexer */ +#define I2C_MUX_PCA_ADDR                0x70 + +/* + * RTC configuration + */ +#define RTC +#define CONFIG_RTC_DS1337               1 +#define CONFIG_SYS_I2C_RTC_ADDR         0x68 + +/*DVI encoder*/ +#define CONFIG_HDMI_ENCODER_I2C_ADDR  0x75 + +/* + * eSPI - Enhanced SPI + */ +#define CONFIG_FSL_ESPI +#define CONFIG_SPI_FLASH +#define CONFIG_SPI_FLASH_STMICRO +#define CONFIG_CMD_SF +#define CONFIG_SF_DEFAULT_SPEED         10000000 +#define CONFIG_SF_DEFAULT_MODE          0 + +/* + * General PCI + * Memory space is mapped 1-1, but I/O space must start from 0. + */ + +#ifdef CONFIG_PCI +/* controller 1, direct to uli, tgtid 3, Base address 20000 */ +#ifdef CONFIG_PCIE1 +#define	CONFIG_SYS_PCIE1_MEM_VIRT	0x80000000 +#define	CONFIG_SYS_PCIE1_MEM_BUS	0xe0000000 +#define	CONFIG_SYS_PCIE1_MEM_PHYS	0xc00000000ull +#define CONFIG_SYS_PCIE1_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE1_IO_VIRT	0xf8000000 +#define CONFIG_SYS_PCIE1_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE1_IO_PHYS	0xff8000000ull +#define CONFIG_SYS_PCIE1_IO_SIZE	0x00010000	/* 64k */ +#endif + +/* controller 2, Slot 2, tgtid 2, Base address 201000 */ +#ifdef CONFIG_PCIE2 +#define CONFIG_SYS_PCIE2_MEM_VIRT	0x90000000 +#define CONFIG_SYS_PCIE2_MEM_BUS	0xe0000000 +#define CONFIG_SYS_PCIE2_MEM_PHYS	0xc10000000ull +#define CONFIG_SYS_PCIE2_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE2_IO_VIRT	0xf8010000 +#define CONFIG_SYS_PCIE2_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE2_IO_PHYS	0xff8010000ull +#define CONFIG_SYS_PCIE2_IO_SIZE	0x00010000	/* 64k */ +#endif + +/* controller 3, Slot 1, tgtid 1, Base address 202000 */ +#ifdef CONFIG_PCIE3 +#define CONFIG_SYS_PCIE3_MEM_VIRT	0xa0000000 +#define CONFIG_SYS_PCIE3_MEM_BUS	0xe0000000 +#define CONFIG_SYS_PCIE3_MEM_PHYS	0xc20000000ull +#define CONFIG_SYS_PCIE3_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE3_IO_VIRT	0xf8020000 +#define CONFIG_SYS_PCIE3_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE3_IO_PHYS	0xff8020000ull +#define CONFIG_SYS_PCIE3_IO_SIZE	0x00010000	/* 64k */ +#endif + +/* controller 4, Base address 203000 */ +#ifdef CONFIG_PCIE4 +#define CONFIG_SYS_PCIE4_MEM_VIRT	0xb0000000 +#define CONFIG_SYS_PCIE4_MEM_BUS	0xe0000000 +#define CONFIG_SYS_PCIE4_MEM_PHYS	0xc30000000ull +#define CONFIG_SYS_PCIE4_MEM_SIZE	0x10000000	/* 256M */ +#define CONFIG_SYS_PCIE4_IO_VIRT	0xf8030000 +#define CONFIG_SYS_PCIE4_IO_BUS		0x00000000 +#define CONFIG_SYS_PCIE4_IO_PHYS	0xff8030000ull +#define CONFIG_SYS_PCIE4_IO_SIZE	0x00010000	/* 64k */ +#endif + +#define CONFIG_PCI_PNP			/* do pci plug-and-play */ +#define CONFIG_E1000 + +#define CONFIG_PCI_SCAN_SHOW		/* show pci devices on startup */ +#define CONFIG_DOS_PARTITION +#endif	/* CONFIG_PCI */ + +/* SATA */ +#define CONFIG_FSL_SATA_V2 +#ifdef CONFIG_FSL_SATA_V2 +#define CONFIG_LIBATA +#define CONFIG_FSL_SATA + +#define CONFIG_SYS_SATA_MAX_DEVICE	1 +#define CONFIG_SATA1 +#define CONFIG_SYS_SATA1		CONFIG_SYS_MPC85xx_SATA1_ADDR +#define CONFIG_SYS_SATA1_FLAGS		FLAGS_DMA + +#define CONFIG_LBA48 +#define CONFIG_CMD_SATA +#define CONFIG_DOS_PARTITION +#define CONFIG_CMD_EXT2 +#endif + +/* +* USB +*/ +#define CONFIG_HAS_FSL_DR_USB + +#ifdef CONFIG_HAS_FSL_DR_USB +#define CONFIG_USB_EHCI + +#ifdef CONFIG_USB_EHCI +#define CONFIG_CMD_USB +#define CONFIG_USB_STORAGE +#define CONFIG_USB_EHCI_FSL +#define CONFIG_EHCI_HCD_INIT_AFTER_RESET +#define CONFIG_CMD_EXT2 +#endif +#endif + +#define CONFIG_MMC + +#ifdef CONFIG_MMC +#define CONFIG_FSL_ESDHC +#define CONFIG_SYS_FSL_ESDHC_ADDR       CONFIG_SYS_MPC85xx_ESDHC_ADDR +#define CONFIG_CMD_MMC +#define CONFIG_GENERIC_MMC +#define CONFIG_CMD_EXT2 +#define CONFIG_CMD_FAT +#define CONFIG_DOS_PARTITION +#endif + +/* Qman/Bman */ +#ifndef CONFIG_NOBQFMAN +#define CONFIG_SYS_DPAA_QBMAN		/* Support Q/Bman */ +#define CONFIG_SYS_BMAN_NUM_PORTALS	25 +#define CONFIG_SYS_BMAN_MEM_BASE	0xf4000000 +#define CONFIG_SYS_BMAN_MEM_PHYS	0xff4000000ull +#define CONFIG_SYS_BMAN_MEM_SIZE	0x02000000 +#define CONFIG_SYS_QMAN_NUM_PORTALS	25 +#define CONFIG_SYS_QMAN_MEM_BASE	0xf6000000 +#define CONFIG_SYS_QMAN_MEM_PHYS	0xff6000000ull +#define CONFIG_SYS_QMAN_MEM_SIZE	0x02000000 + +#define CONFIG_SYS_DPAA_FMAN +#define CONFIG_SYS_DPAA_PME + +/* Default address of microcode for the Linux Fman driver */ +#if defined(CONFIG_SPIFLASH) +/* + * env is stored at 0x100000, sector size is 0x10000, ucode is stored after + * env, so we got 0x110000. + */ +#define CONFIG_SYS_QE_FW_IN_SPIFLASH +#define CONFIG_SYS_QE_FMAN_FW_ADDR	0x110000 +#elif defined(CONFIG_SDCARD) +/* + * PBL SD boot image should stored at 0x1000(8 blocks), the size of the image is + * about 545KB (1089 blocks), Env is stored after the image, and the env size is + * 0x2000 (16 blocks), 8 + 1089 + 16 = 1113, enlarge it to 1130. + */ +#define CONFIG_SYS_QE_FMAN_FW_IN_MMC +#define CONFIG_SYS_QE_FMAN_FW_ADDR	(512 * 1130) +#elif defined(CONFIG_NAND) +#define CONFIG_SYS_QE_FMAN_FW_IN_NAND +#define CONFIG_SYS_QE_FMAN_FW_ADDR	(6 * CONFIG_SYS_NAND_BLOCK_SIZE) +#else +#define CONFIG_SYS_QE_FMAN_FW_IN_NOR +#define CONFIG_SYS_QE_FMAN_FW_ADDR		0xEFF40000 +#endif +#define CONFIG_SYS_QE_FMAN_FW_LENGTH	0x10000 +#define CONFIG_SYS_FDT_PAD		(0x3000 + CONFIG_SYS_QE_FMAN_FW_LENGTH) +#endif /* CONFIG_NOBQFMAN */ + +#ifdef CONFIG_SYS_DPAA_FMAN +#define CONFIG_FMAN_ENET +#define CONFIG_PHY_VITESSE +#define CONFIG_PHY_REALTEK +#endif + +#ifdef CONFIG_FMAN_ENET +#define CONFIG_MII		/* MII PHY management */ +#define CONFIG_ETHPRIME		"FM1@DTSEC1" +#define CONFIG_PHY_GIGE		/* Include GbE speed/duplex detection */ +#endif + +/* + * Environment + */ +#define CONFIG_LOADS_ECHO		/* echo on for serial download */ +#define CONFIG_SYS_LOADS_BAUD_CHANGE	/* allow baudrate change */ + +/* + * Command line configuration. + */ +#include <config_cmd_default.h> + +#define CONFIG_CMD_DATE +#define CONFIG_CMD_DHCP +#define CONFIG_CMD_ELF +#define CONFIG_CMD_ERRATA +#define CONFIG_CMD_GREPENV +#define CONFIG_CMD_IRQ +#define CONFIG_CMD_I2C +#define CONFIG_CMD_MII +#define CONFIG_CMD_PING +#define CONFIG_CMD_REGINFO +#define CONFIG_CMD_SETEXPR + +#ifdef CONFIG_PCI +#define CONFIG_CMD_PCI +#define CONFIG_CMD_NET +#endif + +/* + * Miscellaneous configurable options + */ +#define CONFIG_SYS_LONGHELP			/* undef to save memory	*/ +#define CONFIG_CMDLINE_EDITING			/* Command-line editing */ +#define CONFIG_AUTO_COMPLETE			/* add autocompletion support */ +#define CONFIG_SYS_LOAD_ADDR	0x2000000	/* default load address */ +#define CONFIG_SYS_PROMPT	"=> "		/* Monitor Command Prompt */ +#ifdef CONFIG_CMD_KGDB +#define CONFIG_SYS_CBSIZE	1024		/* Console I/O Buffer Size */ +#else +#define CONFIG_SYS_CBSIZE	256		/* Console I/O Buffer Size */ +#endif +#define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE+sizeof(CONFIG_SYS_PROMPT)+16) +#define CONFIG_SYS_MAXARGS	16		/* max number of command args */ +#define CONFIG_SYS_BARGSIZE	CONFIG_SYS_CBSIZE/* Boot Argument Buffer Size */ +#define CONFIG_SYS_HZ		1000		/* decrementer freq: 1ms ticks*/ + +/* + * For booting Linux, the board info and command line data + * have to be in the first 64 MB of memory, since this is + * the maximum mapped by the Linux kernel during initialization. + */ +#define CONFIG_SYS_BOOTMAPSZ	(64 << 20)	/* Initial map for Linux*/ +#define CONFIG_SYS_BOOTM_LEN	(64 << 20)	/* Increase max gunzip size */ + +#ifdef CONFIG_CMD_KGDB +#define CONFIG_KGDB_BAUDRATE	230400	/* speed to run kgdb serial port */ +#define CONFIG_KGDB_SER_INDEX	2	/* which serial port to use */ +#endif + +/* + * Environment Configuration + */ +#define CONFIG_ROOTPATH		"/opt/nfsroot" +#define CONFIG_BOOTFILE		"uImage" +#define CONFIG_UBOOTPATH	"u-boot.bin"	/* U-Boot image on TFTP server*/ + +/* default location for tftp and bootm */ +#define CONFIG_LOADADDR		1000000 + +#define CONFIG_BOOTDELAY	10	/*-1 disables auto-boot*/ + +#define CONFIG_BAUDRATE	115200 + +#define __USB_PHY_TYPE	utmi + +#define	CONFIG_EXTRA_ENV_SETTINGS				\ +	"hwconfig=fsl_ddr:ctlr_intlv=cacheline,"		\ +	"bank_intlv=cs0_cs1;"					\ +	"usb1:dr_mode=host,phy_type=" __stringify(__USB_PHY_TYPE) "\0"\ +	"netdev=eth0\0"						\ +	"uboot=" __stringify(CONFIG_UBOOTPATH) "\0"		\ +	"ubootaddr=" __stringify(CONFIG_SYS_TEXT_BASE) "\0"	\ +	"tftpflash=tftpboot $loadaddr $uboot && "		\ +	"protect off $ubootaddr +$filesize && "			\ +	"erase $ubootaddr +$filesize && "			\ +	"cp.b $loadaddr $ubootaddr $filesize && "		\ +	"protect on $ubootaddr +$filesize && "			\ +	"cmp.b $loadaddr $ubootaddr $filesize\0"		\ +	"consoledev=ttyS0\0"					\ +	"ramdiskaddr=2000000\0"					\ +	"ramdiskfile=t1040rdb_pi/ramdisk.uboot\0"			\ +	"fdtaddr=c00000\0"					\ +	"fdtfile=t1040rdb_pi/t1040rdb_pi.dtb\0"				\ +	"bdev=sda3\0"						\ +	"c=ffe\0" + +#define CONFIG_LINUX                       \ +	"setenv bootargs root=/dev/ram rw "            \ +	"console=$consoledev,$baudrate $othbootargs;"  \ +	"setenv ramdiskaddr 0x02000000;"               \ +	"setenv fdtaddr 0x00c00000;"		       \ +	"setenv loadaddr 0x1000000;"		       \ +	"bootm $loadaddr $ramdiskaddr $fdtaddr" + +#define CONFIG_HDBOOT					\ +	"setenv bootargs root=/dev/$bdev rw "		\ +	"console=$consoledev,$baudrate $othbootargs;"	\ +	"tftp $loadaddr $bootfile;"			\ +	"tftp $fdtaddr $fdtfile;"			\ +	"bootm $loadaddr - $fdtaddr" + +#define CONFIG_NFSBOOTCOMMAND			\ +	"setenv bootargs root=/dev/nfs rw "	\ +	"nfsroot=$serverip:$rootpath "		\ +	"ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname:$netdev:off " \ +	"console=$consoledev,$baudrate $othbootargs;"	\ +	"tftp $loadaddr $bootfile;"		\ +	"tftp $fdtaddr $fdtfile;"		\ +	"bootm $loadaddr - $fdtaddr" + +#define CONFIG_RAMBOOTCOMMAND				\ +	"setenv bootargs root=/dev/ram rw "		\ +	"console=$consoledev,$baudrate $othbootargs;"	\ +	"tftp $ramdiskaddr $ramdiskfile;"		\ +	"tftp $loadaddr $bootfile;"			\ +	"tftp $fdtaddr $fdtfile;"			\ +	"bootm $loadaddr $ramdiskaddr $fdtaddr" + +#define CONFIG_BOOTCOMMAND		CONFIG_LINUX + +#ifdef CONFIG_SECURE_BOOT +#include <asm/fsl_secure_boot.h> +#endif + +#endif	/* __CONFIG_H */ diff --git a/include/configs/am335x_evm.h b/include/configs/am335x_evm.h index c2ba7e35d..f35ed6fba 100644 --- a/include/configs/am335x_evm.h +++ b/include/configs/am335x_evm.h @@ -183,7 +183,6 @@  #define CONFIG_SYS_NS16550_COM6		0x481aa000	/* UART5 */  #define CONFIG_BAUDRATE			115200 -/* I2C Configuration */  #define CONFIG_CMD_EEPROM  #define CONFIG_ENV_EEPROM_IS_ON_I2C  #define CONFIG_SYS_I2C_EEPROM_ADDR	0x50	/* Main EEPROM */ diff --git a/include/configs/am3517_crane.h b/include/configs/am3517_crane.h index c5e67bf87..6fd3fb904 100644 --- a/include/configs/am3517_crane.h +++ b/include/configs/am3517_crane.h @@ -142,10 +142,10 @@  #undef CONFIG_CMD_IMLS		/* List all found images	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  #undef CONFIG_CMD_NET  #undef CONFIG_CMD_NFS diff --git a/include/configs/am3517_evm.h b/include/configs/am3517_evm.h index 5ff65c6d5..7e9c55edf 100644 --- a/include/configs/am3517_evm.h +++ b/include/configs/am3517_evm.h @@ -136,10 +136,10 @@  #undef CONFIG_CMD_IMLS		/* List all found images	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  #undef CONFIG_CMD_NET  #undef CONFIG_CMD_NFS diff --git a/include/configs/bct-brettl2.h b/include/configs/bct-brettl2.h index ce09c2e13..5b09b45b5 100644 --- a/include/configs/bct-brettl2.h +++ b/include/configs/bct-brettl2.h @@ -111,8 +111,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/bf533-stamp.h b/include/configs/bf533-stamp.h index 7144c6319..a22c86842 100644 --- a/include/configs/bf533-stamp.h +++ b/include/configs/bf533-stamp.h @@ -155,8 +155,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/bf537-pnav.h b/include/configs/bf537-pnav.h index 62bd3bf08..3aa3d50a8 100644 --- a/include/configs/bf537-pnav.h +++ b/include/configs/bf537-pnav.h @@ -111,8 +111,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/bf537-stamp.h b/include/configs/bf537-stamp.h index 25cebf880..02945bee7 100644 --- a/include/configs/bf537-stamp.h +++ b/include/configs/bf537-stamp.h @@ -118,8 +118,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/bf538f-ezkit.h b/include/configs/bf538f-ezkit.h index 77822e792..ffb0caf94 100644 --- a/include/configs/bf538f-ezkit.h +++ b/include/configs/bf538f-ezkit.h @@ -115,8 +115,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/cm-bf537e.h b/include/configs/cm-bf537e.h index 77f47d945..8f10eba46 100644 --- a/include/configs/cm-bf537e.h +++ b/include/configs/cm-bf537e.h @@ -112,8 +112,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/cm-bf537u.h b/include/configs/cm-bf537u.h index 55e61d674..a1c8e8a85 100644 --- a/include/configs/cm-bf537u.h +++ b/include/configs/cm-bf537u.h @@ -110,8 +110,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/cm_t35.h b/include/configs/cm_t35.h index a6c63cb49..f4ecd0ddb 100644 --- a/include/configs/cm_t35.h +++ b/include/configs/cm_t35.h @@ -141,10 +141,10 @@  #undef CONFIG_CMD_IMLS		/* List all found images	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  #define CONFIG_SYS_I2C_EEPROM_ADDR	0x50  #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN	1  #define CONFIG_I2C_MULTI_BUS diff --git a/include/configs/devkit8000.h b/include/configs/devkit8000.h index 8343891cb..474a5687a 100644 --- a/include/configs/devkit8000.h +++ b/include/configs/devkit8000.h @@ -90,10 +90,10 @@  #define CONFIG_DOS_PARTITION		1  /* I2C */ -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /* TWL4030 */  #define CONFIG_TWL4030_POWER		1 diff --git a/include/configs/dig297.h b/include/configs/dig297.h index c19c4c754..5049afca7 100644 --- a/include/configs/dig297.h +++ b/include/configs/dig297.h @@ -123,10 +123,10 @@  #undef CONFIG_CMD_NFS		/* NFS support			*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/dnp5370.h b/include/configs/dnp5370.h index f2f41028e..d0e72e3e1 100644 --- a/include/configs/dnp5370.h +++ b/include/configs/dnp5370.h @@ -85,8 +85,8 @@  #define ENV_IS_EMBEDDED  #define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*); diff --git a/include/configs/ecovec.h b/include/configs/ecovec.h index 335e9cdff..3483cf1f5 100644 --- a/include/configs/ecovec.h +++ b/include/configs/ecovec.h @@ -58,18 +58,17 @@  /* I2C */  #define CONFIG_CMD_I2C -#define CONFIG_SH_I2C 1 -#define CONFIG_HARD_I2C		1 -#define CONFIG_I2C_MULTI_BUS	1 -#define CONFIG_SYS_MAX_I2C_BUS	2 -#define CONFIG_SYS_I2C_MODULE	1 -#define CONFIG_SYS_I2C_SPEED	100000 /* 100 kHz */ +#define CONFIG_SYS_I2C +#define CONFIG_SYS_I2C_SH  #define CONFIG_SYS_I2C_SLAVE	0x7F +#define CONFIG_SYS_I2C_SH_NUM_CONTROLLERS 2 +#define CONFIG_SYS_I2C_SH_BASE0	0xA4470000 +#define CONFIG_SYS_I2C_SH_SPEED0	100000 +#define CONFIG_SYS_I2C_SH_BASE1	0xA4750000 +#define CONFIG_SYS_I2C_SH_SPEED1	100000  #define CONFIG_SH_I2C_DATA_HIGH	4  #define CONFIG_SH_I2C_DATA_LOW 	5  #define CONFIG_SH_I2C_CLOCK  	41666666 -#define CONFIG_SH_I2C_BASE0		0xA4470000 -#define CONFIG_SH_I2C_BASE1		0xA4750000  /* Ether */  #define CONFIG_SH_ETHER 1 diff --git a/include/configs/highbank.h b/include/configs/highbank.h index b86eb430a..7dbee3cdb 100644 --- a/include/configs/highbank.h +++ b/include/configs/highbank.h @@ -8,7 +8,6 @@  #define __CONFIG_H  #define CONFIG_SYS_DCACHE_OFF -#define CONFIG_L2_OFF  #define CONFIG_SYS_THUMB_BUILD  #define CONFIG_SYS_NO_FLASH diff --git a/include/configs/ibf-dsp561.h b/include/configs/ibf-dsp561.h index 529175512..ac5ca9af3 100644 --- a/include/configs/ibf-dsp561.h +++ b/include/configs/ibf-dsp561.h @@ -95,8 +95,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/kzm9g.h b/include/configs/kzm9g.h index 1afd48793..f183279ba 100644 --- a/include/configs/kzm9g.h +++ b/include/configs/kzm9g.h @@ -22,7 +22,6 @@  #define CONFIG_DISPLAY_CPUINFO  #define CONFIG_DISPLAY_BOARDINFO  #define CONFIG_BOARD_EARLY_INIT_F -#define CONFIG_L2_OFF  #define CONFIG_OF_LIBFDT  #include <config_cmd_default.h> @@ -139,21 +138,22 @@  /* I2C */  #define CONFIG_CMD_I2C -#define CONFIG_SH_I2C 1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_I2C_SH +#define CONFIG_SYS_I2C_SH_NUM_CONTROLLERS 5 +#define CONFIG_SYS_I2C_SH_BASE0	0xE6820000 +#define CONFIG_SYS_I2C_SH_SPEED0	100000 +#define CONFIG_SYS_I2C_SH_BASE1	0xE6822000 +#define CONFIG_SYS_I2C_SH_SPEED1	100000 +#define CONFIG_SYS_I2C_SH_BASE2	0xE6824000 +#define CONFIG_SYS_I2C_SH_SPEED2	100000 +#define CONFIG_SYS_I2C_SH_BASE3	0xE6826000 +#define CONFIG_SYS_I2C_SH_SPEED3	100000 +#define CONFIG_SYS_I2C_SH_BASE4	0xE6828000 +#define CONFIG_SYS_I2C_SH_SPEED4	100000  #define CONFIG_SH_I2C_8BIT -#define CONFIG_HARD_I2C -#define CONFIG_I2C_MULTI_BUS -#define CONFIG_SYS_MAX_I2C_BUS  (5) -#define CONFIG_SYS_I2C_MODULE -#define CONFIG_SYS_I2C_SPEED    (100000) /* 100 kHz */ -#define CONFIG_SYS_I2C_SLAVE    (0x7F) -#define CONFIG_SH_I2C_DATA_HIGH (4) -#define CONFIG_SH_I2C_DATA_LOW  (5) -#define CONFIG_SH_I2C_CLOCK     (104000000) /* 104 MHz */ -#define CONFIG_SH_I2C_BASE0     (0xE6820000) -#define CONFIG_SH_I2C_BASE1     (0xE6822000) -#define CONFIG_SH_I2C_BASE2     (0xE6824000) -#define CONFIG_SH_I2C_BASE3     (0xE6826000) -#define CONFIG_SH_I2C_BASE4     (0xE6828000) +#define CONFIG_SH_I2C_DATA_HIGH 4 +#define CONFIG_SH_I2C_DATA_LOW  5 +#define CONFIG_SH_I2C_CLOCK     104000000 /* 104 MHz */  #endif /* __KZM9G_H */ diff --git a/include/configs/mcx.h b/include/configs/mcx.h index 4619dfb3e..a2f7cf711 100644 --- a/include/configs/mcx.h +++ b/include/configs/mcx.h @@ -137,10 +137,10 @@  #undef CONFIG_CMD_IMLS		/* List all found images	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /* RTC */  #define CONFIG_RTC_DS1337 diff --git a/include/configs/mx51_efikamx.h b/include/configs/mx51_efikamx.h index 8a44ef5a7..0f2a4ef97 100644 --- a/include/configs/mx51_efikamx.h +++ b/include/configs/mx51_efikamx.h @@ -29,7 +29,6 @@  #define CONFIG_SYS_TEXT_BASE		0x97800000 -#define	CONFIG_L2_OFF  #define	CONFIG_SYS_ICACHE_OFF  #define	CONFIG_SYS_DCACHE_OFF diff --git a/include/configs/nokia_rx51.h b/include/configs/nokia_rx51.h index 4332779d2..e0c0fac8e 100644 --- a/include/configs/nokia_rx51.h +++ b/include/configs/nokia_rx51.h @@ -157,10 +157,10 @@  #undef CONFIG_CMD_SETGETDCR		/* DCR support on 4xx */  #define CONFIG_OMAP3_SPI -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/omap3_beagle.h b/include/configs/omap3_beagle.h index 47d990208..bba39d428 100644 --- a/include/configs/omap3_beagle.h +++ b/include/configs/omap3_beagle.h @@ -161,11 +161,10 @@  #undef CONFIG_CMD_IMLS		/* List all found images	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_I2C_MULTI_BUS		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  #define CONFIG_VIDEO_OMAP3	/* DSS Support			*/  /* diff --git a/include/configs/omap3_evm_common.h b/include/configs/omap3_evm_common.h index 3eae28884..43616e2b0 100644 --- a/include/configs/omap3_evm_common.h +++ b/include/configs/omap3_evm_common.h @@ -87,11 +87,10 @@  /*   * I2C   */ -#define CONFIG_HARD_I2C -#define CONFIG_DRIVER_OMAP34XX_I2C - -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * PISMO support diff --git a/include/configs/omap3_igep00x0.h b/include/configs/omap3_igep00x0.h index ac36ac695..75d7d70d2 100644 --- a/include/configs/omap3_igep00x0.h +++ b/include/configs/omap3_igep00x0.h @@ -124,10 +124,10 @@  #undef CONFIG_CMD_IMLS		/* List all found images	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_I2C_OMAP34XX +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1  /*   * TWL4030 diff --git a/include/configs/omap3_logic.h b/include/configs/omap3_logic.h index 0c096f429..bedd6f9cb 100644 --- a/include/configs/omap3_logic.h +++ b/include/configs/omap3_logic.h @@ -118,12 +118,10 @@  /*   * I2C   */ -#define CONFIG_HARD_I2C -#define CONFIG_DRIVER_OMAP34XX_I2C - -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_I2C_MULTI_BUS +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/omap3_mvblx.h b/include/configs/omap3_mvblx.h index 45da2e00b..8d11010f8 100644 --- a/include/configs/omap3_mvblx.h +++ b/include/configs/omap3_mvblx.h @@ -128,11 +128,10 @@  #define CONFIG_CMD_PING  #define CONFIG_CMD_FPGA -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		0 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 -#define CONFIG_I2C_MULTI_BUS		1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/omap3_overo.h b/include/configs/omap3_overo.h index 46416946c..84b4aeee2 100644 --- a/include/configs/omap3_overo.h +++ b/include/configs/omap3_overo.h @@ -98,11 +98,10 @@  #define CONFIG_CMD_NET		/* bootp, tftpboot, rarpboot	*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_I2C_MULTI_BUS -#define CONFIG_DRIVER_OMAP34XX_I2C +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/omap3_pandora.h b/include/configs/omap3_pandora.h index 3cce0de48..eacdfaaa5 100644 --- a/include/configs/omap3_pandora.h +++ b/include/configs/omap3_pandora.h @@ -111,10 +111,10 @@  #undef CONFIG_CMD_NFS		/* NFS support			*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/omap3_sdp3430.h b/include/configs/omap3_sdp3430.h index 697a3f386..6f1304dc9 100644 --- a/include/configs/omap3_sdp3430.h +++ b/include/configs/omap3_sdp3430.h @@ -114,10 +114,10 @@  /*   * I2C for power management setup   */ -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /* OMITTED:  single 1 Gbit MT29F1G NAND flash */ diff --git a/include/configs/omap3_zoom1.h b/include/configs/omap3_zoom1.h index 8591f98a8..1dd53fa13 100644 --- a/include/configs/omap3_zoom1.h +++ b/include/configs/omap3_zoom1.h @@ -118,10 +118,10 @@  #undef CONFIG_CMD_NFS		/* NFS support			*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/omap3_zoom2.h b/include/configs/omap3_zoom2.h index cb8c7ec6f..f74974081 100644 --- a/include/configs/omap3_zoom2.h +++ b/include/configs/omap3_zoom2.h @@ -138,10 +138,10 @@  #undef CONFIG_CMD_NFS			/* NFS support			*/  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C			1 -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  /*   * TWL4030 diff --git a/include/configs/origen.h b/include/configs/origen.h index bad34b3e7..f46b833b5 100644 --- a/include/configs/origen.h +++ b/include/configs/origen.h @@ -22,8 +22,6 @@  #define CONFIG_DISPLAY_BOARDINFO  #define CONFIG_BOARD_EARLY_INIT_F -/* Keep L2 Cache Disabled */ -#define CONFIG_L2_OFF			1  #define CONFIG_SYS_DCACHE_OFF		1  #define CONFIG_SYS_SDRAM_BASE		0x40000000 diff --git a/include/configs/pcm051.h b/include/configs/pcm051.h index 4970b13e9..6f41ee771 100644 --- a/include/configs/pcm051.h +++ b/include/configs/pcm051.h @@ -172,11 +172,10 @@  /* I2C Configuration */  #define CONFIG_I2C  #define CONFIG_CMD_I2C -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_I2C_MULTI_BUS -#define CONFIG_DRIVER_OMAP24XX_I2C +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP24XX  #define CONFIG_CMD_EEPROM  #define CONFIG_ENV_EEPROM_IS_ON_I2C  #define CONFIG_SYS_I2C_EEPROM_ADDR	0x50	/* Main EEPROM */ diff --git a/include/configs/siemens-am33x-common.h b/include/configs/siemens-am33x-common.h index 9eb0a04da..745e3bea5 100644 --- a/include/configs/siemens-am33x-common.h +++ b/include/configs/siemens-am33x-common.h @@ -131,11 +131,10 @@  /* I2C Configuration */  #define CONFIG_I2C  #define CONFIG_CMD_I2C -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_I2C_MULTI_BUS -#define CONFIG_DRIVER_OMAP24XX_I2C - +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	OMAP_I2C_STANDARD +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP24XX  /* Defines for SPL */  #define CONFIG_SPL diff --git a/include/configs/smdkv310.h b/include/configs/smdkv310.h index e2e8efe58..1388f4998 100644 --- a/include/configs/smdkv310.h +++ b/include/configs/smdkv310.h @@ -25,9 +25,6 @@  /* Mach Type */  #define CONFIG_MACH_TYPE		MACH_TYPE_SMDKV310 -/* Keep L2 Cache Disabled */ -#define CONFIG_L2_OFF			1 -  #define CONFIG_SYS_SDRAM_BASE		0x40000000  #define CONFIG_SYS_TEXT_BASE		0x43E00000 diff --git a/include/configs/snowball.h b/include/configs/snowball.h index 00d6fa5e8..9a069f3cd 100644 --- a/include/configs/snowball.h +++ b/include/configs/snowball.h @@ -23,7 +23,6 @@   * (easy to change)   */  #define CONFIG_U8500 -#define CONFIG_L2_OFF  #define CONFIG_SYS_MEMTEST_START	0x00000000  #define CONFIG_SYS_MEMTEST_END	0x1FFFFFFF diff --git a/include/configs/socfpga_cyclone5.h b/include/configs/socfpga_cyclone5.h index 980636c93..608578ad2 100644 --- a/include/configs/socfpga_cyclone5.h +++ b/include/configs/socfpga_cyclone5.h @@ -16,7 +16,6 @@  #define CONFIG_SOCFPGA_VIRTUAL_TARGET  #define CONFIG_ARMV7 -#define CONFIG_L2_OFF  #define CONFIG_SYS_DCACHE_OFF  #undef CONFIG_USE_IRQ diff --git a/include/configs/tam3517-common.h b/include/configs/tam3517-common.h index 683bc54a2..6112c1b7a 100644 --- a/include/configs/tam3517-common.h +++ b/include/configs/tam3517-common.h @@ -117,14 +117,13 @@  #undef CONFIG_CMD_IMLS  #define CONFIG_SYS_NO_FLASH -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		400000 -#define CONFIG_SYS_I2C_SLAVE		1 +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	400000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX  #define CONFIG_SYS_I2C_EEPROM_ADDR	0x50		/* base address */  #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN	1		/* bytes of address */  #define CONFIG_SYS_I2C_EEPROM_ADDR_OVERFLOW	0x07 -#define CONFIG_DRIVER_OMAP34XX_I2C -  /*   * Board NAND Info. @@ -369,7 +368,7 @@ struct tam3517_module_info {  #define TAM3517_READ_EEPROM(info, ret) \  do {								\ -	i2c_init(CONFIG_SYS_I2C_SPEED, CONFIG_SYS_I2C_SLAVE);	\ +	i2c_init(CONFIG_SYS_OMAP24_I2C_SPEED, CONFIG_SYS_OMAP24_I2C_SLAVE); \  	if (eeprom_read(CONFIG_SYS_I2C_EEPROM_ADDR, 0,		\  		(void *)info, sizeof(*info)))			\  		ret = 1;					\ diff --git a/include/configs/tcm-bf537.h b/include/configs/tcm-bf537.h index 2adb071dd..627836a7e 100644 --- a/include/configs/tcm-bf537.h +++ b/include/configs/tcm-bf537.h @@ -112,8 +112,8 @@   * it linked after the configuration sector.   */  # define LDS_BOARD_TEXT \ -	arch/blackfin/lib/libblackfin.o (.text*); \ -	arch/blackfin/cpu/libblackfin.o (.text*); \ +	arch/blackfin/lib/built-in.o (.text*); \ +	arch/blackfin/cpu/built-in.o (.text*); \  	. = DEFINED(env_offset) ? env_offset : .; \  	common/env_embedded.o (.text*);  #endif diff --git a/include/configs/ti_armv7_common.h b/include/configs/ti_armv7_common.h index 84269ad26..99b60fcf6 100644 --- a/include/configs/ti_armv7_common.h +++ b/include/configs/ti_armv7_common.h @@ -59,12 +59,11 @@  /* I2C IP block */  #define CONFIG_I2C -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_I2C_MULTI_BUS -#define CONFIG_DRIVER_OMAP24XX_I2C  #define CONFIG_CMD_I2C +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP24XX  /* MMC/SD IP block */  #define CONFIG_MMC diff --git a/include/configs/tricorder.h b/include/configs/tricorder.h index d57394e55..afd870762 100644 --- a/include/configs/tricorder.h +++ b/include/configs/tricorder.h @@ -98,11 +98,11 @@  #define CONFIG_DOS_PARTITION  /* I2C */ -#define CONFIG_HARD_I2C -#define CONFIG_SYS_I2C_SPEED		100000 -#define CONFIG_SYS_I2C_SLAVE		1 -#define CONFIG_DRIVER_OMAP34XX_I2C	1 -#define CONFIG_I2C_MULTI_BUS +#define CONFIG_SYS_I2C +#define CONFIG_SYS_OMAP24_I2C_SPEED	100000 +#define CONFIG_SYS_OMAP24_I2C_SLAVE	1 +#define CONFIG_SYS_I2C_OMAP34XX +   /* EEPROM */  #define CONFIG_SYS_I2C_MULTI_EEPROMS diff --git a/include/configs/u8500_href.h b/include/configs/u8500_href.h index 45d33a689..629299d10 100644 --- a/include/configs/u8500_href.h +++ b/include/configs/u8500_href.h @@ -12,7 +12,6 @@   * (easy to change)   */  #define CONFIG_U8500 -#define CONFIG_L2_OFF  #define CONFIG_SYS_MEMTEST_START	0x00000000  #define CONFIG_SYS_MEMTEST_END	0x1FFFFFFF diff --git a/include/configs/zynq.h b/include/configs/zynq.h index 4c6e6e8f6..82ec826f7 100644 --- a/include/configs/zynq.h +++ b/include/configs/zynq.h @@ -60,10 +60,10 @@  /* I2C */  #if defined(CONFIG_ZYNQ_I2C0) || defined(CONFIG_ZYNQ_I2C1)  # define CONFIG_CMD_I2C -# define CONFIG_ZYNQ_I2C -# define CONFIG_HARD_I2C -# define CONFIG_SYS_I2C_SPEED		100000 -# define CONFIG_SYS_I2C_SLAVE		1 +# define CONFIG_SYS_I2C +# define CONFIG_SYS_I2C_ZYNQ +# define CONFIG_SYS_I2C_ZYNQ_SPEED		100000 +# define CONFIG_SYS_I2C_ZYNQ_SLAVE		1  #endif  #if defined(CONFIG_ZYNQ_DCC) diff --git a/lib/lzma/Makefile b/lib/lzma/Makefile index 25c6797fb..f8eda06c9 100644 --- a/lib/lzma/Makefile +++ b/lib/lzma/Makefile @@ -10,4 +10,4 @@  CFLAGS += -D_LZMA_PROB32 -obj-$(CONFIG_LZMA) += LzmaDec.o LzmaTools.o +obj-y += LzmaDec.o LzmaTools.o diff --git a/lib/lzo/Makefile b/lib/lzo/Makefile index dd853eae2..2936544ab 100644 --- a/lib/lzo/Makefile +++ b/lib/lzo/Makefile @@ -5,4 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_LZO) += lzo1x_decompress.o +obj-y += lzo1x_decompress.o diff --git a/lib/rsa/Makefile b/lib/rsa/Makefile index 693c74551..164ab3996 100644 --- a/lib/rsa/Makefile +++ b/lib/rsa/Makefile @@ -7,6 +7,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -ifdef CONFIG_FIT_SIGNATURE -obj-$(CONFIG_RSA) += rsa-verify.o -endif +obj-$(CONFIG_FIT_SIGNATURE) += rsa-verify.o diff --git a/lib/zlib/Makefile b/lib/zlib/Makefile index 1e9e04d99..2fba95f43 100644 --- a/lib/zlib/Makefile +++ b/lib/zlib/Makefile @@ -5,4 +5,4 @@  # SPDX-License-Identifier:	GPL-2.0+  # -obj-$(CONFIG_ZLIB) += zlib.o +obj-y += zlib.o diff --git a/scripts/Makefile.build b/scripts/Makefile.build index 2ef7341f3..e3354aaa3 100644 --- a/scripts/Makefile.build +++ b/scripts/Makefile.build @@ -10,10 +10,6 @@ SRCS :=  include Makefile -# Backward compatible: obj-y is preferable -COBJS := $(sort $(COBJS) $(COBJS-y)) -SOBJS := $(sort $(SOBJS) $(SOBJS-y)) -  # Going forward use the following  obj-y := $(sort $(obj-y))  extra-y := $(sort $(extra-y)) @@ -24,11 +20,18 @@ obj-y		:= $(patsubst %/, %/built-in.o, $(obj-y))  subdir-obj-y	:= $(filter %/built-in.o, $(obj-y))  subdir-obj-y	:= $(addprefix $(obj),$(subdir-obj-y)) -SRCS	+= $(COBJS:.o=.c) $(SOBJS:.o=.S) \ - $(wildcard $(obj-y:.o=.c) $(obj-y:.o=.S) $(lib-y:.o=.c) $(lib-y:.o=.S) $(extra-y:.o=.c) $(extra-y:.o=.S)) -OBJS	:= $(addprefix $(obj),$(COBJS) $(SOBJS) $(obj-y)) +SRCS	+= $(wildcard $(obj-y:.o=.c) $(obj-y:.o=.S) $(lib-y:.o=.c) \ +	$(lib-y:.o=.S) $(extra-y:.o=.c) $(extra-y:.o=.S)) +OBJS	:= $(addprefix $(obj),$(obj-y)) + +# $(obj-dirs) is a list of directories that contain object files +obj-dirs := $(dir $(OBJS)) + +# Create directories for object files if directory does not exist +# Needed when obj-y := dir/file.o syntax is used +_dummy := $(foreach d,$(obj-dirs), $(shell [ -d $(d) ] || mkdir -p $(d))) -LGOBJS := $(addprefix $(obj),$(sort $(GLSOBJS) $(GLCOBJS)) $(lib-y)) +LGOBJS := $(addprefix $(obj),$(sort $(lib-y)))  all: $(LIB) $(addprefix $(obj),$(extra-y)) diff --git a/spl/Makefile b/spl/Makefile index cbd3d2784..29d7818df 100644 --- a/spl/Makefile +++ b/spl/Makefile @@ -54,63 +54,54 @@ ifeq ($(CPU),mpc85xx)  START += $(START_PATH)/resetvec.o  endif -LIBS-y += arch/$(ARCH)/lib/lib$(ARCH).o +LIBS-y += arch/$(ARCH)/lib/ -LIBS-y += $(CPUDIR)/lib$(CPU).o -ifeq ($(CPU),mpc83xx) -LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o -endif -ifeq ($(CPU),mpc85xx) -LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o -ifdef CONFIG_SPL_MPC8XXX_INIT_DDR_SUPPORT -LIBS-y += arch/powerpc/cpu/mpc8xxx/ddr/libddr.o -endif -endif -ifeq ($(CPU),mpc86xx) -LIBS-y += arch/powerpc/cpu/mpc8xxx/lib8xxx.o -endif +LIBS-y += $(CPUDIR)/  ifdef SOC -LIBS-y += $(CPUDIR)/$(SOC)/lib$(SOC).o +LIBS-y += $(CPUDIR)/$(SOC)/  endif -LIBS-y += board/$(BOARDDIR)/lib$(BOARD).o -LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/lib$(VENDOR).o +LIBS-y += board/$(BOARDDIR)/ +LIBS-$(HAVE_VENDOR_COMMON_LIB) += board/$(VENDOR)/common/ -LIBS-$(CONFIG_SPL_FRAMEWORK) += common/spl/libspl.o -LIBS-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/libcommon.o -LIBS-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/libdisk.o -LIBS-$(CONFIG_SPL_I2C_SUPPORT) += drivers/i2c/libi2c.o -LIBS-$(CONFIG_SPL_GPIO_SUPPORT) += drivers/gpio/libgpio.o -LIBS-$(CONFIG_SPL_MMC_SUPPORT) += drivers/mmc/libmmc.o -LIBS-$(CONFIG_SPL_SERIAL_SUPPORT) += drivers/serial/libserial.o -LIBS-$(CONFIG_SPL_SPI_FLASH_SUPPORT) += drivers/mtd/spi/libspi_flash.o -LIBS-$(CONFIG_SPL_SPI_SUPPORT) += drivers/spi/libspi.o -LIBS-$(CONFIG_SPL_FAT_SUPPORT) += fs/fat/libfat.o -LIBS-$(CONFIG_SPL_LIBGENERIC_SUPPORT) += lib/libgeneric.o -LIBS-$(CONFIG_SPL_POWER_SUPPORT) += drivers/power/libpower.o \ -	drivers/power/pmic/libpmic.o -LIBS-$(CONFIG_SPL_NAND_SUPPORT) += drivers/mtd/nand/libnand.o -LIBS-$(CONFIG_SPL_ONENAND_SUPPORT) += drivers/mtd/onenand/libonenand.o -LIBS-$(CONFIG_SPL_DMA_SUPPORT) += drivers/dma/libdma.o -LIBS-$(CONFIG_SPL_POST_MEM_SUPPORT) += post/drivers/memory.o -LIBS-$(CONFIG_SPL_NET_SUPPORT) += net/libnet.o -LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/libnet.o -LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/phy/libphy.o -LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/net/phy/libphy.o -LIBS-$(CONFIG_SPL_MUSB_NEW_SUPPORT) += drivers/usb/musb-new/libusb_musb-new.o -LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/usb/gadget/libusb_gadget.o -LIBS-$(CONFIG_SPL_WATCHDOG_SUPPORT) += drivers/watchdog/libwatchdog.o +LIBS-$(CONFIG_SPL_FRAMEWORK) += common/spl/ +LIBS-$(CONFIG_SPL_LIBCOMMON_SUPPORT) += common/ +LIBS-$(CONFIG_SPL_LIBDISK_SUPPORT) += disk/ +LIBS-$(CONFIG_SPL_I2C_SUPPORT) += drivers/i2c/ +LIBS-$(CONFIG_SPL_GPIO_SUPPORT) += drivers/gpio/ +LIBS-$(CONFIG_SPL_MMC_SUPPORT) += drivers/mmc/ +LIBS-$(CONFIG_SPL_SERIAL_SUPPORT) += drivers/serial/ +LIBS-$(CONFIG_SPL_SPI_FLASH_SUPPORT) += drivers/mtd/spi/ +LIBS-$(CONFIG_SPL_SPI_SUPPORT) += drivers/spi/ +LIBS-y += fs/ +LIBS-$(CONFIG_SPL_LIBGENERIC_SUPPORT) += lib/ +LIBS-$(CONFIG_SPL_POWER_SUPPORT) += drivers/power/ \ +	drivers/power/pmic/ +LIBS-$(CONFIG_SPL_NAND_SUPPORT) += drivers/mtd/nand/ +LIBS-$(CONFIG_SPL_ONENAND_SUPPORT) += drivers/mtd/onenand/ +LIBS-$(CONFIG_SPL_DMA_SUPPORT) += drivers/dma/ +LIBS-$(CONFIG_SPL_POST_MEM_SUPPORT) += post/drivers/ +LIBS-$(CONFIG_SPL_NET_SUPPORT) += net/ +LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/ +LIBS-$(CONFIG_SPL_ETH_SUPPORT) += drivers/net/phy/ +LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/net/phy/ +LIBS-$(CONFIG_SPL_MUSB_NEW_SUPPORT) += drivers/usb/musb-new/ +LIBS-$(CONFIG_SPL_USBETH_SUPPORT) += drivers/usb/gadget/ +LIBS-$(CONFIG_SPL_WATCHDOG_SUPPORT) += drivers/watchdog/  ifneq (,$(CONFIG_MX23)$(filter $(SOC), mx25 mx27 mx5 mx6 mx31 mx35)) -LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o +LIBS-y += arch/$(ARCH)/imx-common/  endif -LIBS-$(CONFIG_ARM) += arch/arm/cpu/libcpu.o +LIBS-$(CONFIG_ARM) += arch/arm/cpu/ +LIBS-$(CONFIG_PPC) += arch/powerpc/cpu/  ifneq ($(CONFIG_MX23)$(CONFIG_MX35),) -LIBS-y += arch/$(ARCH)/imx-common/libimx-common.o +LIBS-y += arch/$(ARCH)/imx-common/  endif +LIBS-y := $(patsubst %/, %/built-in.o, $(LIBS-y)) +  # Add GCC lib  ifeq ("$(USE_PRIVATE_LIBGCC)", "yes")  PLATFORM_LIBGCC = $(SPLTREE)/arch/$(ARCH)/lib/libgcc.o @@ -175,8 +166,7 @@ all:	$(ALL-y)  ifdef CONFIG_SAMSUNG  $(obj)$(BOARD)-spl.bin: $(obj)u-boot-spl.bin -	$(OBJTREE)/tools/mk$(BOARD)spl \ -		$(obj)u-boot-spl.bin $(obj)$(BOARD)-spl.bin +	$(OBJTREE)/tools/mk$(BOARD)spl $< $@  endif  $(obj)$(SPL_BIN).bin:	$(obj)$(SPL_BIN) @@ -195,7 +185,6 @@ $(START):  $(LIBS):	depend  	$(MAKE) $(build) $(SRCTREE)$(dir $(subst $(SPLTREE),,$@)) -	mv $(dir $@)built-in.o $@  $(obj)u-boot-spl.lds: $(LDSCRIPT) depend  	$(CPP) $(CPPFLAGS) $(LDPPFLAGS) -I$(obj). -ansi -D__ASSEMBLY__ -P - < $< > $@ diff --git a/tools/gdb/Makefile b/tools/gdb/Makefile index dee91fccc..dd98fb65c 100644 --- a/tools/gdb/Makefile +++ b/tools/gdb/Makefile @@ -23,8 +23,6 @@ BINS	:= $(addprefix $(obj),$(BINS))  #  HOSTCPPFLAGS = -I$(BFD_ROOT_DIR)/include -HOSTOS := $(shell uname -s | sed -e 's/\([Cc][Yy][Gg][Ww][Ii][Nn]\).*/cygwin/') -  ifeq ($(HOSTOS),cygwin)  all: |