diff options
Diffstat (limited to 'arch')
94 files changed, 2600 insertions, 466 deletions
| diff --git a/arch/Kconfig b/arch/Kconfig index bf2676469c7..f63cc5a7e94 100644 --- a/arch/Kconfig +++ b/arch/Kconfig @@ -7,6 +7,7 @@ config ARC  config ARM  	bool "ARM architecture" +	select HAVE_PRIVATE_LIBGCC  	select SUPPORT_OF_CONTROL  config AVR32 @@ -24,6 +25,7 @@ config MICROBLAZE  config MIPS  	bool "MIPS architecture" +	select HAVE_PRIVATE_LIBGCC  config NDS32  	bool "NDS32 architecture" @@ -36,6 +38,7 @@ config OPENRISC  config PPC  	bool "PowerPC architecture" +	select HAVE_PRIVATE_LIBGCC  config SANDBOX  	bool "Sandbox" @@ -43,12 +46,14 @@ config SANDBOX  config SH  	bool "SuperH architecture" +	select HAVE_PRIVATE_LIBGCC  config SPARC  	bool "SPARC architecture"  config X86  	bool "x86 architecture" +	select HAVE_PRIVATE_LIBGCC  	select SUPPORT_OF_CONTROL  endchoice diff --git a/arch/arm/Kconfig b/arch/arm/Kconfig index 72558b85620..8f910f39a37 100644 --- a/arch/arm/Kconfig +++ b/arch/arm/Kconfig @@ -141,6 +141,12 @@ config ARCH_DAVINCI  config KIRKWOOD  	bool "Marvell Kirkwood" +config TARGET_DB_MV784MP_GP +	bool "Support db-mv784mp-gp" + +config TARGET_MAXBCM +	bool "Support maxbcm" +  config TARGET_DEVKIT3250  	bool "Support devkit3250" @@ -444,9 +450,15 @@ config TARGET_SUN4I  config TARGET_SUN5I  	bool "Support sun5i" +config TARGET_SUN6I +	bool "Support sun6i" +  config TARGET_SUN7I  	bool "Support sun7i" +config TARGET_SUN8I +	bool "Support sun8i" +  config TARGET_SNOWBALL  	bool "Support snowball" @@ -567,6 +579,7 @@ source "board/BuS/eb_cpux9k2/Kconfig"  source "board/BuS/vl_ma2sc/Kconfig"  source "board/CarMediaLab/flea3/Kconfig"  source "board/Marvell/aspenite/Kconfig" +source "board/Marvell/db-mv784mp-gp/Kconfig"  source "board/Marvell/dkb/Kconfig"  source "board/Marvell/gplugd/Kconfig"  source "board/afeb9260/Kconfig" @@ -648,6 +661,7 @@ source "board/jornada/Kconfig"  source "board/karo/tx25/Kconfig"  source "board/logicpd/imx27lite/Kconfig"  source "board/logicpd/imx31_litekit/Kconfig" +source "board/maxbcm/Kconfig"  source "board/mpl/vcma9/Kconfig"  source "board/olimex/mx23_olinuxino/Kconfig"  source "board/palmld/Kconfig" diff --git a/arch/arm/cpu/arm926ejs/at91/led.c b/arch/arm/cpu/arm926ejs/at91/led.c index 46ed0550239..b8d5c785df4 100644 --- a/arch/arm/cpu/arm926ejs/at91/led.c +++ b/arch/arm/cpu/arm926ejs/at91/led.c @@ -9,6 +9,7 @@  #include <common.h>  #include <asm/gpio.h>  #include <asm/arch/gpio.h> +#include <status_led.h>  #ifdef CONFIG_RED_LED  void red_led_on(void) diff --git a/arch/arm/cpu/arm926ejs/kirkwood/Makefile b/arch/arm/cpu/arm926ejs/kirkwood/Makefile index c230ce8994e..df4756e4bdb 100644 --- a/arch/arm/cpu/arm926ejs/kirkwood/Makefile +++ b/arch/arm/cpu/arm926ejs/kirkwood/Makefile @@ -7,7 +7,5 @@  #  obj-y	= cpu.o -obj-y	+= dram.o -obj-y	+= mpp.o -obj-y	+= timer.o  obj-y	+= cache.o +obj-y	+= mpp.o diff --git a/arch/arm/cpu/arm926ejs/kirkwood/cpu.c b/arch/arm/cpu/arm926ejs/kirkwood/cpu.c index 881e2de81b3..9e412bbb04d 100644 --- a/arch/arm/cpu/arm926ejs/kirkwood/cpu.c +++ b/arch/arm/cpu/arm926ejs/kirkwood/cpu.c @@ -9,14 +9,11 @@  #include <common.h>  #include <netdev.h>  #include <asm/cache.h> -#include <u-boot/md5.h>  #include <asm/io.h>  #include <asm/arch/cpu.h> -#include <asm/arch/kirkwood.h> +#include <asm/arch/soc.h>  #include <mvebu_mmc.h> -#define BUFLEN	16 -  void reset_cpu(unsigned long ignored)  {  	struct kwcpu_registers *cpureg = @@ -30,31 +27,6 @@ void reset_cpu(unsigned long ignored)  }  /* - * Generates Ramdom hex number reading some time varient system registers - * and using md5 algorithm - */ -unsigned char get_random_hex(void) -{ -	int i; -	u32 inbuf[BUFLEN]; -	u8 outbuf[BUFLEN]; - -	/* -	 * in case of 88F6281/88F6282/88F6192 A0, -	 * Bit7 need to reset to generate random values in KW_REG_UNDOC_0x1470 -	 * Soc reg offsets KW_REG_UNDOC_0x1470 and KW_REG_UNDOC_0x1478 are -	 * reserved regs and does not have names at this moment -	 * (no errata available) -	 */ -	writel(readl(KW_REG_UNDOC_0x1478) & ~(1 << 7), KW_REG_UNDOC_0x1478); -	for (i = 0; i < BUFLEN; i++) { -		inbuf[i] = readl(KW_REG_UNDOC_0x1470); -	} -	md5((u8 *) inbuf, (BUFLEN * sizeof(u32)), outbuf); -	return outbuf[outbuf[7] % 0x0f]; -} - -/*   * Window Size   * Used with the Base register to set the address window size and location.   * Must be programmed from LSB to MSB as sequence of ones followed by @@ -140,50 +112,6 @@ int kw_config_adr_windows(void)  }  /* - * kw_config_gpio - GPIO configuration - */ -void kw_config_gpio(u32 gpp0_oe_val, u32 gpp1_oe_val, u32 gpp0_oe, u32 gpp1_oe) -{ -	struct kwgpio_registers *gpio0reg = -		(struct kwgpio_registers *)KW_GPIO0_BASE; -	struct kwgpio_registers *gpio1reg = -		(struct kwgpio_registers *)KW_GPIO1_BASE; - -	/* Init GPIOS to default values as per board requirement */ -	writel(gpp0_oe_val, &gpio0reg->dout); -	writel(gpp1_oe_val, &gpio1reg->dout); -	writel(gpp0_oe, &gpio0reg->oe); -	writel(gpp1_oe, &gpio1reg->oe); -} - -/* - * kw_config_mpp - Multi-Purpose Pins Functionality configuration - * - * Each MPP can be configured to different functionality through - * MPP control register, ref (sec 6.1 of kirkwood h/w specification) - * - * There are maximum 64 Multi-Pourpose Pins on Kirkwood - * Each MPP functionality can be configuration by a 4bit value - * of MPP control reg, the value and associated functionality depends - * upon used SoC varient - */ -int kw_config_mpp(u32 mpp0_7, u32 mpp8_15, u32 mpp16_23, u32 mpp24_31, -		u32 mpp32_39, u32 mpp40_47, u32 mpp48_55) -{ -	u32 *mppreg = (u32 *) KW_MPP_BASE; - -	/* program mpp registers */ -	writel(mpp0_7, &mppreg[0]); -	writel(mpp8_15, &mppreg[1]); -	writel(mpp16_23, &mppreg[2]); -	writel(mpp24_31, &mppreg[3]); -	writel(mpp32_39, &mppreg[4]); -	writel(mpp40_47, &mppreg[5]); -	writel(mpp48_55, &mppreg[6]); -	return 0; -} - -/*   * SYSRSTn Duration Counter Support   *   * Kirkwood SoC implements a hardware-based SYSRSTn duration counter. diff --git a/arch/arm/cpu/arm926ejs/kirkwood/mpp.c b/arch/arm/cpu/arm926ejs/kirkwood/mpp.c index 0ba6f098cb6..7222504ed3a 100644 --- a/arch/arm/cpu/arm926ejs/kirkwood/mpp.c +++ b/arch/arm/cpu/arm926ejs/kirkwood/mpp.c @@ -12,7 +12,7 @@  #include <common.h>  #include <asm/io.h>  #include <asm/arch/cpu.h> -#include <asm/arch/kirkwood.h> +#include <asm/arch/soc.h>  #include <asm/arch/mpp.h>  static u32 kirkwood_variant(void) diff --git a/arch/arm/cpu/armv7/am33xx/board.c b/arch/arm/cpu/armv7/am33xx/board.c index 828d10bb5a4..29b1d734382 100644 --- a/arch/arm/cpu/armv7/am33xx/board.c +++ b/arch/arm/cpu/armv7/am33xx/board.c @@ -9,7 +9,9 @@   */  #include <common.h> +#include <dm.h>  #include <errno.h> +#include <ns16550.h>  #include <spl.h>  #include <asm/arch/cpu.h>  #include <asm/arch/hardware.h> @@ -36,6 +38,63 @@  DECLARE_GLOBAL_DATA_PTR; +#ifdef CONFIG_DM_GPIO +static const struct omap_gpio_platdata am33xx_gpio[] = { +	{ 0, AM33XX_GPIO0_BASE, METHOD_GPIO_24XX }, +	{ 1, AM33XX_GPIO1_BASE, METHOD_GPIO_24XX }, +	{ 2, AM33XX_GPIO2_BASE, METHOD_GPIO_24XX }, +	{ 3, AM33XX_GPIO3_BASE, METHOD_GPIO_24XX }, +#ifdef CONFIG_AM43XX +	{ 4, AM33XX_GPIO4_BASE, METHOD_GPIO_24XX }, +	{ 5, AM33XX_GPIO5_BASE, METHOD_GPIO_24XX }, +#endif +}; + +U_BOOT_DEVICES(am33xx_gpios) = { +	{ "gpio_omap", &am33xx_gpio[0] }, +	{ "gpio_omap", &am33xx_gpio[1] }, +	{ "gpio_omap", &am33xx_gpio[2] }, +	{ "gpio_omap", &am33xx_gpio[3] }, +#ifdef CONFIG_AM43XX +	{ "gpio_omap", &am33xx_gpio[4] }, +	{ "gpio_omap", &am33xx_gpio[5] }, +#endif +}; + +# ifndef CONFIG_OF_CONTROL +/* + * TODO(sjg@chromium.org): When we can move SPL serial to DM, we can remove + * the CONFIGs. At the same time, we should move this to the board files. + */ +static const struct ns16550_platdata am33xx_serial[] = { +	{ CONFIG_SYS_NS16550_COM1, 2, CONFIG_SYS_NS16550_CLK }, +#  ifdef CONFIG_SYS_NS16550_COM2 +	{ CONFIG_SYS_NS16550_COM2, 2, CONFIG_SYS_NS16550_CLK }, +#   ifdef CONFIG_SYS_NS16550_COM3 +	{ CONFIG_SYS_NS16550_COM3, 2, CONFIG_SYS_NS16550_CLK }, +	{ CONFIG_SYS_NS16550_COM4, 2, CONFIG_SYS_NS16550_CLK }, +	{ CONFIG_SYS_NS16550_COM5, 2, CONFIG_SYS_NS16550_CLK }, +	{ CONFIG_SYS_NS16550_COM6, 2, CONFIG_SYS_NS16550_CLK }, +#   endif +#  endif +}; + +U_BOOT_DEVICES(am33xx_uarts) = { +	{ "serial_omap", &am33xx_serial[0] }, +#  ifdef CONFIG_SYS_NS16550_COM2 +	{ "serial_omap", &am33xx_serial[1] }, +#   ifdef CONFIG_SYS_NS16550_COM3 +	{ "serial_omap", &am33xx_serial[2] }, +	{ "serial_omap", &am33xx_serial[3] }, +	{ "serial_omap", &am33xx_serial[4] }, +	{ "serial_omap", &am33xx_serial[5] }, +#   endif +#  endif +}; +# endif + +#else +  static const struct gpio_bank gpio_bank_am33xx[] = {  	{ (void *)AM33XX_GPIO0_BASE, METHOD_GPIO_24XX },  	{ (void *)AM33XX_GPIO1_BASE, METHOD_GPIO_24XX }, @@ -49,6 +108,8 @@ static const struct gpio_bank gpio_bank_am33xx[] = {  const struct gpio_bank *const omap_gpio_bank = gpio_bank_am33xx; +#endif +  #if defined(CONFIG_OMAP_HSMMC) && !defined(CONFIG_SPL_BUILD)  int cpu_mmc_init(bd_t *bis)  { diff --git a/arch/arm/cpu/armv7/armada-xp/Makefile b/arch/arm/cpu/armv7/armada-xp/Makefile new file mode 100644 index 00000000000..885dcee2e19 --- /dev/null +++ b/arch/arm/cpu/armv7/armada-xp/Makefile @@ -0,0 +1,7 @@ +# +# Copyright (C) 2014 Stefan Roese <sr@denx.de> +# +# SPDX-License-Identifier:	GPL-2.0+ +# + +obj-y	= cpu.o diff --git a/arch/arm/cpu/armv7/armada-xp/cpu.c b/arch/arm/cpu/armv7/armada-xp/cpu.c new file mode 100644 index 00000000000..1cf70a9f5d5 --- /dev/null +++ b/arch/arm/cpu/armv7/armada-xp/cpu.c @@ -0,0 +1,193 @@ +/* + * Copyright (C) 2014 Stefan Roese <sr@denx.de> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <netdev.h> +#include <asm/io.h> +#include <asm/arch/cpu.h> +#include <asm/arch/soc.h> + +#define DDR_BASE_CS_OFF(n)	(0x0000 + ((n) << 3)) +#define DDR_SIZE_CS_OFF(n)	(0x0004 + ((n) << 3)) + +static struct mbus_win windows[] = { +	/* PCIE MEM address space */ +	{ DEFADR_PCI_MEM, 256 << 20, CPU_TARGET_PCIE13, CPU_ATTR_PCIE_MEM }, + +	/* PCIE IO address space */ +	{ DEFADR_PCI_IO, 64 << 10, CPU_TARGET_PCIE13, CPU_ATTR_PCIE_IO }, + +	/* SPI */ +	{ DEFADR_SPIF, 8 << 20, CPU_TARGET_DEVICEBUS_BOOTROM_SPI, +	  CPU_ATTR_SPIFLASH }, + +	/* NOR */ +	{ DEFADR_BOOTROM, 8 << 20, CPU_TARGET_DEVICEBUS_BOOTROM_SPI, +	  CPU_ATTR_BOOTROM }, +}; + +void reset_cpu(unsigned long ignored) +{ +	struct mvebu_system_registers *reg = +		(struct mvebu_system_registers *)MVEBU_SYSTEM_REG_BASE; + +	writel(readl(®->rstoutn_mask) | 1, ®->rstoutn_mask); +	writel(readl(®->sys_soft_rst) | 1, ®->sys_soft_rst); +	while (1) +		; +} + +#if defined(CONFIG_DISPLAY_CPUINFO) +int print_cpuinfo(void) +{ +	u16 devid = (readl(MVEBU_REG_PCIE_DEVID) >> 16) & 0xffff; +	u8 revid = readl(MVEBU_REG_PCIE_REVID) & 0xff; + +	puts("SoC:   "); + +	switch (devid) { +	case SOC_MV78460_ID: +		puts("MV78460-"); +		break; +	default: +		puts("Unknown-"); +		break; +	} + +	switch (revid) { +	case 1: +		puts("A0\n"); +		break; +	case 2: +		puts("B0\n"); +		break; +	default: +		puts("??\n"); +		break; +	} + +	return 0; +} +#endif /* CONFIG_DISPLAY_CPUINFO */ + +/* + * This function initialize Controller DRAM Fastpath windows. + * It takes the CS size information from the 0x1500 scratch registers + * and sets the correct windows sizes and base addresses accordingly. + * + * These values are set in the scratch registers by the Marvell + * DDR3 training code, which is executed by the BootROM before the + * main payload (U-Boot) is executed. This training code is currently + * only available in the Marvell U-Boot version. It needs to be + * ported to mainline U-Boot SPL at some point. + */ +static void update_sdram_window_sizes(void) +{ +	u64 base = 0; +	u32 size, temp; +	int i; + +	for (i = 0; i < SDRAM_MAX_CS; i++) { +		size = readl((MVEBU_SDRAM_SCRATCH + (i * 8))) & SDRAM_ADDR_MASK; +		if (size != 0) { +			size |= ~(SDRAM_ADDR_MASK); + +			/* Set Base Address */ +			temp = (base & 0xFF000000ll) | ((base >> 32) & 0xF); +			writel(temp, MVEBU_SDRAM_BASE + DDR_BASE_CS_OFF(i)); + +			/* +			 * Check if out of max window size and resize +			 * the window +			 */ +			temp = (readl(MVEBU_SDRAM_BASE + DDR_SIZE_CS_OFF(i)) & +				~(SDRAM_ADDR_MASK)) | 1; +			temp |= (size & SDRAM_ADDR_MASK); +			writel(temp, MVEBU_SDRAM_BASE + DDR_SIZE_CS_OFF(i)); + +			base += ((u64)size + 1); +		} else { +			/* +			 * Disable window if not used, otherwise this +			 * leads to overlapping enabled windows with +			 * pretty strange results +			 */ +			clrbits_le32(MVEBU_SDRAM_BASE + DDR_SIZE_CS_OFF(i), 1); +		} +	} +} + +#ifdef CONFIG_ARCH_CPU_INIT +int arch_cpu_init(void) +{ +	/* Linux expects the internal registers to be at 0xf1000000 */ +	writel(SOC_REGS_PHY_BASE, INTREG_BASE_ADDR_REG); + +	/* +	 * We need to call mvebu_mbus_probe() before calling +	 * update_sdram_window_sizes() as it disables all previously +	 * configured mbus windows and then configures them as +	 * required for U-Boot. Calling update_sdram_window_sizes() +	 * without this configuration will not work, as the internal +	 * registers can't be accessed reliably because of potenial +	 * double mapping. +	 * After updating the SDRAM access windows we need to call +	 * mvebu_mbus_probe() again, as this now correctly configures +	 * the SDRAM areas that are later used by the MVEBU drivers +	 * (e.g. USB, NETA). +	 */ + +	/* +	 * First disable all windows +	 */ +	mvebu_mbus_probe(NULL, 0); + +	/* +	 * Now the SDRAM access windows can be reconfigured using +	 * the information in the SDRAM scratch pad registers +	 */ +	update_sdram_window_sizes(); + +	/* +	 * Finally the mbus windows can be configured with the +	 * updated SDRAM sizes +	 */ +	mvebu_mbus_probe(windows, ARRAY_SIZE(windows)); + +	return 0; +} +#endif /* CONFIG_ARCH_CPU_INIT */ + +/* + * SOC specific misc init + */ +#if defined(CONFIG_ARCH_MISC_INIT) +int arch_misc_init(void) +{ +	/* Nothing yet, perhaps we need something here later */ +	return 0; +} +#endif /* CONFIG_ARCH_MISC_INIT */ + +#ifdef CONFIG_MVNETA +int cpu_eth_init(bd_t *bis) +{ +	mvneta_initialize(bis, MVEBU_EGIGA0_BASE, 0, CONFIG_PHY_BASE_ADDR + 0); +	mvneta_initialize(bis, MVEBU_EGIGA1_BASE, 1, CONFIG_PHY_BASE_ADDR + 1); +	mvneta_initialize(bis, MVEBU_EGIGA2_BASE, 2, CONFIG_PHY_BASE_ADDR + 2); +	mvneta_initialize(bis, MVEBU_EGIGA3_BASE, 3, CONFIG_PHY_BASE_ADDR + 3); + +	return 0; +} +#endif + +#ifndef CONFIG_SYS_DCACHE_OFF +void enable_caches(void) +{ +	/* Enable D-cache. I-cache is already enabled in start.S */ +	dcache_enable(); +} +#endif diff --git a/arch/arm/cpu/armv7/mx6/soc.c b/arch/arm/cpu/armv7/mx6/soc.c index 63524222539..a202b0318e0 100644 --- a/arch/arm/cpu/armv7/mx6/soc.c +++ b/arch/arm/cpu/armv7/mx6/soc.c @@ -9,6 +9,7 @@  #include <common.h>  #include <asm/armv7.h> +#include <asm/bootm.h>  #include <asm/pl310.h>  #include <asm/errno.h>  #include <asm/io.h> diff --git a/arch/arm/cpu/armv7/omap3/board.c b/arch/arm/cpu/armv7/omap3/board.c index 667e77ff05b..c942fe67eeb 100644 --- a/arch/arm/cpu/armv7/omap3/board.c +++ b/arch/arm/cpu/armv7/omap3/board.c @@ -17,13 +17,15 @@   * SPDX-License-Identifier:	GPL-2.0+   */  #include <common.h> +#include <dm.h> +#include <mmc.h>  #include <spl.h>  #include <asm/io.h>  #include <asm/arch/sys_proto.h>  #include <asm/arch/mem.h>  #include <asm/cache.h>  #include <asm/armv7.h> -#include <asm/arch/gpio.h> +#include <asm/gpio.h>  #include <asm/omap_common.h>  #include <asm/arch/mmc_host_def.h>  #include <i2c.h> @@ -38,6 +40,27 @@ static void omap3_setup_aux_cr(void);  static void omap3_invalidate_l2_cache_secure(void);  #endif +#ifdef CONFIG_DM_GPIO +static const struct omap_gpio_platdata omap34xx_gpio[] = { +	{ 0, OMAP34XX_GPIO1_BASE, METHOD_GPIO_24XX }, +	{ 1, OMAP34XX_GPIO2_BASE, METHOD_GPIO_24XX }, +	{ 2, OMAP34XX_GPIO3_BASE, METHOD_GPIO_24XX }, +	{ 3, OMAP34XX_GPIO4_BASE, METHOD_GPIO_24XX }, +	{ 4, OMAP34XX_GPIO5_BASE, METHOD_GPIO_24XX }, +	{ 5, OMAP34XX_GPIO6_BASE, METHOD_GPIO_24XX }, +}; + +U_BOOT_DEVICES(am33xx_gpios) = { +	{ "gpio_omap", &omap34xx_gpio[0] }, +	{ "gpio_omap", &omap34xx_gpio[1] }, +	{ "gpio_omap", &omap34xx_gpio[2] }, +	{ "gpio_omap", &omap34xx_gpio[3] }, +	{ "gpio_omap", &omap34xx_gpio[4] }, +	{ "gpio_omap", &omap34xx_gpio[5] }, +}; + +#else +  static const struct gpio_bank gpio_bank_34xx[6] = {  	{ (void *)OMAP34XX_GPIO1_BASE, METHOD_GPIO_24XX },  	{ (void *)OMAP34XX_GPIO2_BASE, METHOD_GPIO_24XX }, @@ -49,6 +72,8 @@ static const struct gpio_bank gpio_bank_34xx[6] = {  const struct gpio_bank *const omap_gpio_bank = gpio_bank_34xx; +#endif +  #ifdef CONFIG_SPL_BUILD  /*  * We use static variables because global data is not ready yet. @@ -266,7 +291,7 @@ int __weak misc_init_r(void)   * Routine: wait_for_command_complete   * Description: Wait for posting to finish on watchdog   *****************************************************************************/ -void wait_for_command_complete(struct watchdog *wd_base) +static void wait_for_command_complete(struct watchdog *wd_base)  {  	int pending = 1;  	do { diff --git a/arch/arm/cpu/armv7/omap3/emif4.c b/arch/arm/cpu/armv7/omap3/emif4.c index 6c7330a0cab..a2aadc98169 100644 --- a/arch/arm/cpu/armv7/omap3/emif4.c +++ b/arch/arm/cpu/armv7/omap3/emif4.c @@ -61,7 +61,7 @@ u32 get_sdr_cs_offset(u32 cs)   *  - Init the emif4 module for DDR access   *  - Early init routines, called from flash or SRAM.   */ -void do_emif4_init(void) +static void do_emif4_init(void)  {  	unsigned int regval;  	/* Set the DDR PHY parameters in PHY ctrl registers */ diff --git a/arch/arm/cpu/armv7/omap3/sys_info.c b/arch/arm/cpu/armv7/omap3/sys_info.c index bef5f05eaa7..bbb65bbe726 100644 --- a/arch/arm/cpu/armv7/omap3/sys_info.c +++ b/arch/arm/cpu/armv7/omap3/sys_info.c @@ -16,6 +16,8 @@  #include <asm/io.h>  #include <asm/arch/mem.h>	/* get mem tables */  #include <asm/arch/sys_proto.h> +#include <asm/bootm.h> +  #include <i2c.h>  #include <linux/compiler.h> @@ -202,7 +204,7 @@ u32 __weak get_board_rev(void)  /********************************************************   *  get_base(); get upper addr of current execution   *******************************************************/ -u32 get_base(void) +static u32 get_base(void)  {  	u32 val; diff --git a/arch/arm/cpu/armv7/socfpga/misc.c b/arch/arm/cpu/armv7/socfpga/misc.c index 0eab264668c..8c3e5f7cd42 100644 --- a/arch/arm/cpu/armv7/socfpga/misc.c +++ b/arch/arm/cpu/armv7/socfpga/misc.c @@ -176,7 +176,7 @@ static void socfpga_nic301_slave_ns(void)  static uint32_t iswgrp_handoff[8]; -int misc_init_r(void) +int arch_early_init_r(void)  {  	int i;  	for (i = 0; i < 8; i++)	/* Cache initial SW setting regs */ diff --git a/arch/arm/cpu/armv7/socfpga/u-boot-spl.lds b/arch/arm/cpu/armv7/socfpga/u-boot-spl.lds index db9bdad7d6c..569fa418f46 100644 --- a/arch/arm/cpu/armv7/socfpga/u-boot-spl.lds +++ b/arch/arm/cpu/armv7/socfpga/u-boot-spl.lds @@ -42,13 +42,4 @@ SECTIONS  		. = ALIGN(4);  		__bss_end = .;  	} >.sdram - -	. = ALIGN(8); -	__malloc_start = .; -	. = . + CONFIG_SPL_MALLOC_SIZE; -	__malloc_end = .; - -	. = . + CONFIG_SPL_STACK_SIZE; -	. = ALIGN(8); -	__stack_start = .;  } diff --git a/arch/arm/cpu/armv7/sunxi/Makefile b/arch/arm/cpu/armv7/sunxi/Makefile index e9721b27b64..24f1daee647 100644 --- a/arch/arm/cpu/armv7/sunxi/Makefile +++ b/arch/arm/cpu/armv7/sunxi/Makefile @@ -11,9 +11,13 @@ obj-y	+= timer.o  obj-y	+= board.o  obj-y	+= clock.o  obj-y	+= pinmux.o +obj-$(CONFIG_SUN6I)	+= prcm.o +obj-$(CONFIG_SUN8I)	+= prcm.o  obj-$(CONFIG_SUN4I)	+= clock_sun4i.o  obj-$(CONFIG_SUN5I)	+= clock_sun4i.o +obj-$(CONFIG_SUN6I)	+= clock_sun6i.o  obj-$(CONFIG_SUN7I)	+= clock_sun4i.o +obj-$(CONFIG_SUN8I)	+= clock_sun6i.o  ifndef CONFIG_SPL_BUILD  obj-y	+= cpu_info.o diff --git a/arch/arm/cpu/armv7/sunxi/board.c b/arch/arm/cpu/armv7/sunxi/board.c index f2cedbb1568..06eb6768e8f 100644 --- a/arch/arm/cpu/armv7/sunxi/board.c +++ b/arch/arm/cpu/armv7/sunxi/board.c @@ -50,18 +50,35 @@ u32 spl_boot_mode(void)  int gpio_init(void)  { -#if CONFIG_CONS_INDEX == 1 && (defined(CONFIG_SUN4I) || defined(CONFIG_SUN7I)) +#if CONFIG_CONS_INDEX == 1 && defined(CONFIG_UART0_PORT_F) +#if defined(CONFIG_SUN4I) || defined(CONFIG_SUN7I) +	/* disable GPB22,23 as uart0 tx,rx to avoid conflict */ +	sunxi_gpio_set_cfgpin(SUNXI_GPB(22), SUNXI_GPIO_INPUT); +	sunxi_gpio_set_cfgpin(SUNXI_GPB(23), SUNXI_GPIO_INPUT); +#endif +	sunxi_gpio_set_cfgpin(SUNXI_GPF(2), SUNXI_GPF2_UART0_TX); +	sunxi_gpio_set_cfgpin(SUNXI_GPF(4), SUNXI_GPF4_UART0_RX); +	sunxi_gpio_set_pull(SUNXI_GPF(4), 1); +#elif CONFIG_CONS_INDEX == 1 && (defined(CONFIG_SUN4I) || defined(CONFIG_SUN7I))  	sunxi_gpio_set_cfgpin(SUNXI_GPB(22), SUN4I_GPB22_UART0_TX);  	sunxi_gpio_set_cfgpin(SUNXI_GPB(23), SUN4I_GPB23_UART0_RX); -	sunxi_gpio_set_pull(SUNXI_GPB(23), 1); +	sunxi_gpio_set_pull(SUNXI_GPB(23), SUNXI_GPIO_PULL_UP);  #elif CONFIG_CONS_INDEX == 1 && defined(CONFIG_SUN5I)  	sunxi_gpio_set_cfgpin(SUNXI_GPB(19), SUN5I_GPB19_UART0_TX);  	sunxi_gpio_set_cfgpin(SUNXI_GPB(20), SUN5I_GPB20_UART0_RX); -	sunxi_gpio_set_pull(SUNXI_GPB(20), 1); +	sunxi_gpio_set_pull(SUNXI_GPB(20), SUNXI_GPIO_PULL_UP); +#elif CONFIG_CONS_INDEX == 1 && defined(CONFIG_SUN6I) +	sunxi_gpio_set_cfgpin(SUNXI_GPH(20), SUN6I_GPH20_UART0_TX); +	sunxi_gpio_set_cfgpin(SUNXI_GPH(21), SUN6I_GPH21_UART0_RX); +	sunxi_gpio_set_pull(SUNXI_GPH(21), SUNXI_GPIO_PULL_UP);  #elif CONFIG_CONS_INDEX == 2 && defined(CONFIG_SUN5I)  	sunxi_gpio_set_cfgpin(SUNXI_GPG(3), SUN5I_GPG3_UART1_TX);  	sunxi_gpio_set_cfgpin(SUNXI_GPG(4), SUN5I_GPG4_UART1_RX); -	sunxi_gpio_set_pull(SUNXI_GPG(4), 1); +	sunxi_gpio_set_pull(SUNXI_GPG(4), SUNXI_GPIO_PULL_UP); +#elif CONFIG_CONS_INDEX == 5 && defined(CONFIG_SUN8I) +	sunxi_gpio_set_cfgpin(SUNXI_GPL(2), SUN8I_GPL2_R_UART_TX); +	sunxi_gpio_set_cfgpin(SUNXI_GPL(3), SUN8I_GPL3_R_UART_RX); +	sunxi_gpio_set_pull(SUNXI_GPL(3), SUNXI_GPIO_PULL_UP);  #else  #error Unsupported console port number. Please fix pin mux settings in board.c  #endif @@ -71,6 +88,7 @@ int gpio_init(void)  void reset_cpu(ulong addr)  { +#if defined(CONFIG_SUN4I) || defined(CONFIG_SUN5I) || defined(CONFIG_SUN7I)  	static const struct sunxi_wdog *wdog =  		 &((struct sunxi_timer_reg *)SUNXI_TIMER_BASE)->wdog; @@ -82,12 +100,22 @@ void reset_cpu(ulong addr)  		/* sun5i sometimes gets stuck without this */  		writel(WDT_MODE_RESET_EN | WDT_MODE_EN, &wdog->mode);  	} +#else /* CONFIG_SUN6I || CONFIG_SUN8I || .. */ +	static const struct sunxi_wdog *wdog = +		 ((struct sunxi_timer_reg *)SUNXI_TIMER_BASE)->wdog; + +	/* Set the watchdog for its shortest interval (.5s) and wait */ +	writel(WDT_CFG_RESET, &wdog->cfg); +	writel(WDT_MODE_EN, &wdog->mode); +	writel(WDT_CTRL_KEY | WDT_CTRL_RESTART, &wdog->ctl); +#endif  }  /* do some early init */  void s_init(void)  { -#if !defined CONFIG_SPL_BUILD && (defined CONFIG_SUN7I || defined CONFIG_SUN6I) +#if !defined CONFIG_SPL_BUILD && (defined CONFIG_SUN7I || \ +		defined CONFIG_SUN6I || defined CONFIG_SUN8I)  	/* Enable SMP mode for CPU0, by setting bit 6 of Auxiliary Ctl reg */  	asm volatile(  		"mrc p15, 0, r0, c1, c0, 1\n" diff --git a/arch/arm/cpu/armv7/sunxi/clock_sun4i.c b/arch/arm/cpu/armv7/sunxi/clock_sun4i.c index ecbdb0162b2..4a0d64fb30e 100644 --- a/arch/arm/cpu/armv7/sunxi/clock_sun4i.c +++ b/arch/arm/cpu/armv7/sunxi/clock_sun4i.c @@ -180,6 +180,17 @@ void clock_set_pll1(unsigned int hz)  }  #endif +unsigned int clock_get_pll5p(void) +{ +	struct sunxi_ccm_reg *const ccm = +		(struct sunxi_ccm_reg *)SUNXI_CCM_BASE; +	uint32_t rval = readl(&ccm->pll5_cfg); +	int n = ((rval & CCM_PLL5_CTRL_N_MASK) >> CCM_PLL5_CTRL_N_SHIFT); +	int k = ((rval & CCM_PLL5_CTRL_K_MASK) >> CCM_PLL5_CTRL_K_SHIFT) + 1; +	int p = ((rval & CCM_PLL5_CTRL_P_MASK) >> CCM_PLL5_CTRL_P_SHIFT); +	return (24000000 * n * k) >> p; +} +  unsigned int clock_get_pll6(void)  {  	struct sunxi_ccm_reg *const ccm = diff --git a/arch/arm/cpu/armv7/sunxi/clock_sun6i.c b/arch/arm/cpu/armv7/sunxi/clock_sun6i.c new file mode 100644 index 00000000000..1eae9767d0d --- /dev/null +++ b/arch/arm/cpu/armv7/sunxi/clock_sun6i.c @@ -0,0 +1,76 @@ +/* + * sun6i specific clock code + * + * (C) Copyright 2007-2012 + * Allwinner Technology Co., Ltd. <www.allwinnertech.com> + * Tom Cubie <tangliang@allwinnertech.com> + * + * (C) Copyright 2013 Luke Kenneth Casson Leighton <lkcl@lkcl.net> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/io.h> +#include <asm/arch/clock.h> +#include <asm/arch/prcm.h> +#include <asm/arch/sys_proto.h> + +void clock_init_uart(void) +{ +	struct sunxi_ccm_reg *const ccm = +		(struct sunxi_ccm_reg *)SUNXI_CCM_BASE; + +#if CONFIG_CONS_INDEX < 5 +	/* uart clock source is apb2 */ +	writel(APB2_CLK_SRC_OSC24M| +	       APB2_CLK_RATE_N_1| +	       APB2_CLK_RATE_M(1), +	       &ccm->apb2_div); + +	/* open the clock for uart */ +	setbits_le32(&ccm->apb2_gate, +		     CLK_GATE_OPEN << (APB2_GATE_UART_SHIFT + +				       CONFIG_CONS_INDEX - 1)); + +	/* deassert uart reset */ +	setbits_le32(&ccm->apb2_reset_cfg, +		     1 << (APB2_RESET_UART_SHIFT + +			   CONFIG_CONS_INDEX - 1)); +#else +	/* enable R_PIO and R_UART clocks, and de-assert resets */ +	prcm_apb0_enable(PRCM_APB0_GATE_PIO | PRCM_APB0_GATE_UART); +#endif + +	/* Dup with clock_init_safe(), drop once sun6i SPL support lands */ +	writel(PLL6_CFG_DEFAULT, &ccm->pll6_cfg); +} + +int clock_twi_onoff(int port, int state) +{ +	struct sunxi_ccm_reg *const ccm = +		(struct sunxi_ccm_reg *)SUNXI_CCM_BASE; + +	if (port > 3) +		return -1; + +	/* set the apb clock gate for twi */ +	if (state) +		setbits_le32(&ccm->apb2_gate, +			     CLK_GATE_OPEN << (APB2_GATE_TWI_SHIFT+port)); +	else +		clrbits_le32(&ccm->apb2_gate, +			     CLK_GATE_OPEN << (APB2_GATE_TWI_SHIFT+port)); + +	return 0; +} + +unsigned int clock_get_pll6(void) +{ +	struct sunxi_ccm_reg *const ccm = +		(struct sunxi_ccm_reg *)SUNXI_CCM_BASE; +	uint32_t rval = readl(&ccm->pll6_cfg); +	int n = ((rval & CCM_PLL6_CTRL_N_MASK) >> CCM_PLL6_CTRL_N_SHIFT) + 1; +	int k = ((rval & CCM_PLL6_CTRL_K_MASK) >> CCM_PLL6_CTRL_K_SHIFT) + 1; +	return 24000000 * n * k / 2; +} diff --git a/arch/arm/cpu/armv7/sunxi/cpu_info.c b/arch/arm/cpu/armv7/sunxi/cpu_info.c index 5cf35acc1e6..4f2a09cd2e2 100644 --- a/arch/arm/cpu/armv7/sunxi/cpu_info.c +++ b/arch/arm/cpu/armv7/sunxi/cpu_info.c @@ -23,8 +23,12 @@ int print_cpuinfo(void)  	case 7: puts("CPU:   Allwinner A10s (SUN5I)\n"); break;  	default: puts("CPU:   Allwinner A1X (SUN5I)\n");  	} +#elif defined CONFIG_SUN6I +	puts("CPU:   Allwinner A31 (SUN6I)\n");  #elif defined CONFIG_SUN7I  	puts("CPU:   Allwinner A20 (SUN7I)\n"); +#elif defined CONFIG_SUN8I +	puts("CPU:   Allwinner A23 (SUN8I)\n");  #else  #warning Please update cpu_info.c with correct CPU information  	puts("CPU:   SUNXI Family\n"); diff --git a/arch/arm/cpu/armv7/sunxi/dram.c b/arch/arm/cpu/armv7/sunxi/dram.c index 584f7420d7d..3cf3cbf19ad 100644 --- a/arch/arm/cpu/armv7/sunxi/dram.c +++ b/arch/arm/cpu/armv7/sunxi/dram.c @@ -252,15 +252,9 @@ static void mctl_setup_dram_clock(u32 clk, u32 mbus_clk)  {  	u32 reg_val;  	struct sunxi_ccm_reg *ccm = (struct sunxi_ccm_reg *)SUNXI_CCM_BASE; - -	/* PLL5P and PLL6 are the potential clock sources for MBUS */ -	u32 pll6x_div, pll5p_div; -	u32 pll6x_clk = clock_get_pll6() / 1000000; -	u32 pll5p_clk = clk / 24 * 48; +	u32 pll5p_clk, pll6x_clk; +	u32 pll5p_div, pll6x_div;  	u32 pll5p_rate, pll6x_rate; -#ifdef CONFIG_SUN7I -	pll6x_clk *= 2; /* sun7i uses PLL6*2, sun5i uses just PLL6 */ -#endif  	/* setup DRAM PLL */  	reg_val = readl(&ccm->pll5_cfg); @@ -268,33 +262,32 @@ static void mctl_setup_dram_clock(u32 clk, u32 mbus_clk)  	reg_val &= ~CCM_PLL5_CTRL_K_MASK;		/* set K to 0 (x1) */  	reg_val &= ~CCM_PLL5_CTRL_N_MASK;		/* set N to 0 (x0) */  	reg_val &= ~CCM_PLL5_CTRL_P_MASK;		/* set P to 0 (x1) */ +#ifdef CONFIG_OLD_SUNXI_KERNEL_COMPAT +	/* Old kernels are hardcoded to P=1 (divide by 2) */ +	reg_val |= CCM_PLL5_CTRL_P(1); +#endif  	if (clk >= 540 && clk < 552) { -		/* dram = 540MHz, pll5p = 1080MHz */ -		pll5p_clk = 1080; +		/* dram = 540MHz */  		reg_val |= CCM_PLL5_CTRL_M(CCM_PLL5_CTRL_M_X(2));  		reg_val |= CCM_PLL5_CTRL_K(CCM_PLL5_CTRL_K_X(3));  		reg_val |= CCM_PLL5_CTRL_N(CCM_PLL5_CTRL_N_X(15));  	} else if (clk >= 512 && clk < 528) { -		/* dram = 512MHz, pll5p = 1536MHz */ -		pll5p_clk = 1536; +		/* dram = 512MHz */  		reg_val |= CCM_PLL5_CTRL_M(CCM_PLL5_CTRL_M_X(3));  		reg_val |= CCM_PLL5_CTRL_K(CCM_PLL5_CTRL_K_X(4));  		reg_val |= CCM_PLL5_CTRL_N(CCM_PLL5_CTRL_N_X(16));  	} else if (clk >= 496 && clk < 504) { -		/* dram = 496MHz, pll5p = 1488MHz */ -		pll5p_clk = 1488; +		/* dram = 496MHz */  		reg_val |= CCM_PLL5_CTRL_M(CCM_PLL5_CTRL_M_X(3));  		reg_val |= CCM_PLL5_CTRL_K(CCM_PLL5_CTRL_K_X(2));  		reg_val |= CCM_PLL5_CTRL_N(CCM_PLL5_CTRL_N_X(31));  	} else if (clk >= 468 && clk < 480) { -		/* dram = 468MHz, pll5p = 936MHz */ -		pll5p_clk = 936; +		/* dram = 468MHz */  		reg_val |= CCM_PLL5_CTRL_M(CCM_PLL5_CTRL_M_X(2));  		reg_val |= CCM_PLL5_CTRL_K(CCM_PLL5_CTRL_K_X(3));  		reg_val |= CCM_PLL5_CTRL_N(CCM_PLL5_CTRL_N_X(13));  	} else if (clk >= 396 && clk < 408) { -		/* dram = 396MHz, pll5p = 792MHz */ -		pll5p_clk = 792; +		/* dram = 396MHz */  		reg_val |= CCM_PLL5_CTRL_M(CCM_PLL5_CTRL_M_X(2));  		reg_val |= CCM_PLL5_CTRL_K(CCM_PLL5_CTRL_K_X(3));  		reg_val |= CCM_PLL5_CTRL_N(CCM_PLL5_CTRL_N_X(11)); @@ -322,6 +315,13 @@ static void mctl_setup_dram_clock(u32 clk, u32 mbus_clk)  	/* setup MBUS clock */  	if (!mbus_clk)  		mbus_clk = 300; + +	/* PLL5P and PLL6 are the potential clock sources for MBUS */ +	pll6x_clk = clock_get_pll6() / 1000000; +#ifdef CONFIG_SUN7I +	pll6x_clk *= 2; /* sun7i uses PLL6*2, sun5i uses just PLL6 */ +#endif +	pll5p_clk = clock_get_pll5p() / 1000000;  	pll6x_div = DIV_ROUND_UP(pll6x_clk, mbus_clk);  	pll5p_div = DIV_ROUND_UP(pll5p_clk, mbus_clk);  	pll6x_rate = pll6x_clk / pll6x_div; diff --git a/arch/arm/cpu/armv7/sunxi/prcm.c b/arch/arm/cpu/armv7/sunxi/prcm.c new file mode 100644 index 00000000000..19b4938dc97 --- /dev/null +++ b/arch/arm/cpu/armv7/sunxi/prcm.c @@ -0,0 +1,35 @@ +/* + * Sunxi A31 Power Management Unit + * + * (C) Copyright 2013 Oliver Schinagl <oliver@schinagl.nl> + * http://linux-sunxi.org + * + * Based on sun6i sources and earlier U-Boot Allwinner A10 SPL work + * + * (C) Copyright 2006-2013 + * Allwinner Technology Co., Ltd. <www.allwinnertech.com> + * Berg Xing <bergxing@allwinnertech.com> + * Tom Cubie <tangliang@allwinnertech.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <errno.h> +#include <asm/io.h> +#include <asm/arch/cpu.h> +#include <asm/arch/prcm.h> +#include <asm/arch/sys_proto.h> + +/* APB0 clock gate and reset bit offsets are the same. */ +void prcm_apb0_enable(u32 flags) +{ +	struct sunxi_prcm_reg *prcm = +		(struct sunxi_prcm_reg *)SUNXI_PRCM_BASE; + +	/* open the clock for module */ +	setbits_le32(&prcm->apb0_gate, flags); + +	/* deassert reset for module */ +	setbits_le32(&prcm->apb0_reset, flags); +} diff --git a/arch/arm/cpu/armv7/tegra-common/Kconfig b/arch/arm/cpu/armv7/tegra-common/Kconfig index bcae2d60334..3ea6d7651cb 100644 --- a/arch/arm/cpu/armv7/tegra-common/Kconfig +++ b/arch/arm/cpu/armv7/tegra-common/Kconfig @@ -17,6 +17,9 @@ config TEGRA124  endchoice +config USE_PRIVATE_LIBGCC +	default y if SPL_BUILD +  config SYS_CPU  	default "arm720t" if SPL_BUILD  	default "armv7" if !SPL_BUILD diff --git a/arch/arm/cpu/armv7/tegra20/display.c b/arch/arm/cpu/armv7/tegra20/display.c index fd77f3f0eff..d98cec90180 100644 --- a/arch/arm/cpu/armv7/tegra20/display.c +++ b/arch/arm/cpu/armv7/tegra20/display.c @@ -194,7 +194,8 @@ static void rgb_enable(struct dc_com_reg *com)  		writel(rgb_sel_tab[i], &com->pin_output_sel[i]);  } -int setup_window(struct disp_ctl_win *win, struct fdt_disp_config *config) +static int setup_window(struct disp_ctl_win *win, +			struct fdt_disp_config *config)  {  	win->x = 0;  	win->y = 0; diff --git a/arch/arm/cpu/armv7/tegra30/Kconfig b/arch/arm/cpu/armv7/tegra30/Kconfig index 54aec4ed509..3abdc7ba173 100644 --- a/arch/arm/cpu/armv7/tegra30/Kconfig +++ b/arch/arm/cpu/armv7/tegra30/Kconfig @@ -3,6 +3,9 @@ if TEGRA30  choice  	prompt "Tegra30 board select" +config TARGET_APALIS_T30 +	bool "Toradex Apalis T30 board" +  config TARGET_BEAVER  	bool "NVIDIA Tegra30 Beaver evaluation board" @@ -20,6 +23,7 @@ endchoice  config SYS_SOC  	default "tegra30" +source "board/toradex/apalis_t30/Kconfig"  source "board/nvidia/beaver/Kconfig"  source "board/nvidia/cardhu/Kconfig"  source "board/toradex/colibri_t30/Kconfig" diff --git a/arch/arm/cpu/armv7/uniphier/ph1-ld4/Makefile b/arch/arm/cpu/armv7/uniphier/ph1-ld4/Makefile index b385e195447..781b511a97b 100644 --- a/arch/arm/cpu/armv7/uniphier/ph1-ld4/Makefile +++ b/arch/arm/cpu/armv7/uniphier/ph1-ld4/Makefile @@ -3,6 +3,7 @@  #  obj-$(CONFIG_DISPLAY_BOARDINFO) += board_info.o +obj-y += platdevice.o  obj-y += boot-mode.o  obj-$(CONFIG_BOARD_POSTCLK_INIT) += board_postclk_init.o bcu_init.o \  		sbc_init.o sg_init.o pll_init.o clkrst_init.o pinctrl.o diff --git a/arch/arm/cpu/armv7/uniphier/ph1-ld4/platdevice.c b/arch/arm/cpu/armv7/uniphier/ph1-ld4/platdevice.c new file mode 100644 index 00000000000..0047223181a --- /dev/null +++ b/arch/arm/cpu/armv7/uniphier/ph1-ld4/platdevice.c @@ -0,0 +1,15 @@ +/* + * Copyright (C) 2014 Panasonic Corporation + *   Author: Masahiro Yamada <yamada.m@jp.panasonic.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <asm/arch/platdevice.h> + +#define UART_MASTER_CLK		36864000 + +SERIAL_DEVICE(0, 0x54006800, UART_MASTER_CLK) +SERIAL_DEVICE(1, 0x54006900, UART_MASTER_CLK) +SERIAL_DEVICE(2, 0x54006a00, UART_MASTER_CLK) +SERIAL_DEVICE(3, 0x54006b00, UART_MASTER_CLK) diff --git a/arch/arm/cpu/armv7/uniphier/ph1-pro4/Makefile b/arch/arm/cpu/armv7/uniphier/ph1-pro4/Makefile index 712afd1beeb..e11f4f6d8b3 100644 --- a/arch/arm/cpu/armv7/uniphier/ph1-pro4/Makefile +++ b/arch/arm/cpu/armv7/uniphier/ph1-pro4/Makefile @@ -3,6 +3,7 @@  #  obj-$(CONFIG_DISPLAY_BOARDINFO) += board_info.o +obj-y += platdevice.o  obj-y += boot-mode.o  obj-$(CONFIG_BOARD_POSTCLK_INIT) += board_postclk_init.o sbc_init.o \  				sg_init.o pll_init.o clkrst_init.o pinctrl.o diff --git a/arch/arm/cpu/armv7/uniphier/ph1-pro4/platdevice.c b/arch/arm/cpu/armv7/uniphier/ph1-pro4/platdevice.c new file mode 100644 index 00000000000..6da921e9204 --- /dev/null +++ b/arch/arm/cpu/armv7/uniphier/ph1-pro4/platdevice.c @@ -0,0 +1,15 @@ +/* + * Copyright (C) 2014 Panasonic Corporation + *   Author: Masahiro Yamada <yamada.m@jp.panasonic.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <asm/arch/platdevice.h> + +#define UART_MASTER_CLK		73728000 + +SERIAL_DEVICE(0, 0x54006800, UART_MASTER_CLK) +SERIAL_DEVICE(1, 0x54006900, UART_MASTER_CLK) +SERIAL_DEVICE(2, 0x54006a00, UART_MASTER_CLK) +SERIAL_DEVICE(3, 0x54006b00, UART_MASTER_CLK) diff --git a/arch/arm/cpu/armv7/uniphier/ph1-sld8/Makefile b/arch/arm/cpu/armv7/uniphier/ph1-sld8/Makefile index b385e195447..781b511a97b 100644 --- a/arch/arm/cpu/armv7/uniphier/ph1-sld8/Makefile +++ b/arch/arm/cpu/armv7/uniphier/ph1-sld8/Makefile @@ -3,6 +3,7 @@  #  obj-$(CONFIG_DISPLAY_BOARDINFO) += board_info.o +obj-y += platdevice.o  obj-y += boot-mode.o  obj-$(CONFIG_BOARD_POSTCLK_INIT) += board_postclk_init.o bcu_init.o \  		sbc_init.o sg_init.o pll_init.o clkrst_init.o pinctrl.o diff --git a/arch/arm/cpu/armv7/uniphier/ph1-sld8/platdevice.c b/arch/arm/cpu/armv7/uniphier/ph1-sld8/platdevice.c new file mode 100644 index 00000000000..59d054a3102 --- /dev/null +++ b/arch/arm/cpu/armv7/uniphier/ph1-sld8/platdevice.c @@ -0,0 +1,15 @@ +/* + * Copyright (C) 2014 Panasonic Corporation + *   Author: Masahiro Yamada <yamada.m@jp.panasonic.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <asm/arch/platdevice.h> + +#define UART_MASTER_CLK		80000000 + +SERIAL_DEVICE(0, 0x54006800, UART_MASTER_CLK) +SERIAL_DEVICE(1, 0x54006900, UART_MASTER_CLK) +SERIAL_DEVICE(2, 0x54006a00, UART_MASTER_CLK) +SERIAL_DEVICE(3, 0x54006b00, UART_MASTER_CLK) diff --git a/arch/arm/cpu/tegra-common/board.c b/arch/arm/cpu/tegra-common/board.c index 433da09d10c..b6a84a57747 100644 --- a/arch/arm/cpu/tegra-common/board.c +++ b/arch/arm/cpu/tegra-common/board.c @@ -9,6 +9,7 @@  #include <asm/io.h>  #include <asm/arch/clock.h>  #include <asm/arch/funcmux.h> +#include <asm/arch/mc.h>  #include <asm/arch/tegra.h>  #include <asm/arch-tegra/board.h>  #include <asm/arch-tegra/pmc.h> @@ -27,55 +28,6 @@ enum {  	UART_COUNT = 5,  }; -#if defined(CONFIG_TEGRA20) || defined(CONFIG_TEGRA30) || \ -	defined(CONFIG_TEGRA114) -/* - * Boot ROM initializes the odmdata in APBDEV_PMC_SCRATCH20_0, - * so we are using this value to identify memory size. - */ -unsigned int query_sdram_size(void) -{ -	struct pmc_ctlr *const pmc = (struct pmc_ctlr *)NV_PA_PMC_BASE; -	u32 reg; - -	reg = readl(&pmc->pmc_scratch20); -	debug("pmc->pmc_scratch20 (ODMData) = 0x%08x\n", reg); - -#if defined(CONFIG_TEGRA20) -	/* bits 30:28 in OdmData are used for RAM size on T20  */ -	reg &= 0x70000000; - -	switch ((reg) >> 28) { -	case 1: -		return 0x10000000;	/* 256 MB */ -	case 0: -	case 2: -	default: -		return 0x20000000;	/* 512 MB */ -	case 3: -		return 0x40000000;	/* 1GB */ -	} -#else	/* Tegra30/Tegra114 */ -	/* bits 31:28 in OdmData are used for RAM size on T30  */ -	switch ((reg) >> 28) { -	case 0: -	case 1: -	default: -		return 0x10000000;	/* 256 MB */ -	case 2: -		return 0x20000000;	/* 512 MB */ -	case 3: -		return 0x30000000;	/* 768 MB */ -	case 4: -		return 0x40000000;	/* 1GB */ -	case 8: -		return 0x7ff00000;	/* 2GB - 1MB */ -	} -#endif -} -#else -#include <asm/arch/mc.h> -  /* Read the RAM size directly from the memory controller */  unsigned int query_sdram_size(void)  { @@ -83,12 +35,22 @@ unsigned int query_sdram_size(void)  	u32 size_mb;  	size_mb = readl(&mc->mc_emem_cfg); +#if defined(CONFIG_TEGRA20) +	debug("mc->mc_emem_cfg (MEM_SIZE_KB) = 0x%08x\n", size_mb); +	size_mb = get_ram_size((void *)PHYS_SDRAM_1, size_mb * 1024); +#else  	debug("mc->mc_emem_cfg (MEM_SIZE_MB) = 0x%08x\n", size_mb); +	size_mb = get_ram_size((void *)PHYS_SDRAM_1, size_mb * 1024 * 1024); +#endif -	return size_mb * 1024 * 1024; -} +#if defined(CONFIG_TEGRA30) || defined(CONFIG_TEGRA114) +	/* External memory limited to 2047 MB due to IROM/HI-VEC */ +	if (size_mb == SZ_2G) size_mb -= SZ_1M;  #endif +	return size_mb; +} +  int dram_init(void)  {  	/* We do not initialise DRAM here. We just query the size */ diff --git a/arch/arm/cpu/tegra-common/sys_info.c b/arch/arm/cpu/tegra-common/sys_info.c index de20325ecf3..5933c35ddd4 100644 --- a/arch/arm/cpu/tegra-common/sys_info.c +++ b/arch/arm/cpu/tegra-common/sys_info.c @@ -8,7 +8,7 @@  #include <common.h>  #include <linux/ctype.h> -void upstring(char *s) +static void upstring(char *s)  {  	while (*s) {  		*s = toupper(*s); diff --git a/arch/arm/dts/Makefile b/arch/arm/dts/Makefile index c37580ed842..c34606334db 100644 --- a/arch/arm/dts/Makefile +++ b/arch/arm/dts/Makefile @@ -22,6 +22,7 @@ dtb-$(CONFIG_TEGRA) += tegra20-harmony.dtb \  	tegra20-ventana.dtb \  	tegra20-whistler.dtb \  	tegra20-colibri_t20_iris.dtb \ +	tegra30-apalis.dtb \  	tegra30-beaver.dtb \  	tegra30-cardhu.dtb \  	tegra30-colibri.dtb \ diff --git a/arch/arm/dts/am335x-bone-common.dtsi b/arch/arm/dts/am335x-bone-common.dtsi index 2f66deda9f5..e70b4d1f1fa 100644 --- a/arch/arm/dts/am335x-bone-common.dtsi +++ b/arch/arm/dts/am335x-bone-common.dtsi @@ -10,6 +10,10 @@  	model = "TI AM335x BeagleBone";  	compatible = "ti,am335x-bone", "ti,am33xx"; +	chosen { +		stdout-path = &uart0; +	}; +  	cpus {  		cpu@0 {  			cpu0-supply = <&dcdc2_reg>; diff --git a/arch/arm/dts/dt-bindings/gpio/gpio.h b/arch/arm/dts/dt-bindings/gpio/gpio.h deleted file mode 100644 index e6b1e0a808a..00000000000 --- a/arch/arm/dts/dt-bindings/gpio/gpio.h +++ /dev/null @@ -1,15 +0,0 @@ -/* - * This header provides constants for most GPIO bindings. - * - * Most GPIO bindings include a flags cell as part of the GPIO specifier. - * In most cases, the format of the flags cell uses the standard values - * defined in this header. - */ - -#ifndef _DT_BINDINGS_GPIO_GPIO_H -#define _DT_BINDINGS_GPIO_GPIO_H - -#define GPIO_ACTIVE_HIGH 0 -#define GPIO_ACTIVE_LOW 1 - -#endif diff --git a/arch/arm/dts/dt-bindings/pinctrl/am33xx.h b/arch/arm/dts/dt-bindings/pinctrl/am33xx.h deleted file mode 100644 index 2fbc804e1a4..00000000000 --- a/arch/arm/dts/dt-bindings/pinctrl/am33xx.h +++ /dev/null @@ -1,42 +0,0 @@ -/* - * This header provides constants specific to AM33XX pinctrl bindings. - */ - -#ifndef _DT_BINDINGS_PINCTRL_AM33XX_H -#define _DT_BINDINGS_PINCTRL_AM33XX_H - -#include <dt-bindings/pinctrl/omap.h> - -/* am33xx specific mux bit defines */ -#undef PULL_ENA -#undef INPUT_EN - -#define PULL_DISABLE		(1 << 3) -#define INPUT_EN		(1 << 5) -#define SLEWCTRL_FAST		(1 << 6) - -/* update macro depending on INPUT_EN and PULL_ENA */ -#undef PIN_OUTPUT -#undef PIN_OUTPUT_PULLUP -#undef PIN_OUTPUT_PULLDOWN -#undef PIN_INPUT -#undef PIN_INPUT_PULLUP -#undef PIN_INPUT_PULLDOWN - -#define PIN_OUTPUT		(PULL_DISABLE) -#define PIN_OUTPUT_PULLUP	(PULL_UP) -#define PIN_OUTPUT_PULLDOWN	0 -#define PIN_INPUT		(INPUT_EN | PULL_DISABLE) -#define PIN_INPUT_PULLUP	(INPUT_EN | PULL_UP) -#define PIN_INPUT_PULLDOWN	(INPUT_EN) - -/* undef non-existing modes */ -#undef PIN_OFF_NONE -#undef PIN_OFF_OUTPUT_HIGH -#undef PIN_OFF_OUTPUT_LOW -#undef PIN_OFF_INPUT_PULLUP -#undef PIN_OFF_INPUT_PULLDOWN -#undef PIN_OFF_WAKEUPENABLE - -#endif - diff --git a/arch/arm/dts/dt-bindings/pinctrl/omap.h b/arch/arm/dts/dt-bindings/pinctrl/omap.h deleted file mode 100644 index edbd250809c..00000000000 --- a/arch/arm/dts/dt-bindings/pinctrl/omap.h +++ /dev/null @@ -1,55 +0,0 @@ -/* - * This header provides constants for OMAP pinctrl bindings. - * - * Copyright (C) 2009 Nokia - * Copyright (C) 2009-2010 Texas Instruments - */ - -#ifndef _DT_BINDINGS_PINCTRL_OMAP_H -#define _DT_BINDINGS_PINCTRL_OMAP_H - -/* 34xx mux mode options for each pin. See TRM for options */ -#define MUX_MODE0	0 -#define MUX_MODE1	1 -#define MUX_MODE2	2 -#define MUX_MODE3	3 -#define MUX_MODE4	4 -#define MUX_MODE5	5 -#define MUX_MODE6	6 -#define MUX_MODE7	7 - -/* 24xx/34xx mux bit defines */ -#define PULL_ENA		(1 << 3) -#define PULL_UP			(1 << 4) -#define ALTELECTRICALSEL	(1 << 5) - -/* 34xx specific mux bit defines */ -#define INPUT_EN		(1 << 8) -#define OFF_EN			(1 << 9) -#define OFFOUT_EN		(1 << 10) -#define OFFOUT_VAL		(1 << 11) -#define OFF_PULL_EN		(1 << 12) -#define OFF_PULL_UP		(1 << 13) -#define WAKEUP_EN		(1 << 14) - -/* 44xx specific mux bit defines */ -#define WAKEUP_EVENT		(1 << 15) - -/* Active pin states */ -#define PIN_OUTPUT		0 -#define PIN_OUTPUT_PULLUP	(PIN_OUTPUT | PULL_ENA | PULL_UP) -#define PIN_OUTPUT_PULLDOWN	(PIN_OUTPUT | PULL_ENA) -#define PIN_INPUT		INPUT_EN -#define PIN_INPUT_PULLUP	(PULL_ENA | INPUT_EN | PULL_UP) -#define PIN_INPUT_PULLDOWN	(PULL_ENA | INPUT_EN) - -/* Off mode states */ -#define PIN_OFF_NONE		0 -#define PIN_OFF_OUTPUT_HIGH	(OFF_EN | OFFOUT_EN | OFFOUT_VAL) -#define PIN_OFF_OUTPUT_LOW	(OFF_EN | OFFOUT_EN) -#define PIN_OFF_INPUT_PULLUP	(OFF_EN | OFF_PULL_EN | OFF_PULL_UP) -#define PIN_OFF_INPUT_PULLDOWN	(OFF_EN | OFF_PULL_EN) -#define PIN_OFF_WAKEUPENABLE	WAKEUP_EN - -#endif - diff --git a/arch/arm/dts/tegra30-apalis.dts b/arch/arm/dts/tegra30-apalis.dts new file mode 100644 index 00000000000..5bad3e77698 --- /dev/null +++ b/arch/arm/dts/tegra30-apalis.dts @@ -0,0 +1,304 @@ +/dts-v1/; + +#include "tegra30.dtsi" + +/ { +	model = "Toradex Apalis T30"; +	compatible = "toradex,apalis_t30", "nvidia,tegra30"; + +	chosen { +		stdout-path = &uarta; +	}; + +	aliases { +		i2c0 = "/i2c@7000d000"; +		i2c1 = "/i2c@7000c000"; +		i2c2 = "/i2c@7000c500"; +		i2c3 = "/i2c@7000c700"; +		sdhci0 = "/sdhci@78000600"; +		sdhci1 = "/sdhci@78000400"; +		sdhci2 = "/sdhci@78000000"; +		usb0 = "/usb@7d000000"; +		usb1 = "/usb@7d004000"; +		usb2 = "/usb@7d008000"; +	}; + +	memory { +		device_type = "memory"; +		reg = <0x80000000 0x40000000>; +	}; + +	pcie-controller@00003000 { +		status = "okay"; +		avdd-pexa-supply = <&vdd2_reg>; +		vdd-pexa-supply = <&vdd2_reg>; +		avdd-pexb-supply = <&vdd2_reg>; +		vdd-pexb-supply = <&vdd2_reg>; +		avdd-pex-pll-supply = <&vdd2_reg>; +		avdd-plle-supply = <&ldo6_reg>; +		vddio-pex-ctl-supply = <&sys_3v3_reg>; +		hvdd-pex-supply = <&sys_3v3_reg>; + +		pci@1,0 { +			nvidia,num-lanes = <4>; +		}; + +		pci@2,0 { +			nvidia,num-lanes = <1>; +		}; + +		pci@3,0 { +			status = "okay"; +			nvidia,num-lanes = <1>; +		}; +	}; + +	/* +	 * GEN1_I2C: I2C1_SDA/SCL on MXM3 pin 209/211 (e.g. RTC on carrier +	 * board) +	 */ +	i2c@7000c000 { +		status = "okay"; +		clock-frequency = <100000>; +	}; + +	/* GEN2_I2C: unused */ + +	/* +	 * CAM_I2C: I2C3_SDA/SCL on MXM3 pin 201/203 (e.g. camera sensor on +	 * carrier board) +	 */ +	i2c@7000c500 { +		status = "okay"; +		clock-frequency = <100000>; +	}; + +	/* DDC: I2C2_SDA/SCL on MXM3 pin 205/207 (e.g. display EDID) */ +	i2c@7000c700 { +		status = "okay"; +		clock-frequency = <100000>; +	}; + +	/* +	 * PWR_I2C: power I2C to audio codec, PMIC, temperature sensor and +	 * touch screen controller +	 */ +	i2c@7000d000 { +		status = "okay"; +		clock-frequency = <100000>; + +		pmic: tps65911@2d { +			compatible = "ti,tps65911"; +			reg = <0x2d>; + +			interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>; +			#interrupt-cells = <2>; +			interrupt-controller; + +			ti,system-power-controller; + +			#gpio-cells = <2>; +			gpio-controller; + +			vcc1-supply = <&sys_3v3_reg>; +			vcc2-supply = <&sys_3v3_reg>; +			vcc3-supply = <&vio_reg>; +			vcc4-supply = <&sys_3v3_reg>; +			vcc5-supply = <&sys_3v3_reg>; +			vcc6-supply = <&vio_reg>; +			vcc7-supply = <&charge_pump_5v0_reg>; +			vccio-supply = <&sys_3v3_reg>; + +			regulators { +				#address-cells = <1>; +				#size-cells = <0>; + +				/* SW1: +V1.35_VDDIO_DDR */ +				vdd1_reg: vdd1 { +					regulator-name = "vddio_ddr_1v35"; +					regulator-min-microvolt = <1350000>; +					regulator-max-microvolt = <1350000>; +					regulator-always-on; +				}; + +				/* SW2: +V1.05 */ +				vdd2_reg: vdd2 { +					regulator-name = +						"vdd_pexa,vdd_pexb,vdd_sata"; +					regulator-min-microvolt = <1050000>; +					regulator-max-microvolt = <1050000>; +				}; + +				/* SW CTRL: +V1.0_VDD_CPU */ +				vddctrl_reg: vddctrl { +					regulator-name = "vdd_cpu,vdd_sys"; +					regulator-min-microvolt = <1150000>; +					regulator-max-microvolt = <1150000>; +					regulator-always-on; +				}; + +				/* SWIO: +V1.8 */ +				vio_reg: vio { +					regulator-name = "vdd_1v8_gen"; +					regulator-min-microvolt = <1800000>; +					regulator-max-microvolt = <1800000>; +					regulator-always-on; +				}; + +				/* LDO1: unused */ + +				/* +				 * EN_+V3.3 switching via FET: +				 * +V3.3_AUDIO_AVDD_S, +V3.3 and +V1.8_VDD_LAN +				 * see also v3_3 fixed supply +				 */ +				ldo2_reg: ldo2 { +					regulator-name = "en_3v3"; +					regulator-min-microvolt = <3300000>; +					regulator-max-microvolt = <3300000>; +					regulator-always-on; +				}; + +				/* +V1.2_CSI */ +				ldo3_reg: ldo3 { +					regulator-name = +						"avdd_dsi_csi,pwrdet_mipi"; +					regulator-min-microvolt = <1200000>; +					regulator-max-microvolt = <1200000>; +				}; + +				/* +V1.2_VDD_RTC */ +				ldo4_reg: ldo4 { +					regulator-name = "vdd_rtc"; +					regulator-min-microvolt = <1200000>; +					regulator-max-microvolt = <1200000>; +					regulator-always-on; +				}; + +				/* +				 * +V2.8_AVDD_VDAC: +				 * only required for analog RGB +				 */ +				ldo5_reg: ldo5 { +					regulator-name = "avdd_vdac"; +					regulator-min-microvolt = <2800000>; +					regulator-max-microvolt = <2800000>; +					regulator-always-on; +				}; + +				/* +				 * +V1.05_AVDD_PLLE: avdd_plle should be 1.05V +				 * but LDO6 can't set voltage in 50mV +				 * granularity +				 */ +				ldo6_reg: ldo6 { +					regulator-name = "avdd_plle"; +					regulator-min-microvolt = <1100000>; +					regulator-max-microvolt = <1100000>; +				}; + +				/* +V1.2_AVDD_PLL */ +				ldo7_reg: ldo7 { +					regulator-name = "avdd_pll"; +					regulator-min-microvolt = <1200000>; +					regulator-max-microvolt = <1200000>; +					regulator-always-on; +				}; + +				/* +V1.0_VDD_DDR_HS */ +				ldo8_reg: ldo8 { +					regulator-name = "vdd_ddr_hs"; +					regulator-min-microvolt = <1000000>; +					regulator-max-microvolt = <1000000>; +					regulator-always-on; +				}; +			}; +		}; +	}; + +	/* SPI1: Apalis SPI1 */ +	spi@7000d400 { +		status = "okay"; +		spi-max-frequency = <25000000>; +	}; + +	/* SPI4: CAN2 */ +	spi@7000da00 { +		status = "okay"; +		spi-max-frequency = <25000000>; +	}; + +	/* SPI5: Apalis SPI2 */ +	spi@7000dc00 { +		status = "okay"; +		spi-max-frequency = <25000000>; +	}; + +	/* SPI6: CAN1 */ +	spi@7000de00 { +		status = "okay"; +		spi-max-frequency = <25000000>; +	}; + +	sdhci@78000000 { +		status = "okay"; +		bus-width = <4>; +		cd-gpios = <&gpio 229 1>; /* PCC5, SD1_CD# */ +	}; + +	sdhci@78000400 { +		status = "okay"; +		bus-width = <8>; +		cd-gpios = <&gpio 171 1>; /* PV3, MMC1_CD# */ +	}; + +	sdhci@78000600 { +		status = "okay"; +		bus-width = <8>; +		non-removable; +	}; + +	/* EHCI instance 0: USB1_DP/N -> USBO1_DP/N */ +	usb@7d000000 { +		status = "okay"; +		dr_mode = "peripheral"; +		nvidia,vbus-gpio = <&gpio 157 0>;	/* PT5, USBO1_EN */ +	}; + +	/* EHCI instance 1: USB2_DP/N -> USBH2_DP/N */ +	usb@7d004000 { +		status = "okay"; +		nvidia,vbus-gpio = <&gpio 233 0>;	/* PDD1, USBH_EN */ +		phy_type = "utmi"; +	}; + +	/* EHCI instance 2: USB3_DP/N -> USBH3_DP/N */ +	usb@7d008000 { +		status = "okay"; +		nvidia,vbus-gpio = <&gpio 233 0>;	/* PDD1, USBH_EN */ +	}; + +	regulators { +		compatible = "simple-bus"; +		#address-cells = <1>; +		#size-cells = <0>; + +		sys_3v3_reg: regulator@100 { +			compatible = "regulator-fixed"; +			reg = <100>; +			regulator-name = "3v3"; +			regulator-min-microvolt = <3300000>; +			regulator-max-microvolt = <3300000>; +			regulator-always-on; +		}; + +		charge_pump_5v0_reg: regulator@101 { +			compatible = "regulator-fixed"; +			reg = <101>; +			regulator-name = "5v0"; +			regulator-min-microvolt = <5000000>; +			regulator-max-microvolt = <5000000>; +			regulator-always-on; +		}; +	}; +}; diff --git a/arch/arm/dts/tegra30-colibri.dts b/arch/arm/dts/tegra30-colibri.dts index df79c26a458..572520a00ec 100644 --- a/arch/arm/dts/tegra30-colibri.dts +++ b/arch/arm/dts/tegra30-colibri.dts @@ -6,6 +6,10 @@  	model = "Toradex Colibri T30";  	compatible = "toradex,colibri_t30", "nvidia,tegra30"; +	chosen { +		stdout-path = &uarta; +	}; +  	aliases {  		i2c0 = "/i2c@7000d000";  		i2c1 = "/i2c@7000c000"; diff --git a/arch/arm/imx-common/cpu.c b/arch/arm/imx-common/cpu.c index ed826a0e19c..09fc22760d0 100644 --- a/arch/arm/imx-common/cpu.c +++ b/arch/arm/imx-common/cpu.c @@ -7,7 +7,9 @@   * SPDX-License-Identifier:	GPL-2.0+   */ +#include <bootm.h>  #include <common.h> +#include <netdev.h>  #include <asm/errno.h>  #include <asm/io.h>  #include <asm/arch/imx-regs.h> diff --git a/arch/arm/imx-common/misc.c b/arch/arm/imx-common/misc.c index dbecf4e4348..12256a38eb9 100644 --- a/arch/arm/imx-common/misc.c +++ b/arch/arm/imx-common/misc.c @@ -5,6 +5,7 @@   */  #include <common.h> +#include <asm/arch/sys_proto.h>  #include <asm/errno.h>  #include <asm/io.h>  #include <asm/imx-common/regs-common.h> diff --git a/arch/arm/include/asm/arch-armada-xp/config.h b/arch/arm/include/asm/arch-armada-xp/config.h new file mode 100644 index 00000000000..00ee775a451 --- /dev/null +++ b/arch/arm/include/asm/arch-armada-xp/config.h @@ -0,0 +1,82 @@ +/* + * (C) Copyright 2011 + * Marvell Semiconductor <www.marvell.com> + * Written-by: Lei Wen <leiwen@marvell.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +/* + * This file should be included in board config header file. + * + * It supports common definitions for Armada XP platforms + */ + +#ifndef _ARMADA_XP_CONFIG_H +#define _ARMADA_XP_CONFIG_H + +#include <asm/arch/soc.h> + +#define MV88F78X60 /* for the DDR training bin_hdr code */ + +#define CONFIG_SYS_CACHELINE_SIZE	32 + +/* + * By default kwbimage.cfg from board specific folder is used + * If for some board, different configuration file need to be used, + * CONFIG_SYS_KWD_CONFIG should be defined in board specific header file + */ +#ifndef CONFIG_SYS_KWD_CONFIG +#define	CONFIG_SYS_KWD_CONFIG	$(CONFIG_BOARDDIR)/kwbimage.cfg +#endif /* CONFIG_SYS_KWD_CONFIG */ + +/* Add target to build it automatically upon "make" */ +#define CONFIG_BUILD_TARGET	"u-boot.kwb" + +/* end of 16M scrubbed by training in bootrom */ +#define CONFIG_SYS_INIT_SP_ADDR		0x00FF0000 +#define CONFIG_NR_DRAM_BANKS_MAX	2 + +#define MV_UART_CONSOLE_BASE		MVEBU_UART0_BASE + +/* + * SPI Flash configuration + */ +#ifdef CONFIG_CMD_SF +#define CONFIG_HARD_SPI			1 +#define CONFIG_KIRKWOOD_SPI		1 +#ifndef CONFIG_ENV_SPI_BUS +# define CONFIG_ENV_SPI_BUS		0 +#endif +#ifndef CONFIG_ENV_SPI_CS +# define CONFIG_ENV_SPI_CS		0 +#endif +#ifndef CONFIG_ENV_SPI_MAX_HZ +# define CONFIG_ENV_SPI_MAX_HZ		50000000 +#endif +#endif + +/* + * Ethernet Driver configuration + */ +#ifdef CONFIG_CMD_NET +#define CONFIG_CMD_MII +#define CONFIG_MII		/* expose smi ove miiphy interface */ +#define CONFIG_MVNETA		/* Enable Marvell Gbe Controller Driver */ +#define CONFIG_PHYLIB +#define CONFIG_ENV_OVERWRITE	/* ethaddr can be reprogrammed */ +#define CONFIG_PHY_GIGE		/* GbE speed/duplex detect */ +#endif /* CONFIG_CMD_NET */ + +/* + * I2C related stuff + */ +#ifdef CONFIG_CMD_I2C +#ifndef CONFIG_SYS_I2C_SOFT +#define CONFIG_I2C_MVTWSI +#endif +#define CONFIG_SYS_I2C_SLAVE		0x0 +#define CONFIG_SYS_I2C_SPEED		100000 +#endif + +#endif /* _ARMADA_XP_CONFIG_H */ diff --git a/arch/arm/include/asm/arch-armada-xp/cpu.h b/arch/arm/include/asm/arch-armada-xp/cpu.h new file mode 100644 index 00000000000..6b60c21ceb8 --- /dev/null +++ b/arch/arm/include/asm/arch-armada-xp/cpu.h @@ -0,0 +1,107 @@ +/* + * (C) Copyright 2009 + * Marvell Semiconductor <www.marvell.com> + * Written-by: Prafulla Wadaskar <prafulla@marvell.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _ARMADA_XP_CPU_H +#define _ARMADA_XP_CPU_H + +#include <asm/system.h> + +#ifndef __ASSEMBLY__ + +#define MVEBU_REG_PCIE_DEVID		(MVEBU_REG_PCIE_BASE + 0x00) +#define MVEBU_REG_PCIE_REVID		(MVEBU_REG_PCIE_BASE + 0x08) + +enum memory_bank { +	BANK0, +	BANK1, +	BANK2, +	BANK3 +}; + +enum cpu_winen { +	CPU_WIN_DISABLE, +	CPU_WIN_ENABLE +}; + +enum cpu_target { +	CPU_TARGET_DRAM = 0x0, +	CPU_TARGET_DEVICEBUS_BOOTROM_SPI = 0x1, +	CPU_TARGET_ETH23 = 0x3, +	CPU_TARGET_PCIE02 = 0x4, +	CPU_TARGET_ETH01 = 0x7, +	CPU_TARGET_PCIE13 = 0x8, +	CPU_TARGET_SASRAM = 0x9, +	CPU_TARGET_NAND = 0xd, +}; + +enum cpu_attrib { +	CPU_ATTR_SASRAM = 0x01, +	CPU_ATTR_DRAM_CS0 = 0x0e, +	CPU_ATTR_DRAM_CS1 = 0x0d, +	CPU_ATTR_DRAM_CS2 = 0x0b, +	CPU_ATTR_DRAM_CS3 = 0x07, +	CPU_ATTR_NANDFLASH = 0x2f, +	CPU_ATTR_SPIFLASH = 0x1e, +	CPU_ATTR_BOOTROM = 0x1d, +	CPU_ATTR_PCIE_IO = 0xe0, +	CPU_ATTR_PCIE_MEM = 0xe8, +	CPU_ATTR_DEV_CS0 = 0x3e, +	CPU_ATTR_DEV_CS1 = 0x3d, +	CPU_ATTR_DEV_CS2 = 0x3b, +	CPU_ATTR_DEV_CS3 = 0x37, +}; + +/* + * Default Device Address MAP BAR values + */ +#define DEFADR_PCI_MEM		0x90000000 +#define DEFADR_PCI_IO		0xC0000000 +#define DEFADR_SPIF		0xF4000000 +#define DEFADR_BOOTROM		0xF8000000 + +struct mbus_win { +	u32 base; +	u32 size; +	u8 target; +	u8 attr; +}; + +/* + * System registers + * Ref: Datasheet sec:A.28 + */ +struct mvebu_system_registers { +	u8 pad1[0x60]; +	u32 rstoutn_mask; /* 0x60 */ +	u32 sys_soft_rst; /* 0x64 */ +}; + +/* + * GPIO Registers + * Ref: Datasheet sec:A.19 + */ +struct kwgpio_registers { +	u32 dout; +	u32 oe; +	u32 blink_en; +	u32 din_pol; +	u32 din; +	u32 irq_cause; +	u32 irq_mask; +	u32 irq_level; +}; + +/* + * functions + */ +unsigned int mvebu_sdram_bar(enum memory_bank bank); +unsigned int mvebu_sdram_bs(enum memory_bank bank); +void mvebu_sdram_size_adjust(enum memory_bank bank); +int mvebu_mbus_probe(struct mbus_win windows[], int count); +#endif /* __ASSEMBLY__ */ +#endif /* _ARMADA_XP_CPU_H */ diff --git a/arch/arm/include/asm/arch-armada-xp/soc.h b/arch/arm/include/asm/arch-armada-xp/soc.h new file mode 100644 index 00000000000..963e7ac5b76 --- /dev/null +++ b/arch/arm/include/asm/arch-armada-xp/soc.h @@ -0,0 +1,57 @@ +/* + * (C) Copyright 2009 + * Marvell Semiconductor <www.marvell.com> + * Written-by: Prafulla Wadaskar <prafulla@marvell.com> + * + * Header file for the Marvell's Feroceon CPU core. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _ASM_ARCH_ARMADA_XP_H +#define _ASM_ARCH_ARMADA_XP_H + +#define SOC_MV78460_ID		0x7846 + +/* TCLK Core Clock definition */ +#ifndef CONFIG_SYS_TCLK +#define CONFIG_SYS_TCLK		250000000	/* 250MHz */ +#endif + +/* SOC specific definations */ +#define INTREG_BASE		0xd0000000 +#define INTREG_BASE_ADDR_REG	(INTREG_BASE + 0x20080) +#define SOC_REGS_PHY_BASE	0xf1000000 +#define MVEBU_REGISTER(x)	(SOC_REGS_PHY_BASE + x) + +#define MVEBU_SDRAM_SCRATCH	(MVEBU_REGISTER(0x01504)) +#define MVEBU_SPI_BASE		(MVEBU_REGISTER(0x10600)) +#define MVEBU_TWSI_BASE		(MVEBU_REGISTER(0x11000)) +#define MVEBU_UART0_BASE	(MVEBU_REGISTER(0x12000)) +#define MVEBU_UART1_BASE	(MVEBU_REGISTER(0x12100)) +#define MVEBU_MPP_BASE		(MVEBU_REGISTER(0x18000)) +#define MVEBU_GPIO0_BASE	(MVEBU_REGISTER(0x18100)) +#define MVEBU_GPIO1_BASE	(MVEBU_REGISTER(0x18140)) +#define MVEBU_GPIO2_BASE	(MVEBU_REGISTER(0x18180)) +#define MVEBU_SYSTEM_REG_BASE	(MVEBU_REGISTER(0x18200)) +#define MVEBU_CPU_WIN_BASE	(MVEBU_REGISTER(0x20000)) +#define MVEBU_SDRAM_BASE	(MVEBU_REGISTER(0x20180)) +#define MVEBU_TIMER_BASE	(MVEBU_REGISTER(0x20300)) +#define MVEBU_EGIGA2_BASE	(MVEBU_REGISTER(0x30000)) +#define MVEBU_EGIGA3_BASE	(MVEBU_REGISTER(0x34000)) +#define MVEBU_REG_PCIE_BASE	(MVEBU_REGISTER(0x40000)) +#define MVEBU_EGIGA0_BASE	(MVEBU_REGISTER(0x70000)) +#define MVEBU_EGIGA1_BASE	(MVEBU_REGISTER(0x74000)) + +#define SDRAM_MAX_CS		4 +#define SDRAM_ADDR_MASK		0xFF000000 + +/* Armada XP GbE controller has 4 ports */ +#define MAX_MVNETA_DEVS		4 + +/* Kirkwood CPU memory windows */ +#define MVCPU_WIN_CTRL_DATA	CPU_WIN_CTRL_DATA +#define MVCPU_WIN_ENABLE	CPU_WIN_ENABLE +#define MVCPU_WIN_DISABLE	CPU_WIN_DISABLE + +#endif /* _ASM_ARCH_ARMADA_XP_H */ diff --git a/arch/arm/include/asm/arch-bcm2835/mbox.h b/arch/arm/include/asm/arch-bcm2835/mbox.h index dded857c3ad..61f427d914c 100644 --- a/arch/arm/include/asm/arch-bcm2835/mbox.h +++ b/arch/arm/include/asm/arch-bcm2835/mbox.h @@ -119,6 +119,20 @@ struct bcm2835_mbox_tag_hdr {   * };   */ +#define BCM2835_MBOX_TAG_GET_MAC_ADDRESS	0x00010003 + +struct bcm2835_mbox_tag_get_mac_address { +	struct bcm2835_mbox_tag_hdr tag_hdr; +	union { +		struct { +		} req; +		struct { +			u8 mac[6]; +			u8 pad[2]; +		} resp; +	} body; +}; +  #define BCM2835_MBOX_TAG_GET_ARM_MEMORY		0x00010005  struct bcm2835_mbox_tag_get_arm_mem { diff --git a/arch/arm/include/asm/arch-kirkwood/config.h b/arch/arm/include/asm/arch-kirkwood/config.h index f7bfa0e74d7..ccc8e4e7d64 100644 --- a/arch/arm/include/asm/arch-kirkwood/config.h +++ b/arch/arm/include/asm/arch-kirkwood/config.h @@ -23,7 +23,7 @@  #error "SOC Name not defined"  #endif /* CONFIG_KW88F6281 */ -#include <asm/arch/kirkwood.h> +#include <asm/arch/soc.h>  #define CONFIG_ARM926EJS	1	/* Basic Architecture */  #define CONFIG_SYS_CACHELINE_SIZE	32  				/* default Dcache Line length for kirkwood */ diff --git a/arch/arm/include/asm/arch-kirkwood/cpu.h b/arch/arm/include/asm/arch-kirkwood/cpu.h index 97daa403ce7..926d347110f 100644 --- a/arch/arm/include/asm/arch-kirkwood/cpu.h +++ b/arch/arm/include/asm/arch-kirkwood/cpu.h @@ -140,11 +140,11 @@ struct kwgpio_registers {   * functions   */  unsigned char get_random_hex(void); -unsigned int kw_sdram_bar(enum memory_bank bank); -unsigned int kw_sdram_bs(enum memory_bank bank); -void kw_sdram_size_adjust(enum memory_bank bank); +unsigned int mvebu_sdram_bar(enum memory_bank bank); +unsigned int mvebu_sdram_bs(enum memory_bank bank); +void mvebu_sdram_size_adjust(enum memory_bank bank);  int kw_config_adr_windows(void); -void kw_config_gpio(unsigned int gpp0_oe_val, unsigned int gpp1_oe_val, +void mvebu_config_gpio(unsigned int gpp0_oe_val, unsigned int gpp1_oe_val,  		unsigned int gpp0_oe, unsigned int gpp1_oe);  int kw_config_mpp(unsigned int mpp0_7, unsigned int mpp8_15,  		unsigned int mpp16_23, unsigned int mpp24_31, diff --git a/arch/arm/include/asm/arch-kirkwood/gpio.h b/arch/arm/include/asm/arch-kirkwood/gpio.h index 5f4d7860855..aa8c5da36d3 100644 --- a/arch/arm/include/asm/arch-kirkwood/gpio.h +++ b/arch/arm/include/asm/arch-kirkwood/gpio.h @@ -21,14 +21,14 @@  #define GPIO_MAX		50  #define GPIO_OFF(pin)		(((pin) >> 5) ? 0x0040 : 0x0000) -#define GPIO_OUT(pin)		(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x00) -#define GPIO_IO_CONF(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x04) -#define GPIO_BLINK_EN(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x08) -#define GPIO_IN_POL(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x0c) -#define GPIO_DATA_IN(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x10) -#define GPIO_EDGE_CAUSE(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x14) -#define GPIO_EDGE_MASK(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x18) -#define GPIO_LEVEL_MASK(pin)	(KW_GPIO0_BASE + GPIO_OFF(pin) + 0x1c) +#define GPIO_OUT(pin)		(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x00) +#define GPIO_IO_CONF(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x04) +#define GPIO_BLINK_EN(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x08) +#define GPIO_IN_POL(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x0c) +#define GPIO_DATA_IN(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x10) +#define GPIO_EDGE_CAUSE(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x14) +#define GPIO_EDGE_MASK(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x18) +#define GPIO_LEVEL_MASK(pin)	(MVEBU_GPIO0_BASE + GPIO_OFF(pin) + 0x1c)  /*   * Kirkwood-specific GPIO API diff --git a/arch/arm/include/asm/arch-kirkwood/kirkwood.h b/arch/arm/include/asm/arch-kirkwood/soc.h index 3ea51d7848c..58ed71b1864 100644 --- a/arch/arm/include/asm/arch-kirkwood/kirkwood.h +++ b/arch/arm/include/asm/arch-kirkwood/soc.h @@ -22,18 +22,19 @@  #define KW_REG_UNDOC_0x1470		(KW_REGISTER(0x1470))  #define KW_REG_UNDOC_0x1478		(KW_REGISTER(0x1478)) +#define MVEBU_SDRAM_BASE		(KW_REGISTER(0x1500))  #define KW_TWSI_BASE			(KW_REGISTER(0x11000))  #define KW_UART0_BASE			(KW_REGISTER(0x12000))  #define KW_UART1_BASE			(KW_REGISTER(0x12100))  #define KW_MPP_BASE			(KW_REGISTER(0x10000)) -#define KW_GPIO0_BASE			(KW_REGISTER(0x10100)) -#define KW_GPIO1_BASE			(KW_REGISTER(0x10140)) +#define MVEBU_GPIO0_BASE			(KW_REGISTER(0x10100)) +#define MVEBU_GPIO1_BASE			(KW_REGISTER(0x10140))  #define KW_RTC_BASE			(KW_REGISTER(0x10300))  #define KW_NANDF_BASE			(KW_REGISTER(0x10418)) -#define KW_SPI_BASE			(KW_REGISTER(0x10600)) +#define MVEBU_SPI_BASE			(KW_REGISTER(0x10600))  #define KW_CPU_WIN_BASE			(KW_REGISTER(0x20000))  #define KW_CPU_REG_BASE			(KW_REGISTER(0x20100)) -#define KW_TIMER_BASE			(KW_REGISTER(0x20300)) +#define MVEBU_TIMER_BASE			(KW_REGISTER(0x20300))  #define KW_REG_PCIE_BASE		(KW_REGISTER(0x40000))  #define KW_USB20_BASE			(KW_REGISTER(0x50000))  #define KW_EGIGA0_BASE			(KW_REGISTER(0x72000)) diff --git a/arch/arm/include/asm/arch-kirkwood/spi.h b/arch/arm/include/asm/arch-mvebu/spi.h index e512dcec162..e512dcec162 100644 --- a/arch/arm/include/asm/arch-kirkwood/spi.h +++ b/arch/arm/include/asm/arch-mvebu/spi.h diff --git a/arch/arm/include/asm/arch-mxs/sys_proto.h b/arch/arm/include/asm/arch-mxs/sys_proto.h index 09dfc90a9b0..062f3de1d05 100644 --- a/arch/arm/include/asm/arch-mxs/sys_proto.h +++ b/arch/arm/include/asm/arch-mxs/sys_proto.h @@ -10,6 +10,8 @@  #ifndef __SYS_PROTO_H__  #define __SYS_PROTO_H__ +#include <asm/imx-common/regs-common.h> +  int mxs_reset_block(struct mxs_register_32 *reg);  int mxs_wait_mask_set(struct mxs_register_32 *reg,  		       uint32_t mask, diff --git a/arch/arm/include/asm/arch-omap3/sys_proto.h b/arch/arm/include/asm/arch-omap3/sys_proto.h index 5866bf23e8d..34bd8c509aa 100644 --- a/arch/arm/include/asm/arch-omap3/sys_proto.h +++ b/arch/arm/include/asm/arch-omap3/sys_proto.h @@ -64,6 +64,7 @@ void try_unlock_memory(void);  u32 get_boot_type(void);  void invalidate_dcache(u32);  u32 wait_on_value(u32, u32, void *, u32); +void cancel_out(u32 *num, u32 *den, u32 den_limit);  void sdelay(unsigned long);  void make_cs1_contiguous(void);  void omap_nand_switch_ecc(uint32_t, uint32_t); diff --git a/arch/arm/include/asm/arch-socfpga/spl.h b/arch/arm/include/asm/arch-socfpga/spl.h deleted file mode 100644 index 7e310d5a0c9..00000000000 --- a/arch/arm/include/asm/arch-socfpga/spl.h +++ /dev/null @@ -1,15 +0,0 @@ -/* - *  Copyright (C) 2012 Pavel Machek <pavel@denx.de> - * - * SPDX-License-Identifier:	GPL-2.0+ - */ - -#ifndef _SOCFPGA_SPL_H_ -#define _SOCFPGA_SPL_H_ - -/* Symbols from linker script */ -extern char __malloc_start, __malloc_end, __stack_start; - -#define BOOT_DEVICE_RAM 1 - -#endif diff --git a/arch/arm/include/asm/arch-sunxi/clock.h b/arch/arm/include/asm/arch-sunxi/clock.h index 5669f392fab..c562f621c22 100644 --- a/arch/arm/include/asm/arch-sunxi/clock.h +++ b/arch/arm/include/asm/arch-sunxi/clock.h @@ -15,12 +15,17 @@  #define CLK_GATE_CLOSE			0x0  /* clock control module regs definition */ +#if defined(CONFIG_SUN6I) || defined(CONFIG_SUN8I) +#include <asm/arch/clock_sun6i.h> +#else  #include <asm/arch/clock_sun4i.h> +#endif  #ifndef __ASSEMBLY__  int clock_init(void);  int clock_twi_onoff(int port, int state);  void clock_set_pll1(unsigned int hz); +unsigned int clock_get_pll5p(void);  unsigned int clock_get_pll6(void);  void clock_init_safe(void);  void clock_init_uart(void); diff --git a/arch/arm/include/asm/arch-sunxi/clock_sun4i.h b/arch/arm/include/asm/arch-sunxi/clock_sun4i.h index 1ba997adf9f..90af8e25069 100644 --- a/arch/arm/include/asm/arch-sunxi/clock_sun4i.h +++ b/arch/arm/include/asm/arch-sunxi/clock_sun4i.h @@ -199,13 +199,16 @@ struct sunxi_ccm_reg {  #define CCM_PLL5_CTRL_M1_MASK CCM_PLL5_CTRL_M1(0x3)  #define CCM_PLL5_CTRL_M1_X(n) ((n) - 1)  #define CCM_PLL5_CTRL_K(n) (((n) & 0x3) << 4) +#define CCM_PLL5_CTRL_K_SHIFT 4  #define CCM_PLL5_CTRL_K_MASK CCM_PLL5_CTRL_K(0x3)  #define CCM_PLL5_CTRL_K_X(n) ((n) - 1)  #define CCM_PLL5_CTRL_LDO (0x1 << 7)  #define CCM_PLL5_CTRL_N(n) (((n) & 0x1f) << 8) +#define CCM_PLL5_CTRL_N_SHIFT 8  #define CCM_PLL5_CTRL_N_MASK CCM_PLL5_CTRL_N(0x1f)  #define CCM_PLL5_CTRL_N_X(n) (n)  #define CCM_PLL5_CTRL_P(n) (((n) & 0x3) << 16) +#define CCM_PLL5_CTRL_P_SHIFT 16  #define CCM_PLL5_CTRL_P_MASK CCM_PLL5_CTRL_P(0x3)  #define CCM_PLL5_CTRL_P_X(n) ((n) - 1)  #define CCM_PLL5_CTRL_BW (0x1 << 18) diff --git a/arch/arm/include/asm/arch-sunxi/clock_sun6i.h b/arch/arm/include/asm/arch-sunxi/clock_sun6i.h new file mode 100644 index 00000000000..1397b358898 --- /dev/null +++ b/arch/arm/include/asm/arch-sunxi/clock_sun6i.h @@ -0,0 +1,205 @@ +/* + * sun6i clock register definitions + * + * (C) Copyright 2007-2011 + * Allwinner Technology Co., Ltd. <www.allwinnertech.com> + * Tom Cubie <tangliang@allwinnertech.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _SUNXI_CLOCK_SUN6I_H +#define _SUNXI_CLOCK_SUN6I_H + +struct sunxi_ccm_reg { +	u32 pll1_cfg;		/* 0x00 pll1 control */ +	u32 reserved0; +	u32 pll2_cfg;		/* 0x08 pll2 control */ +	u32 reserved1; +	u32 pll3_cfg;		/* 0x10 pll3 control */ +	u32 reserved2; +	u32 pll4_cfg;		/* 0x18 pll4 control */ +	u32 reserved3; +	u32 pll5_cfg;		/* 0x20 pll5 control */ +	u32 reserved4; +	u32 pll6_cfg;		/* 0x28 pll6 control */ +	u32 reserved5; +	u32 pll7_cfg;		/* 0x30 pll7 control */ +	u32 reserved6; +	u32 pll8_cfg;		/* 0x38 pll8 control */ +	u32 reserved7; +	u32 mipi_pll_cfg;	/* 0x40 MIPI pll control */ +	u32 pll9_cfg;		/* 0x44 pll9 control */ +	u32 pll10_cfg;		/* 0x48 pll10 control */ +	u32 reserved8; +	u32 cpu_axi_cfg;	/* 0x50 CPU/AXI divide ratio */ +	u32 ahb1_apb1_div;	/* 0x54 AHB1/APB1 divide ratio */ +	u32 apb2_div;		/* 0x58 APB2 divide ratio */ +	u32 axi_gate;		/* 0x5c axi module clock gating */ +	u32 ahb_gate0;		/* 0x60 ahb module clock gating 0 */ +	u32 ahb_gate1;		/* 0x64 ahb module clock gating 1 */ +	u32 apb1_gate;		/* 0x68 apb1 module clock gating */ +	u32 apb2_gate;		/* 0x6c apb2 module clock gating */ +	u32 reserved9[4]; +	u32 nand0_clk_cfg;	/* 0x80 nand0 clock control */ +	u32 nand1_clk_cfg;	/* 0x84 nand1 clock control */ +	u32 sd0_clk_cfg;	/* 0x88 sd0 clock control */ +	u32 sd1_clk_cfg;	/* 0x8c sd1 clock control */ +	u32 sd2_clk_cfg;	/* 0x90 sd2 clock control */ +	u32 sd3_clk_cfg;	/* 0x94 sd3 clock control */ +	u32 ts_clk_cfg;		/* 0x98 transport stream clock control */ +	u32 ss_clk_cfg;		/* 0x9c security system clock control */ +	u32 spi0_clk_cfg;	/* 0xa0 spi0 clock control */ +	u32 spi1_clk_cfg;	/* 0xa4 spi1 clock control */ +	u32 spi2_clk_cfg;	/* 0xa8 spi2 clock control */ +	u32 spi3_clk_cfg;	/* 0xac spi3 clock control */ +	u32 i2s0_clk_cfg;	/* 0xb0 I2S0 clock control*/ +	u32 i2s1_clk_cfg;	/* 0xb4 I2S1 clock control */ +	u32 reserved10[2]; +	u32 spdif_clk_cfg;	/* 0xc0 SPDIF clock control */ +	u32 reserved11[2]; +	u32 usb_clk_cfg;	/* 0xcc USB clock control */ +	u32 gmac_clk_cfg;	/* 0xd0 GMAC clock control */ +	u32 reserved12[7]; +	u32 mdfs_clk_cfg;	/* 0xf0 MDFS clock control */ +	u32 dram_clk_cfg;	/* 0xf4 DRAM configuration clock control */ +	u32 reserved13[2]; +	u32 dram_clk_gate;	/* 0x100 DRAM module gating */ +	u32 be0_clk_cfg;	/* 0x104 BE0 module clock */ +	u32 be1_clk_cfg;	/* 0x108 BE1 module clock */ +	u32 fe0_clk_cfg;	/* 0x10c FE0 module clock */ +	u32 fe1_clk_cfg;	/* 0x110 FE1 module clock */ +	u32 mp_clk_cfg;		/* 0x114 MP module clock */ +	u32 lcd0_ch0_clk_cfg;	/* 0x118 LCD0 CH0 module clock */ +	u32 lcd1_ch0_clk_cfg;	/* 0x11c LCD1 CH0 module clock */ +	u32 reserved14[3]; +	u32 lcd0_ch1_clk_cfg;	/* 0x12c LCD0 CH1 module clock */ +	u32 lcd1_ch1_clk_cfg;	/* 0x130 LCD1 CH1 module clock */ +	u32 csi0_clk_cfg;	/* 0x134 CSI0 module clock */ +	u32 csi1_clk_cfg;	/* 0x138 CSI1 module clock */ +	u32 ve_clk_cfg;		/* 0x13c VE module clock */ +	u32 adda_clk_cfg;	/* 0x140 ADDA module clock */ +	u32 avs_clk_cfg;	/* 0x144 AVS module clock */ +	u32 dmic_clk_cfg;	/* 0x148 Digital Mic module clock*/ +	u32 reserved15; +	u32 hdmi_clk_cfg;	/* 0x150 HDMI module clock */ +	u32 ps_clk_cfg;		/* 0x154 PS module clock */ +	u32 mtc_clk_cfg;	/* 0x158 MTC module clock */ +	u32 mbus0_clk_cfg;	/* 0x15c MBUS0 module clock */ +	u32 mbus1_clk_cfg;	/* 0x160 MBUS1 module clock */ +	u32 reserved16; +	u32 mipi_dsi_clk_cfg;	/* 0x168 MIPI DSI clock control */ +	u32 mipi_csi_clk_cfg;	/* 0x16c MIPI CSI clock control */ +	u32 reserved17[4]; +	u32 iep_drc0_clk_cfg;	/* 0x180 IEP DRC0 module clock */ +	u32 iep_drc1_clk_cfg;	/* 0x184 IEP DRC1 module clock */ +	u32 iep_deu0_clk_cfg;	/* 0x188 IEP DEU0 module clock */ +	u32 iep_deu1_clk_cfg;	/* 0x18c IEP DEU1 module clock */ +	u32 reserved18[4]; +	u32 gpu_core_clk_cfg;	/* 0x1a0 GPU core clock config */ +	u32 gpu_mem_clk_cfg;	/* 0x1a4 GPU memory clock config */ +	u32 gpu_hyd_clk_cfg;	/* 0x1a0 GPU HYD clock config */ +	u32 reserved19[21]; +	u32 pll_lock;		/* 0x200 PLL Lock Time */ +	u32 pll1_lock;		/* 0x204 PLL1 Lock Time */ +	u32 reserved20[6]; +	u32 pll1_bias_cfg;	/* 0x220 PLL1 Bias config */ +	u32 pll2_bias_cfg;	/* 0x224 PLL2 Bias config */ +	u32 pll3_bias_cfg;	/* 0x228 PLL3 Bias config */ +	u32 pll4_bias_cfg;	/* 0x22c PLL4 Bias config */ +	u32 pll5_bias_cfg;	/* 0x230 PLL5 Bias config */ +	u32 pll6_bias_cfg;	/* 0x234 PLL6 Bias config */ +	u32 pll7_bias_cfg;	/* 0x238 PLL7 Bias config */ +	u32 pll8_bias_cfg;	/* 0x23c PLL8 Bias config */ +	u32 mipi_bias_cfg;	/* 0x240 MIPI Bias config */ +	u32 pll9_bias_cfg;	/* 0x244 PLL9 Bias config */ +	u32 pll10_bias_cfg;	/* 0x248 PLL10 Bias config */ +	u32 reserved21[13]; +	u32 pll1_pattern_cfg;	/* 0x280 PLL1 Pattern config */ +	u32 pll2_pattern_cfg;	/* 0x284 PLL2 Pattern config */ +	u32 pll3_pattern_cfg;	/* 0x288 PLL3 Pattern config */ +	u32 pll4_pattern_cfg;	/* 0x28c PLL4 Pattern config */ +	u32 pll5_pattern_cfg;	/* 0x290 PLL5 Pattern config */ +	u32 pll6_pattern_cfg;	/* 0x294 PLL6 Pattern config */ +	u32 pll7_pattern_cfg;	/* 0x298 PLL7 Pattern config */ +	u32 pll8_pattern_cfg;	/* 0x29c PLL8 Pattern config */ +	u32 mipi_pattern_cfg;	/* 0x2a0 MIPI Pattern config */ +	u32 pll9_pattern_cfg;	/* 0x2a4 PLL9 Pattern config */ +	u32 pll10_pattern_cfg;	/* 0x2a8 PLL10 Pattern config */ +	u32 reserved22[5]; +	u32 ahb_reset0_cfg;	/* 0x2c0 AHB1 Reset 0 config */ +	u32 ahb_reset1_cfg;	/* 0x2c4 AHB1 Reset 1 config */ +	u32 ahb_reset2_cfg;	/* 0x2c8 AHB1 Reset 2 config */ +	u32 reserved23; +	u32 apb1_reset_cfg;	/* 0x2d0 APB1 Reset config */ +	u32 reserved24; +	u32 apb2_reset_cfg;	/* 0x2d8 APB2 Reset config */ +}; + +/* apb2 bit field */ +#define APB2_CLK_SRC_LOSC		(0x0 << 24) +#define APB2_CLK_SRC_OSC24M		(0x1 << 24) +#define APB2_CLK_SRC_PLL6		(0x2 << 24) +#define APB2_CLK_SRC_MASK		(0x3 << 24) +#define APB2_CLK_RATE_N_1		(0x0 << 16) +#define APB2_CLK_RATE_N_2		(0x1 << 16) +#define APB2_CLK_RATE_N_4		(0x2 << 16) +#define APB2_CLK_RATE_N_8		(0x3 << 16) +#define APB2_CLK_RATE_N_MASK		(3 << 16) +#define APB2_CLK_RATE_M(m)		(((m)-1) << 0) +#define APB2_CLK_RATE_M_MASK            (0x1f << 0) + +/* apb2 gate field */ +#define APB2_GATE_UART_SHIFT	(16) +#define APB2_GATE_UART_MASK		(0xff << APB2_GATE_UART_SHIFT) +#define APB2_GATE_TWI_SHIFT	(0) +#define APB2_GATE_TWI_MASK		(0xf << APB2_GATE_TWI_SHIFT) + +/* cpu_axi_cfg bits */ +#define AXI_DIV_SHIFT			0 +#define ATB_DIV_SHIFT			8 +#define CPU_CLK_SRC_SHIFT		16 + +#define AXI_DIV_1			0 +#define AXI_DIV_2			1 +#define AXI_DIV_3			2 +#define AXI_DIV_4			3 +#define ATB_DIV_1			0 +#define ATB_DIV_2			1 +#define ATB_DIV_4			2 +#define CPU_CLK_SRC_OSC24M		1 +#define CPU_CLK_SRC_PLL1		2 + +#define PLL1_CFG_DEFAULT		0x90011b21 + +#define PLL6_CFG_DEFAULT		0x90041811 + +#define CCM_PLL6_CTRL_N_SHIFT		8 +#define CCM_PLL6_CTRL_N_MASK		(0x1f << CCM_PLL6_CTRL_N_SHIFT) +#define CCM_PLL6_CTRL_K_SHIFT		4 +#define CCM_PLL6_CTRL_K_MASK		(0x3 << CCM_PLL6_CTRL_K_SHIFT) + +#define AHB_GATE_OFFSET_MMC3		11 +#define AHB_GATE_OFFSET_MMC2		10 +#define AHB_GATE_OFFSET_MMC1		9 +#define AHB_GATE_OFFSET_MMC0		8 +#define AHB_GATE_OFFSET_MMC(n)		(AHB_GATE_OFFSET_MMC0 + (n)) + +#define CCM_MMC_CTRL_OSCM24 (0x0 << 24) +#define CCM_MMC_CTRL_PLL6   (0x1 << 24) + +#define CCM_MMC_CTRL_ENABLE (0x1 << 31) + +#define AHB_RESET_OFFSET_MMC3		11 +#define AHB_RESET_OFFSET_MMC2		10 +#define AHB_RESET_OFFSET_MMC1		9 +#define AHB_RESET_OFFSET_MMC0		8 +#define AHB_RESET_OFFSET_MMC(n)		(AHB_RESET_OFFSET_MMC0 + (n)) + +/* apb2 reset */ +#define APB2_RESET_UART_SHIFT		(16) +#define APB2_RESET_UART_MASK		(0xff << APB2_RESET_UART_SHIFT) +#define APB2_RESET_TWI_SHIFT		(0) +#define APB2_RESET_TWI_MASK		(0xf << APB2_RESET_TWI_SHIFT) + +#endif /* _SUNXI_CLOCK_SUN6I_H */ diff --git a/arch/arm/include/asm/arch-sunxi/cpu.h b/arch/arm/include/asm/arch-sunxi/cpu.h index a987e51d576..0de79a0d508 100644 --- a/arch/arm/include/asm/arch-sunxi/cpu.h +++ b/arch/arm/include/asm/arch-sunxi/cpu.h @@ -95,6 +95,11 @@  #define SUNXI_MALI400_BASE		0x01c40000  #define SUNXI_GMAC_BASE			0x01c50000 +#define SUNXI_DRAM_COM_BASE		0x01c62000 +#define SUNXI_DRAM_CTL_BASE		0x01c63000 +#define SUNXI_DRAM_PHY_CH1_BASE		0x01c65000 +#define SUNXI_DRAM_PHY_CH2_BASE		0x01c66000 +  /* module sram */  #define SUNXI_SRAM_C_BASE		0x01d00000 @@ -105,6 +110,11 @@  #define SUNXI_MP_BASE			0x01e80000  #define SUNXI_AVG_BASE			0x01ea0000 +#define SUNXI_PRCM_BASE			0x01f01400 +#define SUNXI_R_UART_BASE		0x01f02800 +#define SUNXI_R_PIO_BASE		0x01f02c00 +#define SUNXI_P2WI_BASE			0x01f03400 +  /* CoreSight Debug Module */  #define SUNXI_CSDM_BASE			0x3f500000 diff --git a/arch/arm/include/asm/arch-sunxi/gpio.h b/arch/arm/include/asm/arch-sunxi/gpio.h index f7f3d8c41ad..7bb649950a9 100644 --- a/arch/arm/include/asm/arch-sunxi/gpio.h +++ b/arch/arm/include/asm/arch-sunxi/gpio.h @@ -10,6 +10,7 @@  #define _SUNXI_GPIO_H  #include <linux/types.h> +#include <asm/arch/cpu.h>  /*   * sunxi has 9 banks of gpio, they are: @@ -27,8 +28,27 @@  #define SUNXI_GPIO_G	6  #define SUNXI_GPIO_H	7  #define SUNXI_GPIO_I	8 + +/* + * This defines the number of GPIO banks for the _main_ GPIO controller. + * You should fix up the padding in struct sunxi_gpio_reg below if you + * change this. + */  #define SUNXI_GPIO_BANKS 9 +/* + * sun6i/sun8i and later SoCs have an additional GPIO controller (R_PIO) + * at a different register offset. + * + * sun6i has 2 banks: + * PL0 - PL8  | PM0 - PM7 + * + * sun8i has 1 bank: + * PL0 - PL11 + */ +#define SUNXI_GPIO_L	11 +#define SUNXI_GPIO_M	12 +  struct sunxi_gpio {  	u32 cfg[4];  	u32 dat; @@ -50,8 +70,9 @@ struct sunxi_gpio_reg {  	struct sunxi_gpio_int gpio_int;  }; -#define BANK_TO_GPIO(bank) \ -	&((struct sunxi_gpio_reg *)SUNXI_PIO_BASE)->gpio_bank[bank] +#define BANK_TO_GPIO(bank)	(((bank) < SUNXI_GPIO_L) ? \ +	&((struct sunxi_gpio_reg *)SUNXI_PIO_BASE)->gpio_bank[bank] : \ +	&((struct sunxi_gpio_reg *)SUNXI_R_PIO_BASE)->gpio_bank[(bank) - SUNXI_GPIO_L])  #define GPIO_BANK(pin)		((pin) >> 5)  #define GPIO_NUM(pin)		((pin) & 0x1f) @@ -75,6 +96,8 @@ struct sunxi_gpio_reg {  #define SUNXI_GPIO_G_NR		32  #define SUNXI_GPIO_H_NR		32  #define SUNXI_GPIO_I_NR		32 +#define SUNXI_GPIO_L_NR		32 +#define SUNXI_GPIO_M_NR		32  #define SUNXI_GPIO_NEXT(__gpio) \  	((__gpio##_START) + (__gpio##_NR) + 0) @@ -89,6 +112,8 @@ enum sunxi_gpio_number {  	SUNXI_GPIO_G_START = SUNXI_GPIO_NEXT(SUNXI_GPIO_F),  	SUNXI_GPIO_H_START = SUNXI_GPIO_NEXT(SUNXI_GPIO_G),  	SUNXI_GPIO_I_START = SUNXI_GPIO_NEXT(SUNXI_GPIO_H), +	SUNXI_GPIO_L_START = 352, +	SUNXI_GPIO_M_START = SUNXI_GPIO_NEXT(SUNXI_GPIO_L),  };  /* SUNXI GPIO number definitions */ @@ -101,6 +126,8 @@ enum sunxi_gpio_number {  #define SUNXI_GPG(_nr)	(SUNXI_GPIO_G_START + (_nr))  #define SUNXI_GPH(_nr)	(SUNXI_GPIO_H_START + (_nr))  #define SUNXI_GPI(_nr)	(SUNXI_GPIO_I_START + (_nr)) +#define SUNXI_GPL(_nr)	(SUNXI_GPIO_L_START + (_nr)) +#define SUNXI_GPM(_nr)	(SUNXI_GPIO_M_START + (_nr))  /* GPIO pin function config */  #define SUNXI_GPIO_INPUT	0 @@ -117,6 +144,8 @@ enum sunxi_gpio_number {  #define SUN5I_GPB19_UART0_TX	2  #define SUN5I_GPB20_UART0_RX	2 +#define SUN5I_GPG3_SDC1		2 +  #define SUN5I_GPG3_UART1_TX	4  #define SUN5I_GPG4_UART1_RX	4 @@ -125,15 +154,27 @@ enum sunxi_gpio_number {  #define SUNXI_GPF0_SDC0		2  #define SUNXI_GPF2_SDC0		2 + +#ifdef CONFIG_SUN8I +#define SUNXI_GPF2_UART0_TX	3 +#define SUNXI_GPF4_UART0_RX	3 +#else  #define SUNXI_GPF2_UART0_TX	4  #define SUNXI_GPF4_UART0_RX	4 +#endif  #define SUN4I_GPG0_SDC1		4  #define SUN4I_GPH22_SDC1	5 +#define SUN6I_GPH20_UART0_TX	2 +#define SUN6I_GPH21_UART0_RX	2 +  #define SUN4I_GPI4_SDC3		2 +#define SUN8I_GPL2_R_UART_TX	2 +#define SUN8I_GPL3_R_UART_RX	2 +  /* GPIO pin pull-up/down config */  #define SUNXI_GPIO_PULL_DISABLE	0  #define SUNXI_GPIO_PULL_UP	1 diff --git a/arch/arm/include/asm/arch-sunxi/mmc.h b/arch/arm/include/asm/arch-sunxi/mmc.h index 53196e3b024..8a216740a72 100644 --- a/arch/arm/include/asm/arch-sunxi/mmc.h +++ b/arch/arm/include/asm/arch-sunxi/mmc.h @@ -43,7 +43,10 @@ struct sunxi_mmc {  	u32 chda;		/* 0x90 */  	u32 cbda;		/* 0x94 */  	u32 res1[26]; -	u32 fifo;		/* 0x100 FIFO access address */ +#if defined(CONFIG_SUN6I) || defined(CONFIG_SUN8I) +	u32 res2[64]; +#endif +	u32 fifo;		/* 0x100 (0x200 on sun6i) FIFO access address */  };  #define SUNXI_MMC_CLK_POWERSAVE		(0x1 << 17) @@ -120,5 +123,5 @@ struct sunxi_mmc {  #define SUNXI_MMC_IDIE_TXIRQ		(0x1 << 0)  #define SUNXI_MMC_IDIE_RXIRQ		(0x1 << 1) -int sunxi_mmc_init(int sdc_no); +struct mmc *sunxi_mmc_init(int sdc_no);  #endif /* _SUNXI_MMC_H */ diff --git a/arch/arm/include/asm/arch-sunxi/prcm.h b/arch/arm/include/asm/arch-sunxi/prcm.h new file mode 100644 index 00000000000..3d3bfa6cd1b --- /dev/null +++ b/arch/arm/include/asm/arch-sunxi/prcm.h @@ -0,0 +1,238 @@ +/* + * Sunxi A31 Power Management Unit register definition. + * + * (C) Copyright 2013 Oliver Schinagl <oliver@schinagl.nl> + * http://linux-sunxi.org + * Allwinner Technology Co., Ltd. <www.allwinnertech.com> + * Berg Xing <bergxing@allwinnertech.com> + * Tom Cubie <tangliang@allwinnertech.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _SUNXI_PRCM_H +#define _SUNXI_PRCM_H + +#define __PRCM_CPUS_CFG_PRE(n) (((n) & 0x3) << 4) +#define PRCM_CPUS_CFG_PRE_MASK __PRCM_CPUS_CFG_PRE(0x3) +#define __PRCM_CPUS_CFG_PRE_DIV(n) (((n) >> 1) - 1) +#define PRCM_CPUS_CFG_PRE_DIV(n) \ +	__PRCM_CPUS_CFG_PRE(__PRCM_CPUS_CFG_CLK_PRE(n)) +#define __PRCM_CPUS_CFG_POST(n) (((n) & 0x1f) << 8) +#define PRCM_CPUS_CFG_POST_MASK __PRCM_CPUS_CFG_POST(0x1f) +#define __PRCM_CPUS_CFG_POST_DIV(n) ((n) - 1) +#define PRCM_CPUS_CFG_POST_DIV(n) \ +	__PRCM_CPUS_CFG_POST_DIV(__PRCM_CPUS_CFG_POST_DIV(n)) +#define __PRCM_CPUS_CFG_CLK_SRC(n) (((n) & 0x3) << 16) +#define PRCM_CPUS_CFG_CLK_SRC_MASK __PRCM_CPUS_CFG_CLK_SRC(0x3) +#define __PRCM_CPUS_CFG_CLK_SRC_LOSC 0x0 +#define __PRCM_CPUS_CFG_CLK_SRC_HOSC 0x1 +#define __PRCM_CPUS_CFG_CLK_SRC_PLL6 0x2 +#define __PRCM_CPUS_CFG_CLK_SRC_PDIV 0x3 +#define PRCM_CPUS_CFG_CLK_SRC_LOSC \ +	__PRCM_CPUS_CFG_CLK_SRC(__PRCM_CPUS_CFG_CLK_SRC_LOSC) +#define PRCM_CPUS_CFG_CLK_SRC_HOSC \ +	__PRCM_CPUS_CFG_CLK_SRC(__PRCM_CPUS_CFG_CLK_SRC_HOSC) +#define PRCM_CPUS_CFG_CLK_SRC_PLL6 \ +	__PRCM_CPUS_CFG_CLK_SRC(__PRCM_CPUS_CFG_CLK_SRC_PLL6) +#define PRCM_CPUS_CFG_CLK_SRC_PDIV \ +	__PRCM_CPUS_CFG_CLK_SRC(__PRCM_CPUS_CFG_CLK_SRC_PDIV) + +#define __PRCM_APB0_RATIO(n) (((n) & 0x3) << 0) +#define PRCM_APB0_RATIO_DIV_MASK __PRCM_APB0_RATIO_DIV(0x3) +#define __PRCM_APB0_RATIO_DIV(n) (((n) >> 1) - 1) +#define PRCM_APB0_RATIO_DIV(n) \ +	__PRCM_APB0_RATIO(__PRCM_APB0_RATIO_DIV(n)) + +#define PRCM_CPU_CFG_NEON_CLK_EN (0x1 << 0) +#define PRCM_CPU_CFG_CPU_CLK_EN (0x1 << 1) + +#define PRCM_APB0_GATE_PIO (0x1 << 0) +#define PRCM_APB0_GATE_IR (0x1 << 1) +#define PRCM_APB0_GATE_TIMER01 (0x1 << 2) +#define PRCM_APB0_GATE_P2WI (0x1 << 3) +#define PRCM_APB0_GATE_UART (0x1 << 4) +#define PRCM_APB0_GATE_1WIRE (0x1 << 5) +#define PRCM_APB0_GATE_I2C (0x1 << 6) + +#define PRCM_APB0_RESET_PIO (0x1 << 0) +#define PRCM_APB0_RESET_IR (0x1 << 1) +#define PRCM_APB0_RESET_TIMER01 (0x1 << 2) +#define PRCM_APB0_RESET_P2WI (0x1 << 3) +#define PRCM_APB0_RESET_UART (0x1 << 4) +#define PRCM_APB0_RESET_1WIRE (0x1 << 5) +#define PRCM_APB0_RESET_I2C (0x1 << 6) + +#define PRCM_PLL_CTRL_PLL_BIAS (0x1 << 0) +#define PRCM_PLL_CTRL_HOSC_GAIN_ENH (0x1 << 1) +#define __PRCM_PLL_CTRL_USB_CLK_SRC(n) (((n) & 0x3) << 4) +#define PRCM_PLL_CTRL_USB_CLK_SRC_MASK \ +	__PRCM_PLL_CTRL_USB_CLK_SRC(0x3) +#define __PRCM_PLL_CTRL_USB_CLK_0 0x0 +#define __PRCM_PLL_CTRL_USB_CLK_1 0x1 +#define __PRCM_PLL_CTRL_USB_CLK_2 0x2 +#define __PRCM_PLL_CTRL_USB_CLK_3 0x3 +#define PRCM_PLL_CTRL_USB_CLK_0 \ +	__PRCM_PLL_CTRL_USB_CLK_SRC(__PRCM_PLL_CTRL_USB_CLK_0) +#define PRCM_PLL_CTRL_USB_CLK_1 \ +	__PRCM_PLL_CTRL_USB_CLK_SRC(__PRCM_PLL_CTRL_USB_CLK_1) +#define PRCM_PLL_CTRL_USB_CLK_2 \ +	__PRCM_PLL_CTRL_USB_CLK_SRC(__PRCM_PLL_CTRL_USB_CLK_2) +#define PRCM_PLL_CTRL_USB_CLK_3 \ +	__PRCM_PLL_CTRL_USB_CLK_SRC(__PRCM_PLL_CTRL_USB_CLK_3) +#define __PRCM_PLL_CTRL_INT_PLL_IN_SEL(n) (((n) & 0x3) << 12) +#define PRCM_PLL_CTRL_INT_PLL_IN_SEL_MASK \ +	__PRCM_PLL_CTRL_INT_PLL_IN_SEL(0x3) +#define PRCM_PLL_CTRL_INT_PLL_IN_SEL(n) \ +	__PRCM_PLL_CTRL_INT_PLL_IN_SEL(n) +#define __PRCM_PLL_CTRL_HOSC_CLK_SEL(n) (((n) & 0x3) << 20) +#define PRCM_PLL_CTRL_HOSC_CLK_SEL_MASK \ +	__PRCM_PLL_CTRL_HOSC_CLK_SEL(0x3) +#define __PRCM_PLL_CTRL_HOSC_CLK_0 0x0 +#define __PRCM_PLL_CTRL_HOSC_CLK_1 0x1 +#define __PRCM_PLL_CTRL_HOSC_CLK_2 0x2 +#define __PRCM_PLL_CTRL_HOSC_CLK_3 0x3 +#define PRCM_PLL_CTRL_HOSC_CLK_0 \ +	__PRCM_PLL_CTRL_HOSC_CLK_SEL(__PRCM_PLL_CTRL_HOSC_CLK_0) +#define PRCM_PLL_CTRL_HOSC_CLK_1 \ +	__PRCM_PLL_CTRL_HOSC_CLK_SEL(__PRCM_PLL_CTRL_HOSC_CLK_1) +#define PRCM_PLL_CTRL_HOSC_CLK_2 \ +	__PRCM_PLL_CTRL_HOSC_CLK_SEL(__PRCM_PLL_CTRL_HOSC_CLK_2) +#define PRCM_PLL_CTRL_HOSC_CLK_3 \ +	__PRCM_PLL_CTRL_HOSC_CLK_SEL(__PRCM_PLL_CTRL_HOSC_CLK_3) +#define PRCM_PLL_CTRL_PLL_TST_SRC_EXT (0x1 << 24) +#define PRCM_PLL_CTRL_LDO_DIGITAL_EN (0x1 << 0) +#define PRCM_PLL_CTRL_LDO_ANALOG_EN (0x1 << 1) +#define PRCM_PLL_CTRL_EXT_OSC_EN (0x1 << 2) +#define PRCM_PLL_CTRL_CLK_TST_EN (0x1 << 3) +#define PRCM_PLL_CTRL_IN_PWR_HIGH (0x1 << 15) /* 3.3 for hi 2.5 for lo */ +#define __PRCM_PLL_CTRL_VDD_LDO_OUT(n) (((n) & 0x7) << 16) +#define PRCM_PLL_CTRL_LDO_OUT_MASK \ +	__PRCM_PLL_CTRL_LDO_OUT(0x7) +/* When using the low voltage 20 mV steps, and high voltage 30 mV steps */ +#define PRCM_PLL_CTRL_LDO_OUT_L(n) \ +	__PRCM_PLL_CTRL_VDD_LDO_OUT((((n) - 1000) / 20) & 0x7) +#define PRCM_PLL_CTRL_LDO_OUT_H(n) \ +	__PRCM_PLL_CTRL_VDD_LDO_OUT((((n) - 1160) / 30) & 0x7) +#define PRCM_PLL_CTRL_LDO_OUT_LV(n) \ +	__PRCM_PLL_CTRL_VDD_LDO_OUT((((n) & 0x7) * 20) + 1000) +#define PRCM_PLL_CTRL_LDO_OUT_HV(n) \ +	__PRCM_PLL_CTRL_VDD_LDO_OUT((((n) & 0x7) * 30) + 1160) +#define PRCM_PLL_CTRL_LDO_KEY (0xa7 << 24) + +#define PRCM_CLK_1WIRE_GATE (0x1 << 31) + +#define __PRCM_CLK_MOD0_M(n) (((n) & 0xf) << 0) +#define PRCM_CLK_MOD0_M_MASK __PRCM_CLK_MOD0_M(0xf) +#define __PRCM_CLK_MOD0_M_X(n) (n - 1) +#define PRCM_CLK_MOD0_M(n) __PRCM_CLK_MOD0_M(__PRCM_CLK_MOD0_M_X(n)) +#define PRCM_CLK_MOD0_OUT_PHASE(n) (((n) & 0x7) << 8) +#define PRCM_CLK_MOD0_OUT_PHASE_MASK(n) PRCM_CLK_MOD0_OUT_PHASE(0x7) +#define _PRCM_CLK_MOD0_N(n) (((n) & 0x3) << 16) +#define PRCM_CLK_MOD0_N_MASK __PRCM_CLK_MOD_N(0x3) +#define __PRCM_CLK_MOD0_N_X(n) (((n) >> 1) - 1) +#define PRCM_CLK_MOD0_N(n) __PRCM_CLK_MOD0_N(__PRCM_CLK_MOD0_N_X(n)) +#define PRCM_CLK_MOD0_SMPL_PHASE(n) (((n) & 0x7) << 20) +#define PRCM_CLK_MOD0_SMPL_PHASE_MASK PRCM_CLK_MOD0_SMPL_PHASE(0x7) +#define PRCM_CLK_MOD0_SRC_SEL(n) (((n) & 0x7) << 24) +#define PRCM_CLK_MOD0_SRC_SEL_MASK PRCM_CLK_MOD0_SRC_SEL(0x7) +#define PRCM_CLK_MOD0_GATE_EN (0x1 << 31) + +#define PRCM_APB0_RESET_PIO (0x1 << 0) +#define PRCM_APB0_RESET_IR (0x1 << 1) +#define PRCM_APB0_RESET_TIMER01 (0x1 << 2) +#define PRCM_APB0_RESET_P2WI (0x1 << 3) +#define PRCM_APB0_RESET_UART (0x1 << 4) +#define PRCM_APB0_RESET_1WIRE (0x1 << 5) +#define PRCM_APB0_RESET_I2C (0x1 << 6) + +#define __PRCM_CLK_OUTD_M(n) (((n) & 0x7) << 8) +#define PRCM_CLK_OUTD_M_MASK __PRCM_CLK_OUTD_M(0x7) +#define __PRCM_CLK_OUTD_M_X() ((n) - 1) +#define PRCM_CLK_OUTD_M(n) __PRCM_CLK_OUTD_M(__PRCM_CLK_OUTD_M_X(n)) +#define __PRCM_CLK_OUTD_N(n) (((n) & 0x7) << 20) +#define PRCM_CLK_OUTD_N_MASK __PRCM_CLK_OUTD_N(0x7) +#define __PRCM_CLK_OUTD_N_X(n) (((n) >> 1) - 1) +#define PRCM_CLK_OUTD_N(n) __PRCM_CLK_OUTD_N(__PRCM_CLK_OUTD_N_X(n) +#define __PRCM_CLK_OUTD_SRC_SEL(n) (((n) & 0x3) << 24) +#define PRCM_CLK_OUTD_SRC_SEL_MASK __PRCM_CLK_OUTD_SRC_SEL(0x3) +#define __PRCM_CLK_OUTD_SRC_LOSC2 0x0 +#define __PRCM_CLK_OUTD_SRC_LOSC 0x1 +#define __PRCM_CLK_OUTD_SRC_HOSC 0x2 +#define __PRCM_CLK_OUTD_SRC_ERR 0x3 +#define PRCM_CLK_OUTD_SRC_LOSC2 \ +#deifne __PRCM_CLK_OUTD_SRC_SEL(__PRCM_CLK_OUTD_SRC_LOSC2) +#define PRCM_CLK_OUTD_SRC_LOSC \ +#deifne __PRCM_CLK_OUTD_SRC_SEL(__PRCM_CLK_OUTD_SRC_LOSC) +#define PRCM_CLK_OUTD_SRC_HOSC \ +#deifne __PRCM_CLK_OUTD_SRC_SEL(__PRCM_CLK_OUTD_SRC_HOSC) +#define PRCM_CLK_OUTD_SRC_ERR \ +#deifne __PRCM_CLK_OUTD_SRC_SEL(__PRCM_CLK_OUTD_SRC_ERR) +#define PRCM_CLK_OUTD_EN (0x1 << 31) + +#define PRCM_CPU0_PWROFF (0x1 << 0) +#define PRCM_CPU1_PWROFF (0x1 << 1) +#define PRCM_CPU2_PWROFF (0x1 << 2) +#define PRCM_CPU3_PWROFF (0x1 << 3) +#define PRCM_CPU_ALL_PWROFF (0xf << 0) + +#define PRCM_VDD_SYS_DRAM_CH0_PAD_HOLD_PWROFF (0x1 << 0) +#define PRCM_VDD_SYS_DRAM_CH1_PAD_HOLD_PWROFF (0x1 << 1) +#define PRCM_VDD_SYS_AVCC_A_PWROFF (0x1 << 2) +#define PRCM_VDD_SYS_CPU0_VDD_PWROFF (0x1 << 3) + +#define PRCM_VDD_GPU_PWROFF (0x1 << 0) + +#define PRCM_VDD_SYS_RESET (0x1 << 0) + +#define PRCM_CPU1_PWR_CLAMP(n) (((n) & 0xff) << 0) +#define PRCM_CPU1_PWR_CLAMP_MASK PRCM_CPU1_PWR_CLAMP(0xff) + +#define PRCM_CPU2_PWR_CLAMP(n) (((n) & 0xff) << 0) +#define PRCM_CPU2_PWR_CLAMP_MASK PRCM_CPU2_PWR_CLAMP(0xff) + +#define PRCM_CPU3_PWR_CLAMP(n) (((n) & 0xff) << 0) +#define PRCM_CPU3_PWR_CLAMP_MASK PRCM_CPU3_PWR_CLAMP(0xff) + +#ifndef __ASSEMBLY__ +struct sunxi_prcm_reg { +	u32 cpus_cfg;		/* 0x000 */ +	u8 res0[0x8];		/* 0x004 */ +	u32 apb0_ratio;		/* 0x00c */ +	u32 cpu0_cfg;		/* 0x010 */ +	u32 cpu1_cfg;		/* 0x014 */ +	u32 cpu2_cfg;		/* 0x018 */ +	u32 cpu3_cfg;		/* 0x01c */ +	u8 res1[0x8];		/* 0x020 */ +	u32 apb0_gate;		/* 0x028 */ +	u8 res2[0x14];		/* 0x02c */ +	u32 pll_ctrl0;		/* 0x040 */ +	u32 pll_ctrl1;		/* 0x044 */ +	u8 res3[0x8];		/* 0x048 */ +	u32 clk_1wire;		/* 0x050 */ +	u32 clk_ir;		/* 0x054 */ +	u8 res4[0x58];		/* 0x058 */ +	u32 apb0_reset;		/* 0x0b0 */ +	u8 res5[0x3c];		/* 0x0b4 */ +	u32 clk_outd;		/* 0x0f0 */ +	u8 res6[0xc];		/* 0x0f4 */ +	u32 cpu_pwroff;		/* 0x100 */ +	u8 res7[0xc];		/* 0x104 */ +	u32 vdd_sys_pwroff;	/* 0x110 */ +	u8 res8[0x4];		/* 0x114 */ +	u32 gpu_pwroff;		/* 0x118 */ +	u8 res9[0x4];		/* 0x11c */ +	u32 vdd_pwr_reset;	/* 0x120 */ +	u8 res10[0x20];		/* 0x124 */ +	u32 cpu1_pwr_clamp;	/* 0x144 */ +	u32 cpu2_pwr_clamp;	/* 0x148 */ +	u32 cpu3_pwr_clamp;	/* 0x14c */ +	u8 res11[0x30];		/* 0x150 */ +	u32 dram_pwr;		/* 0x180 */ +	u8 res12[0xc];		/* 0x184 */ +	u32 dram_tst;		/* 0x190 */ +}; + +void prcm_apb0_enable(u32 flags); +#endif /* __ASSEMBLY__ */ +#endif /* _PRCM_H */ diff --git a/arch/arm/include/asm/arch-sunxi/timer.h b/arch/arm/include/asm/arch-sunxi/timer.h index 58e14fd0f71..03a0684c797 100644 --- a/arch/arm/include/asm/arch-sunxi/timer.h +++ b/arch/arm/include/asm/arch-sunxi/timer.h @@ -11,14 +11,10 @@  #ifndef _SUNXI_TIMER_H_  #define _SUNXI_TIMER_H_ -#define WDT_CTRL_RESTART	(0x1 << 0) -#define WDT_CTRL_KEY		(0x0a57 << 1) -#define WDT_MODE_EN		(0x1 << 0) -#define WDT_MODE_RESET_EN	(0x1 << 1) -  #ifndef __ASSEMBLY__  #include <linux/types.h> +#include <asm/arch/watchdog.h>  /* General purpose timer */  struct sunxi_timer { @@ -43,12 +39,6 @@ struct sunxi_64cnt {  	u32 hi;			/* 0xa8 */  }; -/* Watchdog */ -struct sunxi_wdog { -	u32 ctl;		/* 0x90 */ -	u32 mode;		/* 0x94 */ -}; -  /* Rtc */  struct sunxi_rtc {  	u32 ctl;		/* 0x100 */ @@ -77,15 +67,20 @@ struct sunxi_timer_reg {  	struct sunxi_timer timer[6];	/* We have 6 timers */  	u8 res2[16];  	struct sunxi_avs avs; -	struct sunxi_wdog wdog; -	u8 res3[8]; -	struct sunxi_64cnt cnt64; +#if defined(CONFIG_SUN4I) || defined(CONFIG_SUN5I) || defined(CONFIG_SUN7I) +	struct sunxi_wdog wdog;	/* 0x90 */ +	/* XXX the following is not accurate for sun5i/sun7i */ +	struct sunxi_64cnt cnt64;	/* 0xa0 */  	u8 res4[0x58];  	struct sunxi_rtc rtc;  	struct sunxi_alarm alarm;  	struct sunxi_tgp tgp[4];  	u8 res5[8];  	u32 cpu_cfg; +#else /* CONFIG_SUN6I || CONFIG_SUN8I || ... */ +	u8 res3[16]; +	struct sunxi_wdog wdog[5];	/* We have 5 watchdogs */ +#endif  };  #endif /* __ASSEMBLY__ */ diff --git a/arch/arm/include/asm/arch-sunxi/watchdog.h b/arch/arm/include/asm/arch-sunxi/watchdog.h new file mode 100644 index 00000000000..ccc8fa32c49 --- /dev/null +++ b/arch/arm/include/asm/arch-sunxi/watchdog.h @@ -0,0 +1,44 @@ +/* + * (C) Copyright 2014 + * Chen-Yu Tsai <wens@csie.org> + * + * Watchdog register definitions + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _SUNXI_WATCHDOG_H_ +#define _SUNXI_WATCHDOG_H_ + +#define WDT_CTRL_RESTART	(0x1 << 0) +#define WDT_CTRL_KEY		(0x0a57 << 1) + +#if defined(CONFIG_SUN4I) || defined(CONFIG_SUN5I) || defined(CONFIG_SUN7I) + +#define WDT_MODE_EN		(0x1 << 0) +#define WDT_MODE_RESET_EN	(0x1 << 1) + +struct sunxi_wdog { +	u32 ctl;		/* 0x00 */ +	u32 mode;		/* 0x04 */ +	u32 res[2]; +}; + +#else + +#define WDT_CFG_RESET		(0x1) +#define WDT_MODE_EN		(0x1) + +struct sunxi_wdog { +	u32 irq_en;		/* 0x00 */ +	u32 irq_sta;		/* 0x04 */ +	u32 res1[2]; +	u32 ctl;		/* 0x10 */ +	u32 cfg;		/* 0x14 */ +	u32 mode;		/* 0x18 */ +	u32 res2; +}; + +#endif + +#endif /* _SUNXI_WATCHDOG_H_ */ diff --git a/arch/arm/include/asm/arch-tegra/board.h b/arch/arm/include/asm/arch-tegra/board.h index ff773646cbe..783bb3c0fa1 100644 --- a/arch/arm/include/asm/arch-tegra/board.h +++ b/arch/arm/include/asm/arch-tegra/board.h @@ -24,10 +24,11 @@ void gpio_early_init(void);  /* overrideable GPIO config        */   * an empty stub function will be called.   */ -void pinmux_init(void);      /* overrideable general pinmux setup */ -void pin_mux_usb(void);      /* overrideable USB pinmux setup     */ -void pin_mux_spi(void);      /* overrideable SPI pinmux setup     */ -void pin_mux_nand(void);     /* overrideable NAND pinmux setup    */ -void pin_mux_display(void);  /* overrideable DISPLAY pinmux setup */ +void pinmux_init(void);      /* overridable general pinmux setup */ +void pin_mux_usb(void);      /* overridable USB pinmux setup     */ +void pin_mux_spi(void);      /* overridable SPI pinmux setup     */ +void pin_mux_nand(void);     /* overridable NAND pinmux setup    */ +void pin_mux_mmc(void);      /* overridable mmc pinmux setup     */ +void pin_mux_display(void);  /* overridable DISPLAY pinmux setup */  #endif diff --git a/arch/arm/include/asm/arch-tegra114/mc.h b/arch/arm/include/asm/arch-tegra114/mc.h new file mode 100644 index 00000000000..044b1e0b399 --- /dev/null +++ b/arch/arm/include/asm/arch-tegra114/mc.h @@ -0,0 +1,37 @@ +/* + *  (C) Copyright 2014 + *  NVIDIA Corporation <www.nvidia.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _TEGRA114_MC_H_ +#define _TEGRA114_MC_H_ + +/** + * Defines the memory controller registers we need/care about + */ +struct mc_ctlr { +	u32 reserved0[4];			/* offset 0x00 - 0x0C */ +	u32 mc_smmu_config;			/* offset 0x10 */ +	u32 mc_smmu_tlb_config;			/* offset 0x14 */ +	u32 mc_smmu_ptc_config;			/* offset 0x18 */ +	u32 mc_smmu_ptb_asid;			/* offset 0x1C */ +	u32 mc_smmu_ptb_data;			/* offset 0x20 */ +	u32 reserved1[3];			/* offset 0x24 - 0x2C */ +	u32 mc_smmu_tlb_flush;			/* offset 0x30 */ +	u32 mc_smmu_ptc_flush;			/* offset 0x34 */ +	u32 reserved2[6];			/* offset 0x38 - 0x4C */ +	u32 mc_emem_cfg;			/* offset 0x50 */ +	u32 mc_emem_adr_cfg;			/* offset 0x54 */ +	u32 mc_emem_adr_cfg_dev0;		/* offset 0x58 */ +	u32 mc_emem_adr_cfg_dev1;		/* offset 0x5C */ +	u32 reserved3[12];			/* offset 0x60 - 0x8C */ +	u32 mc_emem_arb_reserved[28];		/* offset 0x90 - 0xFC */ +	u32 reserved4[338];			/* offset 0x100 - 0x644 */ +	u32 mc_video_protect_bom;		/* offset 0x648 */ +	u32 mc_video_protect_size_mb;		/* offset 0x64c */ +	u32 mc_video_protect_reg_ctrl;		/* offset 0x650 */ +}; + +#endif	/* _TEGRA114_MC_H_ */ diff --git a/arch/arm/include/asm/arch-tegra114/tegra.h b/arch/arm/include/asm/arch-tegra114/tegra.h index 5d426b524a1..c3d061ec586 100644 --- a/arch/arm/include/asm/arch-tegra114/tegra.h +++ b/arch/arm/include/asm/arch-tegra114/tegra.h @@ -19,6 +19,7 @@  #define NV_PA_SDRAM_BASE	0x80000000	/* 0x80000000 for real T114 */  #define NV_PA_TSC_BASE		0x700F0000	/* System Counter TSC regs */ +#define NV_PA_MC_BASE		0x70019000  #include <asm/arch-tegra/tegra.h> diff --git a/arch/arm/include/asm/arch-tegra20/mc.h b/arch/arm/include/asm/arch-tegra20/mc.h new file mode 100644 index 00000000000..9c6e3ffb6f4 --- /dev/null +++ b/arch/arm/include/asm/arch-tegra20/mc.h @@ -0,0 +1,36 @@ +/* + *  (C) Copyright 2014 + *  NVIDIA Corporation <www.nvidia.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _TEGRA20_MC_H_ +#define _TEGRA20_MC_H_ + +/** + * Defines the memory controller registers we need/care about + */ +struct mc_ctlr { +	u32 reserved0[3];			/* offset 0x00 - 0x08 */ +	u32 mc_emem_cfg;			/* offset 0x0C */ +	u32 mc_emem_adr_cfg;			/* offset 0x10 */ +	u32 mc_emem_arb_cfg0;			/* offset 0x14 */ +	u32 mc_emem_arb_cfg1;			/* offset 0x18 */ +	u32 mc_emem_arb_cfg2;			/* offset 0x1C */ +	u32 reserved1;				/* offset 0x20 */ +	u32 mc_gart_cfg;			/* offset 0x24 */ +	u32 mc_gart_entry_addr;			/* offset 0x28 */ +	u32 mc_gart_entry_data;			/* offset 0x2C */ +	u32 mc_gart_error_req;			/* offset 0x30 */ +	u32 mc_gart_error_addr;			/* offset 0x34 */ +	u32 reserved2;				/* offset 0x38 */ +	u32 mc_timeout_ctrl;			/* offset 0x3C */ +	u32 reserved3[6];			/* offset 0x40 - 0x54 */ +	u32 mc_decerr_emem_others_status;	/* offset 0x58 */ +	u32 mc_decerr_emem_others_adr;		/* offset 0x5C */ +	u32 reserved4[40];			/* offset 0x60 - 0xFC */ +	u32 reserved5[93];			/* offset 0x100 - 0x270 */ +}; + +#endif	/* _TEGRA20_MC_H_ */ diff --git a/arch/arm/include/asm/arch-tegra20/tegra.h b/arch/arm/include/asm/arch-tegra20/tegra.h index 18856ac3727..22774abb936 100644 --- a/arch/arm/include/asm/arch-tegra20/tegra.h +++ b/arch/arm/include/asm/arch-tegra20/tegra.h @@ -9,6 +9,7 @@  #define _TEGRA20_H_  #define NV_PA_SDRAM_BASE	0x00000000 +#define NV_PA_MC_BASE		0x7000F000  #include <asm/arch-tegra/tegra.h> diff --git a/arch/arm/include/asm/arch-tegra30/mc.h b/arch/arm/include/asm/arch-tegra30/mc.h new file mode 100644 index 00000000000..242a1fc64b9 --- /dev/null +++ b/arch/arm/include/asm/arch-tegra30/mc.h @@ -0,0 +1,38 @@ +/* + *  (C) Copyright 2014 + *  NVIDIA Corporation <www.nvidia.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _TEGRA30_MC_H_ +#define _TEGRA30_MC_H_ + +/** + * Defines the memory controller registers we need/care about + */ +struct mc_ctlr { +	u32 reserved0[4];			/* offset 0x00 - 0x0C */ +	u32 mc_smmu_config;			/* offset 0x10 */ +	u32 mc_smmu_tlb_config;			/* offset 0x14 */ +	u32 mc_smmu_ptc_config;			/* offset 0x18 */ +	u32 mc_smmu_ptb_asid;			/* offset 0x1C */ +	u32 mc_smmu_ptb_data;			/* offset 0x20 */ +	u32 reserved1[3];			/* offset 0x24 - 0x2C */ +	u32 mc_smmu_tlb_flush;			/* offset 0x30 */ +	u32 mc_smmu_ptc_flush;			/* offset 0x34 */ +	u32 mc_smmu_asid_security;		/* offset 0x38 */ +	u32 reserved2[5];			/* offset 0x3C - 0x4C */ +	u32 mc_emem_cfg;			/* offset 0x50 */ +	u32 mc_emem_adr_cfg;			/* offset 0x54 */ +	u32 mc_emem_adr_cfg_dev0;		/* offset 0x58 */ +	u32 mc_emem_adr_cfg_dev1;		/* offset 0x5C */ +	u32 reserved3[12];			/* offset 0x60 - 0x8C */ +	u32 mc_emem_arb_reserved[28];		/* offset 0x90 - 0xFC */ +	u32 reserved4[338];			/* offset 0x100 - 0x644 */ +	u32 mc_video_protect_bom;		/* offset 0x648 */ +	u32 mc_video_protect_size_mb;		/* offset 0x64c */ +	u32 mc_video_protect_reg_ctrl;		/* offset 0x650 */ +}; + +#endif	/* _TEGRA30_MC_H_ */ diff --git a/arch/arm/include/asm/arch-tegra30/tegra.h b/arch/arm/include/asm/arch-tegra30/tegra.h index c02c5d85003..93671793a9f 100644 --- a/arch/arm/include/asm/arch-tegra30/tegra.h +++ b/arch/arm/include/asm/arch-tegra30/tegra.h @@ -17,6 +17,7 @@  #ifndef _TEGRA30_H_  #define _TEGRA30_H_ +#define NV_PA_MC_BASE		0x7000F000  #define NV_PA_SDRAM_BASE	0x80000000	/* 0x80000000 for real T30 */  #include <asm/arch-tegra/tegra.h> diff --git a/arch/arm/include/asm/arch-uniphier/platdevice.h b/arch/arm/include/asm/arch-uniphier/platdevice.h new file mode 100644 index 00000000000..cdf7d132d44 --- /dev/null +++ b/arch/arm/include/asm/arch-uniphier/platdevice.h @@ -0,0 +1,24 @@ +/* + * Copyright (C) 2014 Panasonic Corporation + *   Author: Masahiro Yamada <yamada.m@jp.panasonic.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef ARCH_PLATDEVICE_H +#define ARCH_PLATDEVICE_H + +#include <dm/platdata.h> +#include <dm/platform_data/serial-uniphier.h> + +#define SERIAL_DEVICE(n, ba, clk)					\ +static struct uniphier_serial_platform_data serial_device##n = {	\ +	.base = ba,							\ +	.uartclk = clk							\ +};									\ +U_BOOT_DEVICE(serial##n) = {						\ +	.name = DRIVER_NAME,						\ +	.platdata = &serial_device##n					\ +}; + +#endif /* ARCH_PLATDEVICE_H */ diff --git a/arch/arm/include/asm/mach-types.h b/arch/arm/include/asm/mach-types.h index 560924e83ff..d4a447b2b8a 100644 --- a/arch/arm/include/asm/mach-types.h +++ b/arch/arm/include/asm/mach-types.h @@ -1107,6 +1107,7 @@ extern unsigned int __machine_arch_type;  #define MACH_TYPE_ARMADILLO_800EVA     3863  #define MACH_TYPE_KZM9G                4140  #define MACH_TYPE_COLIBRI_T30          4493 +#define MACH_TYPE_APALIS_T30           4513  #ifdef CONFIG_ARCH_EBSA110  # ifdef machine_arch_type @@ -14248,6 +14249,18 @@ extern unsigned int __machine_arch_type;  # define machine_is_colibri_t30()	(0)  #endif +#ifdef CONFIG_MACH_APALIS_T30 +# ifdef machine_arch_type +#  undef machine_arch_type +#  define machine_arch_type	__machine_arch_type +# else +#  define machine_arch_type	MACH_TYPE_APALIS_T30 +# endif +# define machine_is_apalis_t30()	(machine_arch_type == MACH_TYPE_APALIS_T30) +#else +# define machine_is_apalis_t30()	(0) +#endif +  /*   * These have not yet been registered   */ diff --git a/arch/arm/include/asm/omap_gpio.h b/arch/arm/include/asm/omap_gpio.h index 5d25d04c3bf..839af54d482 100644 --- a/arch/arm/include/asm/omap_gpio.h +++ b/arch/arm/include/asm/omap_gpio.h @@ -23,6 +23,21 @@  #include <asm/arch/cpu.h> +enum gpio_method { +	METHOD_GPIO_24XX	= 4, +}; + +#ifdef CONFIG_DM_GPIO + +/* Information about a GPIO bank */ +struct omap_gpio_platdata { +	int bank_index; +	ulong base;	/* address of registers in physical memory */ +	enum gpio_method method; +}; + +#else +  struct gpio_bank {  	void *base;  	int method; @@ -30,8 +45,6 @@ struct gpio_bank {  extern const struct gpio_bank *const omap_gpio_bank; -#define METHOD_GPIO_24XX	4 -  /**   * Check if gpio is valid.   * @@ -39,4 +52,6 @@ extern const struct gpio_bank *const omap_gpio_bank;   * @return 1 if ok, 0 on error   */  int gpio_is_valid(int gpio); +#endif +  #endif /* _GPIO_H_ */ diff --git a/arch/arm/include/asm/spl.h b/arch/arm/include/asm/spl.h index e5daf891271..8acd7cd1bd5 100644 --- a/arch/arm/include/asm/spl.h +++ b/arch/arm/include/asm/spl.h @@ -7,7 +7,7 @@  #ifndef	_ASM_SPL_H_  #define	_ASM_SPL_H_ -#if defined(CONFIG_OMAP) || defined(CONFIG_SOCFPGA) \ +#if defined(CONFIG_OMAP) \  	|| defined(CONFIG_EXYNOS4) || defined(CONFIG_EXYNOS5) \  	|| defined(CONFIG_EXYNOS4210)  /* Platform-specific defines */ diff --git a/arch/arm/include/asm/u-boot-arm.h b/arch/arm/include/asm/u-boot-arm.h index b16694c72f8..f97f3dd1496 100644 --- a/arch/arm/include/asm/u-boot-arm.h +++ b/arch/arm/include/asm/u-boot-arm.h @@ -45,4 +45,19 @@ void	reset_timer_masked	(void);  ulong	get_timer_masked	(void);  void	udelay_masked		(unsigned long usec); +/* calls to c from vectors.S */ +void bad_mode(void); +void do_undefined_instruction(struct pt_regs *pt_regs); +void do_software_interrupt(struct pt_regs *pt_regs); +void do_prefetch_abort(struct pt_regs *pt_regs); +void do_data_abort(struct pt_regs *pt_regs); +void do_not_used(struct pt_regs *pt_regs); +#ifdef CONFIG_ARM64 +void do_fiq(struct pt_regs *pt_regs, unsigned int esr); +void do_irq(struct pt_regs *pt_regs, unsigned int esr); +#else +void do_fiq(struct pt_regs *pt_regs); +void do_irq(struct pt_regs *pt_regswq); +#endif +  #endif	/* _U_BOOT_ARM_H_ */ diff --git a/arch/arm/lib/board.c b/arch/arm/lib/board.c index 76adaf3aa4a..f6062557e66 100644 --- a/arch/arm/lib/board.c +++ b/arch/arm/lib/board.c @@ -34,6 +34,7 @@  #include <onenand_uboot.h>  #include <mmc.h>  #include <scsi.h> +#include <status_led.h>  #include <libfdt.h>  #include <fdtdec.h>  #include <post.h> @@ -63,25 +64,15 @@ extern void dataflash_print_info(void);   ************************************************************************   * May be supplied by boards if desired   */ -inline void __coloured_LED_init(void) {} -void coloured_LED_init(void) -	__attribute__((weak, alias("__coloured_LED_init"))); -inline void __red_led_on(void) {} -void red_led_on(void) __attribute__((weak, alias("__red_led_on"))); -inline void __red_led_off(void) {} -void red_led_off(void) __attribute__((weak, alias("__red_led_off"))); -inline void __green_led_on(void) {} -void green_led_on(void) __attribute__((weak, alias("__green_led_on"))); -inline void __green_led_off(void) {} -void green_led_off(void) __attribute__((weak, alias("__green_led_off"))); -inline void __yellow_led_on(void) {} -void yellow_led_on(void) __attribute__((weak, alias("__yellow_led_on"))); -inline void __yellow_led_off(void) {} -void yellow_led_off(void) __attribute__((weak, alias("__yellow_led_off"))); -inline void __blue_led_on(void) {} -void blue_led_on(void) __attribute__((weak, alias("__blue_led_on"))); -inline void __blue_led_off(void) {} -void blue_led_off(void) __attribute__((weak, alias("__blue_led_off"))); +__weak void coloured_LED_init(void) {} +__weak void red_led_on(void) {} +__weak void red_led_off(void) {} +__weak void green_led_on(void) {} +__weak void green_led_off(void) {} +__weak void yellow_led_on(void) {} +__weak void yellow_led_off(void) {} +__weak void blue_led_on(void) {} +__weak void blue_led_off(void) {}  /*   ************************************************************************ @@ -198,27 +189,21 @@ static int arm_pci_init(void)   */  typedef int (init_fnc_t) (void); -void __dram_init_banksize(void) +__weak void dram_init_banksize(void)  {  	gd->bd->bi_dram[0].start = CONFIG_SYS_SDRAM_BASE;  	gd->bd->bi_dram[0].size =  gd->ram_size;  } -void dram_init_banksize(void) -	__attribute__((weak, alias("__dram_init_banksize"))); -int __arch_cpu_init(void) +__weak int arch_cpu_init(void)  {  	return 0;  } -int arch_cpu_init(void) -	__attribute__((weak, alias("__arch_cpu_init"))); -int __power_init_board(void) +__weak int power_init_board(void)  {  	return 0;  } -int power_init_board(void) -	__attribute__((weak, alias("__power_init_board")));  	/* Record the board_init_f() bootstage (after arch_cpu_init()) */  static int mark_bootstage(void) diff --git a/arch/arm/lib/bootm.c b/arch/arm/lib/bootm.c index 39fe7a17fcf..0d19c8ae236 100644 --- a/arch/arm/lib/bootm.c +++ b/arch/arm/lib/bootm.c @@ -15,6 +15,7 @@  #include <common.h>  #include <command.h>  #include <image.h> +#include <vxworks.h>  #include <u-boot/zlib.h>  #include <asm/byteorder.h>  #include <libfdt.h> diff --git a/arch/arm/lib/interrupts.c b/arch/arm/lib/interrupts.c index f6b7c03578b..9019736d2c7 100644 --- a/arch/arm/lib/interrupts.c +++ b/arch/arm/lib/interrupts.c @@ -21,6 +21,7 @@  #include <common.h>  #include <asm/proc-armv/ptrace.h> +#include <asm/u-boot-arm.h>  DECLARE_GLOBAL_DATA_PTR; diff --git a/arch/arm/mvebu-common/Makefile b/arch/arm/mvebu-common/Makefile new file mode 100644 index 00000000000..9dcab6958c5 --- /dev/null +++ b/arch/arm/mvebu-common/Makefile @@ -0,0 +1,12 @@ +# +# (C) Copyright 2009 +# Marvell Semiconductor <www.marvell.com> +# Written-by: Prafulla Wadaskar <prafulla@marvell.com> +# +# SPDX-License-Identifier:	GPL-2.0+ +# + +obj-y	= dram.o +obj-y	+= gpio.o +obj-$(CONFIG_ARMADA_XP) += mbus.o +obj-y	+= timer.o diff --git a/arch/arm/cpu/arm926ejs/kirkwood/dram.c b/arch/arm/mvebu-common/dram.c index d73ae47c341..db18791a862 100644 --- a/arch/arm/cpu/arm926ejs/kirkwood/dram.c +++ b/arch/arm/mvebu-common/dram.c @@ -10,31 +10,31 @@  #include <common.h>  #include <asm/io.h>  #include <asm/arch/cpu.h> -#include <asm/arch/kirkwood.h> +#include <asm/arch/soc.h>  DECLARE_GLOBAL_DATA_PTR; -struct kw_sdram_bank { +struct sdram_bank {  	u32	win_bar;  	u32	win_sz;  }; -struct kw_sdram_addr_dec { -	struct kw_sdram_bank	sdram_bank[4]; +struct sdram_addr_dec { +	struct sdram_bank sdram_bank[4];  }; -#define KW_REG_CPUCS_WIN_ENABLE		(1 << 0) -#define KW_REG_CPUCS_WIN_WR_PROTECT	(1 << 1) -#define KW_REG_CPUCS_WIN_WIN0_CS(x)	(((x) & 0x3) << 2) -#define KW_REG_CPUCS_WIN_SIZE(x)	(((x) & 0xff) << 24) +#define REG_CPUCS_WIN_ENABLE		(1 << 0) +#define REG_CPUCS_WIN_WR_PROTECT	(1 << 1) +#define REG_CPUCS_WIN_WIN0_CS(x)	(((x) & 0x3) << 2) +#define REG_CPUCS_WIN_SIZE(x)		(((x) & 0xff) << 24)  /* - * kw_sdram_bar - reads SDRAM Base Address Register + * mvebu_sdram_bar - reads SDRAM Base Address Register   */ -u32 kw_sdram_bar(enum memory_bank bank) +u32 mvebu_sdram_bar(enum memory_bank bank)  { -	struct kw_sdram_addr_dec *base = -		(struct kw_sdram_addr_dec *)KW_REGISTER(0x1500); +	struct sdram_addr_dec *base = +		(struct sdram_addr_dec *)MVEBU_SDRAM_BASE;  	u32 result = 0;  	u32 enable = 0x01 & readl(&base->sdram_bank[bank].win_sz); @@ -46,31 +46,31 @@ u32 kw_sdram_bar(enum memory_bank bank)  }  /* - * kw_sdram_bs_set - writes SDRAM Bank size + * mvebu_sdram_bs_set - writes SDRAM Bank size   */ -static void kw_sdram_bs_set(enum memory_bank bank, u32 size) +static void mvebu_sdram_bs_set(enum memory_bank bank, u32 size)  { -	struct kw_sdram_addr_dec *base = -		(struct kw_sdram_addr_dec *)KW_REGISTER(0x1500); +	struct sdram_addr_dec *base = +		(struct sdram_addr_dec *)MVEBU_SDRAM_BASE;  	/* Read current register value */  	u32 reg = readl(&base->sdram_bank[bank].win_sz);  	/* Clear window size */ -	reg &= ~KW_REG_CPUCS_WIN_SIZE(0xFF); +	reg &= ~REG_CPUCS_WIN_SIZE(0xFF);  	/* Set new window size */ -	reg |= KW_REG_CPUCS_WIN_SIZE((size - 1) >> 24); +	reg |= REG_CPUCS_WIN_SIZE((size - 1) >> 24);  	writel(reg, &base->sdram_bank[bank].win_sz);  }  /* - * kw_sdram_bs - reads SDRAM Bank size + * mvebu_sdram_bs - reads SDRAM Bank size   */ -u32 kw_sdram_bs(enum memory_bank bank) +u32 mvebu_sdram_bs(enum memory_bank bank)  { -	struct kw_sdram_addr_dec *base = -		(struct kw_sdram_addr_dec *)KW_REGISTER(0x1500); +	struct sdram_addr_dec *base = +		(struct sdram_addr_dec *)MVEBU_SDRAM_BASE;  	u32 result = 0;  	u32 enable = 0x01 & readl(&base->sdram_bank[bank].win_sz); @@ -81,15 +81,16 @@ u32 kw_sdram_bs(enum memory_bank bank)  	return result;  } -void kw_sdram_size_adjust(enum memory_bank bank) +void mvebu_sdram_size_adjust(enum memory_bank bank)  {  	u32 size;  	/* probe currently equipped RAM size */ -	size = get_ram_size((void *)kw_sdram_bar(bank), kw_sdram_bs(bank)); +	size = get_ram_size((void *)mvebu_sdram_bar(bank), +			    mvebu_sdram_bs(bank));  	/* adjust SDRAM window size accordingly */ -	kw_sdram_bs_set(bank, size); +	mvebu_sdram_bs_set(bank, size);  }  #ifndef CONFIG_SYS_BOARD_DRAM_INIT @@ -99,8 +100,8 @@ int dram_init(void)  	gd->ram_size = 0;  	for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) { -		gd->bd->bi_dram[i].start = kw_sdram_bar(i); -		gd->bd->bi_dram[i].size = kw_sdram_bs(i); +		gd->bd->bi_dram[i].start = mvebu_sdram_bar(i); +		gd->bd->bi_dram[i].size = mvebu_sdram_bs(i);  		/*  		 * It is assumed that all memory banks are consecutive  		 * and without gaps. @@ -110,7 +111,13 @@ int dram_init(void)  		if (gd->bd->bi_dram[i].start != gd->ram_size)  			break; -		gd->ram_size += gd->bd->bi_dram[i].size; +		/* +		 * Don't report more than 3GiB of SDRAM, otherwise there is no +		 * address space left for the internal registers etc. +		 */ +		if ((gd->ram_size + gd->bd->bi_dram[i].size != 0) && +		    (gd->ram_size + gd->bd->bi_dram[i].size <= (3 << 30))) +			gd->ram_size += gd->bd->bi_dram[i].size;  	} diff --git a/arch/arm/mvebu-common/gpio.c b/arch/arm/mvebu-common/gpio.c new file mode 100644 index 00000000000..56e54e0a621 --- /dev/null +++ b/arch/arm/mvebu-common/gpio.c @@ -0,0 +1,30 @@ +/* + * (C) Copyright 2009 + * Marvell Semiconductor <www.marvell.com> + * Written-by: Prafulla Wadaskar <prafulla@marvell.com> + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/io.h> +#include <asm/arch/cpu.h> +#include <asm/arch/soc.h> + +/* + * mvebu_config_gpio - GPIO configuration + */ +void mvebu_config_gpio(u32 gpp0_oe_val, u32 gpp1_oe_val, +		       u32 gpp0_oe, u32 gpp1_oe) +{ +	struct kwgpio_registers *gpio0reg = +		(struct kwgpio_registers *)MVEBU_GPIO0_BASE; +	struct kwgpio_registers *gpio1reg = +		(struct kwgpio_registers *)MVEBU_GPIO1_BASE; + +	/* Init GPIOS to default values as per board requirement */ +	writel(gpp0_oe_val, &gpio0reg->dout); +	writel(gpp1_oe_val, &gpio1reg->dout); +	writel(gpp0_oe, &gpio0reg->oe); +	writel(gpp1_oe, &gpio1reg->oe); +} diff --git a/arch/arm/mvebu-common/mbus.c b/arch/arm/mvebu-common/mbus.c new file mode 100644 index 00000000000..05c9ef2cbbc --- /dev/null +++ b/arch/arm/mvebu-common/mbus.c @@ -0,0 +1,471 @@ +/* + * Address map functions for Marvell EBU SoCs (Kirkwood, Armada + * 370/XP, Dove, Orion5x and MV78xx0) + * + * Ported from the Barebox version to U-Boot by: + * Stefan Roese <sr@denx.de> + * + * The Barebox version is: + * Sebastian Hesselbarth <sebastian.hesselbarth@gmail.com> + * + * based on mbus driver from Linux + *   (C) Copyright 2008 Marvell Semiconductor + * + * SPDX-License-Identifier:	GPL-2.0 + * + * The Marvell EBU SoCs have a configurable physical address space: + * the physical address at which certain devices (PCIe, NOR, NAND, + * etc.) sit can be configured. The configuration takes place through + * two sets of registers: + * + * - One to configure the access of the CPU to the devices. Depending + *   on the families, there are between 8 and 20 configurable windows, + *   each can be use to create a physical memory window that maps to a + *   specific device. Devices are identified by a tuple (target, + *   attribute). + * + * - One to configure the access to the CPU to the SDRAM. There are + *   either 2 (for Dove) or 4 (for other families) windows to map the + *   SDRAM into the physical address space. + * + * This driver: + * + * - Reads out the SDRAM address decoding windows at initialization + *   time, and fills the mbus_dram_info structure with these + *   informations. The exported function mv_mbus_dram_info() allow + *   device drivers to get those informations related to the SDRAM + *   address decoding windows. This is because devices also have their + *   own windows (configured through registers that are part of each + *   device register space), and therefore the drivers for Marvell + *   devices have to configure those device -> SDRAM windows to ensure + *   that DMA works properly. + * + * - Provides an API for platform code or device drivers to + *   dynamically add or remove address decoding windows for the CPU -> + *   device accesses. This API is mvebu_mbus_add_window_by_id(), + *   mvebu_mbus_add_window_remap_by_id() and + *   mvebu_mbus_del_window(). + */ + +#include <common.h> +#include <asm/errno.h> +#include <asm/io.h> +#include <asm/arch/cpu.h> +#include <asm/arch/soc.h> +#include <linux/mbus.h> + +#define BIT(nr)			(1UL << (nr)) + +/* DDR target is the same on all platforms */ +#define TARGET_DDR		0 + +/* CPU Address Decode Windows registers */ +#define WIN_CTRL_OFF		0x0000 +#define   WIN_CTRL_ENABLE       BIT(0) +#define   WIN_CTRL_TGT_MASK     0xf0 +#define   WIN_CTRL_TGT_SHIFT    4 +#define   WIN_CTRL_ATTR_MASK    0xff00 +#define   WIN_CTRL_ATTR_SHIFT   8 +#define   WIN_CTRL_SIZE_MASK    0xffff0000 +#define   WIN_CTRL_SIZE_SHIFT   16 +#define WIN_BASE_OFF		0x0004 +#define   WIN_BASE_LOW          0xffff0000 +#define   WIN_BASE_HIGH         0xf +#define WIN_REMAP_LO_OFF	0x0008 +#define   WIN_REMAP_LOW         0xffff0000 +#define WIN_REMAP_HI_OFF	0x000c + +#define ATTR_HW_COHERENCY	(0x1 << 4) + +#define DDR_BASE_CS_OFF(n)	(0x0000 + ((n) << 3)) +#define  DDR_BASE_CS_HIGH_MASK  0xf +#define  DDR_BASE_CS_LOW_MASK   0xff000000 +#define DDR_SIZE_CS_OFF(n)	(0x0004 + ((n) << 3)) +#define  DDR_SIZE_ENABLED       BIT(0) +#define  DDR_SIZE_CS_MASK       0x1c +#define  DDR_SIZE_CS_SHIFT      2 +#define  DDR_SIZE_MASK          0xff000000 + +#define DOVE_DDR_BASE_CS_OFF(n) ((n) << 4) + +struct mvebu_mbus_state; + +struct mvebu_mbus_soc_data { +	unsigned int num_wins; +	unsigned int num_remappable_wins; +	unsigned int (*win_cfg_offset)(const int win); +	void (*setup_cpu_target)(struct mvebu_mbus_state *s); +}; + +struct mvebu_mbus_state mbus_state +	__attribute__ ((section(".data"))); +static struct mbus_dram_target_info mbus_dram_info +	__attribute__ ((section(".data"))); + +/* + * Functions to manipulate the address decoding windows + */ + +static void mvebu_mbus_read_window(struct mvebu_mbus_state *mbus, +				   int win, int *enabled, u64 *base, +				   u32 *size, u8 *target, u8 *attr, +				   u64 *remap) +{ +	void __iomem *addr = mbus->mbuswins_base + +		mbus->soc->win_cfg_offset(win); +	u32 basereg = readl(addr + WIN_BASE_OFF); +	u32 ctrlreg = readl(addr + WIN_CTRL_OFF); + +	if (!(ctrlreg & WIN_CTRL_ENABLE)) { +		*enabled = 0; +		return; +	} + +	*enabled = 1; +	*base = ((u64)basereg & WIN_BASE_HIGH) << 32; +	*base |= (basereg & WIN_BASE_LOW); +	*size = (ctrlreg | ~WIN_CTRL_SIZE_MASK) + 1; + +	if (target) +		*target = (ctrlreg & WIN_CTRL_TGT_MASK) >> WIN_CTRL_TGT_SHIFT; + +	if (attr) +		*attr = (ctrlreg & WIN_CTRL_ATTR_MASK) >> WIN_CTRL_ATTR_SHIFT; + +	if (remap) { +		if (win < mbus->soc->num_remappable_wins) { +			u32 remap_low = readl(addr + WIN_REMAP_LO_OFF); +			u32 remap_hi  = readl(addr + WIN_REMAP_HI_OFF); +			*remap = ((u64)remap_hi << 32) | remap_low; +		} else { +			*remap = 0; +		} +	} +} + +static void mvebu_mbus_disable_window(struct mvebu_mbus_state *mbus, +				      int win) +{ +	void __iomem *addr; + +	addr = mbus->mbuswins_base + mbus->soc->win_cfg_offset(win); + +	writel(0, addr + WIN_BASE_OFF); +	writel(0, addr + WIN_CTRL_OFF); +	if (win < mbus->soc->num_remappable_wins) { +		writel(0, addr + WIN_REMAP_LO_OFF); +		writel(0, addr + WIN_REMAP_HI_OFF); +	} +} + +/* Checks whether the given window number is available */ +static int mvebu_mbus_window_is_free(struct mvebu_mbus_state *mbus, +				     const int win) +{ +	void __iomem *addr = mbus->mbuswins_base + +		mbus->soc->win_cfg_offset(win); +	u32 ctrl = readl(addr + WIN_CTRL_OFF); +	return !(ctrl & WIN_CTRL_ENABLE); +} + +/* + * Checks whether the given (base, base+size) area doesn't overlap an + * existing region + */ +static int mvebu_mbus_window_conflicts(struct mvebu_mbus_state *mbus, +				       phys_addr_t base, size_t size, +				       u8 target, u8 attr) +{ +	u64 end = (u64)base + size; +	int win; + +	for (win = 0; win < mbus->soc->num_wins; win++) { +		u64 wbase, wend; +		u32 wsize; +		u8 wtarget, wattr; +		int enabled; + +		mvebu_mbus_read_window(mbus, win, +				       &enabled, &wbase, &wsize, +				       &wtarget, &wattr, NULL); + +		if (!enabled) +			continue; + +		wend = wbase + wsize; + +		/* +		 * Check if the current window overlaps with the +		 * proposed physical range +		 */ +		if ((u64)base < wend && end > wbase) +			return 0; + +		/* +		 * Check if target/attribute conflicts +		 */ +		if (target == wtarget && attr == wattr) +			return 0; +	} + +	return 1; +} + +static int mvebu_mbus_find_window(struct mvebu_mbus_state *mbus, +				  phys_addr_t base, size_t size) +{ +	int win; + +	for (win = 0; win < mbus->soc->num_wins; win++) { +		u64 wbase; +		u32 wsize; +		int enabled; + +		mvebu_mbus_read_window(mbus, win, +				       &enabled, &wbase, &wsize, +				       NULL, NULL, NULL); + +		if (!enabled) +			continue; + +		if (base == wbase && size == wsize) +			return win; +	} + +	return -ENODEV; +} + +static int mvebu_mbus_setup_window(struct mvebu_mbus_state *mbus, +				   int win, phys_addr_t base, size_t size, +				   phys_addr_t remap, u8 target, +				   u8 attr) +{ +	void __iomem *addr = mbus->mbuswins_base + +		mbus->soc->win_cfg_offset(win); +	u32 ctrl, remap_addr; + +	ctrl = ((size - 1) & WIN_CTRL_SIZE_MASK) | +		(attr << WIN_CTRL_ATTR_SHIFT)    | +		(target << WIN_CTRL_TGT_SHIFT)   | +		WIN_CTRL_ENABLE; + +	writel(base & WIN_BASE_LOW, addr + WIN_BASE_OFF); +	writel(ctrl, addr + WIN_CTRL_OFF); +	if (win < mbus->soc->num_remappable_wins) { +		if (remap == MVEBU_MBUS_NO_REMAP) +			remap_addr = base; +		else +			remap_addr = remap; +		writel(remap_addr & WIN_REMAP_LOW, addr + WIN_REMAP_LO_OFF); +		writel(0, addr + WIN_REMAP_HI_OFF); +	} + +	return 0; +} + +static int mvebu_mbus_alloc_window(struct mvebu_mbus_state *mbus, +				   phys_addr_t base, size_t size, +				   phys_addr_t remap, u8 target, +				   u8 attr) +{ +	int win; + +	if (remap == MVEBU_MBUS_NO_REMAP) { +		for (win = mbus->soc->num_remappable_wins; +		     win < mbus->soc->num_wins; win++) +			if (mvebu_mbus_window_is_free(mbus, win)) +				return mvebu_mbus_setup_window(mbus, win, base, +							       size, remap, +							       target, attr); +	} + + +	for (win = 0; win < mbus->soc->num_wins; win++) +		if (mvebu_mbus_window_is_free(mbus, win)) +			return mvebu_mbus_setup_window(mbus, win, base, size, +						       remap, target, attr); + +	return -ENOMEM; +} + +/* + * SoC-specific functions and definitions + */ + +static unsigned int armada_370_xp_mbus_win_offset(int win) +{ +	/* The register layout is a bit annoying and the below code +	 * tries to cope with it. +	 * - At offset 0x0, there are the registers for the first 8 +	 *   windows, with 4 registers of 32 bits per window (ctrl, +	 *   base, remap low, remap high) +	 * - Then at offset 0x80, there is a hole of 0x10 bytes for +	 *   the internal registers base address and internal units +	 *   sync barrier register. +	 * - Then at offset 0x90, there the registers for 12 +	 *   windows, with only 2 registers of 32 bits per window +	 *   (ctrl, base). +	 */ +	if (win < 8) +		return win << 4; +	else +		return 0x90 + ((win - 8) << 3); +} + +static unsigned int orion5x_mbus_win_offset(int win) +{ +	return win << 4; +} + +static void mvebu_mbus_default_setup_cpu_target(struct mvebu_mbus_state *mbus) +{ +	int i; +	int cs; + +	mbus_dram_info.mbus_dram_target_id = TARGET_DDR; + +	for (i = 0, cs = 0; i < 4; i++) { +		u32 base = readl(mbus->sdramwins_base + DDR_BASE_CS_OFF(i)); +		u32 size = readl(mbus->sdramwins_base + DDR_SIZE_CS_OFF(i)); + +		/* +		 * We only take care of entries for which the chip +		 * select is enabled, and that don't have high base +		 * address bits set (devices can only access the first +		 * 32 bits of the memory). +		 */ +		if ((size & DDR_SIZE_ENABLED) && +		    !(base & DDR_BASE_CS_HIGH_MASK)) { +			struct mbus_dram_window *w; + +			w = &mbus_dram_info.cs[cs++]; +			w->cs_index = i; +			w->mbus_attr = 0xf & ~(1 << i); +#if defined(CONFIG_ARMADA_XP) +			w->mbus_attr |= ATTR_HW_COHERENCY; +#endif +			w->base = base & DDR_BASE_CS_LOW_MASK; +			w->size = (size | ~DDR_SIZE_MASK) + 1; +		} +	} +	mbus_dram_info.num_cs = cs; +} + +static const struct mvebu_mbus_soc_data +armada_370_xp_mbus_data __maybe_unused = { +	.num_wins            = 20, +	.num_remappable_wins = 8, +	.win_cfg_offset      = armada_370_xp_mbus_win_offset, +	.setup_cpu_target    = mvebu_mbus_default_setup_cpu_target, +}; + +static const struct mvebu_mbus_soc_data +kirkwood_mbus_data __maybe_unused = { +	.num_wins            = 8, +	.num_remappable_wins = 4, +	.win_cfg_offset      = orion5x_mbus_win_offset, +	.setup_cpu_target    = mvebu_mbus_default_setup_cpu_target, +}; + +/* + * Public API of the driver + */ +const struct mbus_dram_target_info *mvebu_mbus_dram_info(void) +{ +	return &mbus_dram_info; +} + +int mvebu_mbus_add_window_remap_by_id(unsigned int target, +				      unsigned int attribute, +				      phys_addr_t base, size_t size, +				      phys_addr_t remap) +{ +	struct mvebu_mbus_state *s = &mbus_state; + +	if (!mvebu_mbus_window_conflicts(s, base, size, target, attribute)) { +		printf("Cannot add window '%x:%x', conflicts with another window\n", +		       target, attribute); +		return -EINVAL; +	} + +	return mvebu_mbus_alloc_window(s, base, size, remap, target, attribute); +} + +int mvebu_mbus_add_window_by_id(unsigned int target, unsigned int attribute, +				phys_addr_t base, size_t size) +{ +	return mvebu_mbus_add_window_remap_by_id(target, attribute, base, +						 size, MVEBU_MBUS_NO_REMAP); +} + +int mvebu_mbus_del_window(phys_addr_t base, size_t size) +{ +	int win; + +	win = mvebu_mbus_find_window(&mbus_state, base, size); +	if (win < 0) +		return win; + +	mvebu_mbus_disable_window(&mbus_state, win); +	return 0; +} + +int mbus_dt_setup_win(struct mvebu_mbus_state *mbus, +		      u32 base, u32 size, u8 target, u8 attr) +{ +	if (!mvebu_mbus_window_conflicts(mbus, base, size, target, attr)) { +		printf("Cannot add window '%04x:%04x', conflicts with another window\n", +		       target, attr); +		return -EBUSY; +	} + +	/* +	 * In U-Boot we first try to add the mbus window to the remap windows. +	 * If this fails, lets try to add the windows to the non-remap windows. +	 */ +	if (mvebu_mbus_alloc_window(mbus, base, size, base, target, attr)) { +		if (mvebu_mbus_alloc_window(mbus, base, size, +					    MVEBU_MBUS_NO_REMAP, target, attr)) +			return -ENOMEM; +	} + +	return 0; +} + +int mvebu_mbus_probe(struct mbus_win windows[], int count) +{ +	int win; +	int ret; +	int i; + +#if defined(CONFIG_KIRKWOOD) +	mbus_state.soc = &kirkwood_mbus_data; +#endif +#if defined(CONFIG_ARMADA_XP) +	mbus_state.soc = &armada_370_xp_mbus_data; +#endif + +	mbus_state.mbuswins_base = (void __iomem *)MVEBU_CPU_WIN_BASE; +	mbus_state.sdramwins_base = (void __iomem *)MVEBU_SDRAM_BASE; + +	for (win = 0; win < mbus_state.soc->num_wins; win++) +		mvebu_mbus_disable_window(&mbus_state, win); + +	mbus_state.soc->setup_cpu_target(&mbus_state); + +	/* Setup statically declared windows in the DT */ +	for (i = 0; i < count; i++) { +		u32 base, size; +		u8 target, attr; + +		target = windows[i].target; +		attr = windows[i].attr; +		base = windows[i].base; +		size = windows[i].size; +		ret = mbus_dt_setup_win(&mbus_state, base, size, target, attr); +		if (ret < 0) +			return ret; +	} + +	return 0; +} diff --git a/arch/arm/cpu/arm926ejs/kirkwood/timer.c b/arch/arm/mvebu-common/timer.c index a08f4a1456c..40c4bc2da1b 100644 --- a/arch/arm/cpu/arm926ejs/kirkwood/timer.c +++ b/arch/arm/mvebu-common/timer.c @@ -7,75 +7,68 @@  #include <common.h>  #include <asm/io.h> -#include <asm/arch/kirkwood.h> +#include <asm/arch/soc.h> -#define UBOOT_CNTR	0	/* counter to use for uboot timer */ - -/* Timer reload and current value registers */ -struct kwtmr_val { -	u32 reload;	/* Timer reload reg */ -	u32 val;	/* Timer value reg */ -}; - -/* Timer registers */ -struct kwtmr_registers { -	u32 ctrl;	/* Timer control reg */ -	u32 pad[3]; -	struct kwtmr_val tmr[2]; -	u32 wdt_reload; -	u32 wdt_val; -}; - -struct kwtmr_registers *kwtmr_regs = (struct kwtmr_registers *)KW_TIMER_BASE; +#define UBOOT_CNTR	0	/* counter to use for U-Boot timer */  /*   * ARM Timers Registers Map   */ -#define CNTMR_CTRL_REG			&kwtmr_regs->ctrl -#define CNTMR_RELOAD_REG(tmrnum)	&kwtmr_regs->tmr[tmrnum].reload -#define CNTMR_VAL_REG(tmrnum)		&kwtmr_regs->tmr[tmrnum].val +#define CNTMR_CTRL_REG			&tmr_regs->ctrl +#define CNTMR_RELOAD_REG(tmrnum)	&tmr_regs->tmr[tmrnum].reload +#define CNTMR_VAL_REG(tmrnum)		&tmr_regs->tmr[tmrnum].val  /*   * ARM Timers Control Register   * CPU_TIMERS_CTRL_REG (CTCR)   */  #define CTCR_ARM_TIMER_EN_OFFS(cntr)	(cntr * 2) -#define CTCR_ARM_TIMER_EN_MASK(cntr)	(1 << CTCR_ARM_TIMER_EN_OFFS)  #define CTCR_ARM_TIMER_EN(cntr)		(1 << CTCR_ARM_TIMER_EN_OFFS(cntr)) -#define CTCR_ARM_TIMER_DIS(cntr)	(0 << CTCR_ARM_TIMER_EN_OFFS(cntr))  #define CTCR_ARM_TIMER_AUTO_OFFS(cntr)	((cntr * 2) + 1) -#define CTCR_ARM_TIMER_AUTO_MASK(cntr)	(1 << 1)  #define CTCR_ARM_TIMER_AUTO_EN(cntr)	(1 << CTCR_ARM_TIMER_AUTO_OFFS(cntr)) -#define CTCR_ARM_TIMER_AUTO_DIS(cntr)	(0 << CTCR_ARM_TIMER_AUTO_OFFS(cntr)) -/* - * ARM Timer\Watchdog Reload Register - * CNTMR_RELOAD_REG (TRR) - */ -#define TRG_ARM_TIMER_REL_OFFS		0 -#define TRG_ARM_TIMER_REL_MASK		0xffffffff +/* Only Armada XP have the 25MHz enable bit (Kirkwood doesn't) */ +#if defined(CONFIG_ARMADA_XP) +#define CTCR_ARM_TIMER_25MHZ_OFFS(cntr)	(cntr + 11) +#define CTCR_ARM_TIMER_25MHZ(cntr)	(1 << CTCR_ARM_TIMER_25MHZ_OFFS(cntr)) +#else +#define CTCR_ARM_TIMER_25MHZ(cntr)	0 +#endif -/* - * ARM Timer\Watchdog Register - * CNTMR_VAL_REG (TVRG) - */ -#define TVR_ARM_TIMER_OFFS		0 -#define TVR_ARM_TIMER_MASK		0xffffffff -#define TVR_ARM_TIMER_MAX		0xffffffff  #define TIMER_LOAD_VAL 			0xffffffff -#define READ_TIMER			(readl(CNTMR_VAL_REG(UBOOT_CNTR)) /	\ -					 (CONFIG_SYS_TCLK / 1000)) +#define timestamp			gd->arch.tbl +#define lastdec				gd->arch.lastinc + +/* Timer reload and current value registers */ +struct kwtmr_val { +	u32 reload;	/* Timer reload reg */ +	u32 val;	/* Timer value reg */ +}; + +/* Timer registers */ +struct kwtmr_registers { +	u32 ctrl;	/* Timer control reg */ +	u32 pad[3]; +	struct kwtmr_val tmr[4]; +	u32 wdt_reload; +	u32 wdt_val; +};  DECLARE_GLOBAL_DATA_PTR; -#define timestamp gd->arch.tbl -#define lastdec gd->arch.lastinc +static struct kwtmr_registers *tmr_regs = +	(struct kwtmr_registers *)MVEBU_TIMER_BASE; + +static inline ulong read_timer(void) +{ +	return readl(CNTMR_VAL_REG(UBOOT_CNTR))	/ (CONFIG_SYS_TCLK / 1000); +}  ulong get_timer_masked(void)  { -	ulong now = READ_TIMER; +	ulong now = read_timer();  	if (lastdec >= now) {  		/* normal mode */ @@ -119,20 +112,17 @@ void __udelay(unsigned long usec)   */  int timer_init(void)  { -	unsigned int cntmrctrl; -  	/* load value into timer */  	writel(TIMER_LOAD_VAL, CNTMR_RELOAD_REG(UBOOT_CNTR));  	writel(TIMER_LOAD_VAL, CNTMR_VAL_REG(UBOOT_CNTR));  	/* enable timer in auto reload mode */ -	cntmrctrl = readl(CNTMR_CTRL_REG); -	cntmrctrl |= CTCR_ARM_TIMER_EN(UBOOT_CNTR); -	cntmrctrl |= CTCR_ARM_TIMER_AUTO_EN(UBOOT_CNTR); -	writel(cntmrctrl, CNTMR_CTRL_REG); +	clrsetbits_le32(CNTMR_CTRL_REG, CTCR_ARM_TIMER_25MHZ(UBOOT_CNTR), +			CTCR_ARM_TIMER_EN(UBOOT_CNTR) | +			CTCR_ARM_TIMER_AUTO_EN(UBOOT_CNTR));  	/* init the timestamp and lastdec value */ -	lastdec = READ_TIMER; +	lastdec = read_timer();  	timestamp = 0;  	return 0; diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig index 7686b779bf7..9b72bab56b6 100644 --- a/arch/mips/Kconfig +++ b/arch/mips/Kconfig @@ -4,6 +4,9 @@ menu "MIPS architecture"  config SYS_ARCH  	default "mips" +config USE_PRIVATE_LIBGCC +	default y +  choice  	prompt "Target select" diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index ff9935acc4f..0dba8acbb2b 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig @@ -4,6 +4,9 @@ menu "x86 architecture"  config SYS_ARCH  	default "x86" +config USE_PRIVATE_LIBGCC +	default y +  choice  	prompt "Target select" diff --git a/arch/x86/config.mk b/arch/x86/config.mk index 3106079c852..3e7fedb913b 100644 --- a/arch/x86/config.mk +++ b/arch/x86/config.mk @@ -28,6 +28,3 @@ PLATFORM_LDFLAGS += --emit-relocs -Bsymbolic -Bsymbolic-functions -m elf_i386  LDFLAGS_FINAL += --gc-sections -pie  LDFLAGS_FINAL += --wrap=__divdi3 --wrap=__udivdi3  LDFLAGS_FINAL += --wrap=__moddi3 --wrap=__umoddi3 - -export NORMAL_LIBGCC = $(shell $(CC) $(PLATFORM_CPPFLAGS) -print-libgcc-file-name) -CONFIG_USE_PRIVATE_LIBGCC := arch/x86/lib diff --git a/arch/x86/cpu/start.S b/arch/x86/cpu/start.S index 329bb3ab35b..338bab19e47 100644 --- a/arch/x86/cpu/start.S +++ b/arch/x86/cpu/start.S @@ -85,12 +85,25 @@ car_init_ret:  	/* Align global data to 16-byte boundary */  	andl	$0xfffffff0, %esp +	/* Zero the global data since it won't happen later */ +	xorl	%eax, %eax +	movl	$GENERATED_GBL_DATA_SIZE, %ecx +	movl	%esp, %edi +	rep	stosb +  	/* Setup first parameter to setup_gdt */  	movl	%esp, %eax  	/* Reserve space for global descriptor table */  	subl	$X86_GDT_SIZE, %esp +#if defined(CONFIG_SYS_MALLOC_F_LEN) +	subl	$CONFIG_SYS_MALLOC_F_LEN, %esp +	movl	%eax, %edx +	addl	$GD_MALLOC_BASE, %edx +	movl	%esp, (%edx) +#endif +  	/* Align temporary global descriptor table to 16-byte boundary */  	andl	$0xfffffff0, %esp diff --git a/arch/x86/dts/coreboot.dtsi b/arch/x86/dts/coreboot.dtsi index 4862a59704e..c8dc4cec3c9 100644 --- a/arch/x86/dts/coreboot.dtsi +++ b/arch/x86/dts/coreboot.dtsi @@ -1,13 +1,14 @@  /include/ "skeleton.dtsi"  / { -	aliases { -		console = "/serial"; +	chosen { +		stdout-path = "/serial";  	};  	serial { -		compatible = "ns16550"; -		reg-shift = <1>; +		compatible = "coreboot-uart"; +		reg = <0x3f8 0x10>; +		reg-shift = <0>;  		io-mapped = <1>;  		multiplier = <1>;  		baudrate = <115200>; diff --git a/arch/x86/dts/link.dts b/arch/x86/dts/link.dts index 4a37dac4ea9..f2fcb3927cb 100644 --- a/arch/x86/dts/link.dts +++ b/arch/x86/dts/link.dts @@ -12,7 +12,23 @@  	       silent_console = <0>;  	}; -	gpio: gpio {}; +	gpioa { +		compatible = "intel,ich6-gpio"; +		reg = <0 0x10>; +		bank-name = "A"; +	}; + +	gpiob { +		compatible = "intel,ich6-gpio"; +		reg = <0x30 0x10>; +		bank-name = "B"; +	}; + +	gpioc { +		compatible = "intel,ich6-gpio"; +		reg = <0x40 0x10>; +		bank-name = "C"; +	};  	serial {  		reg = <0x3f8 8>; @@ -32,4 +48,22 @@  			memory-map = <0xff800000 0x00800000>;  		};  	}; + +	lpc { +		compatible = "intel,lpc"; +		#address-cells = <1>; +		#size-cells = <1>; +		cros-ec@200 { +			compatible = "google,cros-ec"; +			reg = <0x204 1 0x200 1 0x880 0x80>; + +			/* This describes the flash memory within the EC */ +			#address-cells = <1>; +			#size-cells = <1>; +			flash@8000000 { +				reg = <0x08000000 0x20000>; +				erase-value = <0xff>; +			}; +		}; +	};  }; diff --git a/arch/x86/include/asm/arch-coreboot/gpio.h b/arch/x86/include/asm/arch-coreboot/gpio.h new file mode 100644 index 00000000000..3ec18168339 --- /dev/null +++ b/arch/x86/include/asm/arch-coreboot/gpio.h @@ -0,0 +1,15 @@ +/* + * Copyright (c) 2014, Google Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _X86_ARCH_GPIO_H_ +#define _X86_ARCH_GPIO_H_ + +struct ich6_bank_platdata { +	uint32_t base_addr; +	const char *bank_name; +}; + +#endif /* _X86_ARCH_GPIO_H_ */ diff --git a/arch/x86/include/asm/gpio.h b/arch/x86/include/asm/gpio.h index fe09f315154..8bda414dbd7 100644 --- a/arch/x86/include/asm/gpio.h +++ b/arch/x86/include/asm/gpio.h @@ -6,6 +6,7 @@  #ifndef _X86_GPIO_H_  #define _X86_GPIO_H_ +#include <asm/arch/gpio.h>  #include <asm-generic/gpio.h>  #endif /* _X86_GPIO_H_ */ diff --git a/arch/x86/include/asm/ibmpc.h b/arch/x86/include/asm/ibmpc.h index 0f9665f5495..e6d183b4796 100644 --- a/arch/x86/include/asm/ibmpc.h +++ b/arch/x86/include/asm/ibmpc.h @@ -18,14 +18,4 @@  #define SYSCTLA         0x92  #define SLAVE_PIC       0xa0 -#if 1 -#define UART0_BASE     0x3f8 -#define UART1_BASE     0x2f8 -#else -/* FixMe: uarts swapped */ -#define UART0_BASE     0x2f8 -#define UART1_BASE     0x3f8 -#endif - -  #endif diff --git a/arch/x86/lib/Makefile b/arch/x86/lib/Makefile index f7303abccbd..25b672a0c13 100644 --- a/arch/x86/lib/Makefile +++ b/arch/x86/lib/Makefile @@ -20,9 +20,9 @@ obj-$(CONFIG_SYS_X86_TSC_TIMER)	+= tsc_timer.o  obj-$(CONFIG_VIDEO_VGA)	+= video.o  obj-$(CONFIG_CMD_ZBOOT)	+= zimage.o -LIBGCC := $(notdir $(NORMAL_LIBGCC)) -extra-y := $(LIBGCC) +extra-$(CONFIG_USE_PRIVATE_LIBGCC) := lib.a +NORMAL_LIBGCC = $(shell $(CC) $(PLATFORM_CPPFLAGS) -print-libgcc-file-name)  OBJCOPYFLAGS := --prefix-symbols=__normal_ -$(obj)/$(LIBGCC): $(NORMAL_LIBGCC) FORCE +$(obj)/lib.a: $(NORMAL_LIBGCC) FORCE  	$(call if_changed,objcopy) diff --git a/arch/x86/lib/zimage.c b/arch/x86/lib/zimage.c index 2f0e92f123a..b1902834e8a 100644 --- a/arch/x86/lib/zimage.c +++ b/arch/x86/lib/zimage.c @@ -282,7 +282,6 @@ void boot_zimage(void *setup_base, void *load_address)  	:: [kernel_entry]"a"(load_address),  	   [boot_params] "S"(setup_base),  	   "b"(0), "D"(0) -	:  "%ebp"  	);  } | 
