diff options
Diffstat (limited to 'arch')
141 files changed, 3228 insertions, 1807 deletions
| diff --git a/arch/arm/config.mk b/arch/arm/config.mk index 540a1192c..ce3903ba9 100644 --- a/arch/arm/config.mk +++ b/arch/arm/config.mk @@ -8,7 +8,7 @@  CROSS_COMPILE ?= arm-linux-  ifndef CONFIG_STANDALONE_LOAD_ADDR -ifneq ($(CONFIG_AM33XX)$(CONFIG_OMAP34XX)$(CONFIG_OMAP44XX)$(CONFIG_OMAP54XX)$(CONFIG_TI814X),) +ifneq ($(CONFIG_OMAP_COMMON),)  CONFIG_STANDALONE_LOAD_ADDR = 0x80300000  else  CONFIG_STANDALONE_LOAD_ADDR = 0xc100000 diff --git a/arch/arm/cpu/arm1136/omap24xx/Makefile b/arch/arm/cpu/arm1136/omap24xx/Makefile deleted file mode 100644 index 7d76d96ca..000000000 --- a/arch/arm/cpu/arm1136/omap24xx/Makefile +++ /dev/null @@ -1,31 +0,0 @@ -# -# (C) Copyright 2000-2006 -# Wolfgang Denk, DENX Software Engineering, wd@denx.de. -# -# SPDX-License-Identifier:	GPL-2.0+ -# - -include $(TOPDIR)/config.mk - -LIB	= $(obj)lib$(SOC).o - -SOBJS	= reset.o - -COBJS	= timer.o - -SRCS	:= $(SOBJS:.o=.S) $(COBJS:.o=.c) -OBJS	:= $(addprefix $(obj),$(SOBJS) $(COBJS)) - -all:	$(obj).depend $(LIB) - -$(LIB):	$(OBJS) -	$(call cmd_link_o_target, $(OBJS)) - -######################################################################### - -# defines $(obj).depend target -include $(SRCTREE)/rules.mk - -sinclude $(obj).depend - -######################################################################### diff --git a/arch/arm/cpu/arm1136/omap24xx/reset.S b/arch/arm/cpu/arm1136/omap24xx/reset.S deleted file mode 100644 index dd0752b28..000000000 --- a/arch/arm/cpu/arm1136/omap24xx/reset.S +++ /dev/null @@ -1,26 +0,0 @@ -/* - *  armboot - Startup Code for OMP2420/ARM1136 CPU-core - * - *  Copyright (c) 2004	Texas Instruments <r-woodruff2@ti.com> - * - *  Copyright (c) 2001	Marius Gröger <mag@sysgo.de> - *  Copyright (c) 2002	Alex Züpke <azu@sysgo.de> - *  Copyright (c) 2002	Gary Jennejohn <garyj@denx.de> - *  Copyright (c) 2003	Richard Woodruff <r-woodruff2@ti.com> - *  Copyright (c) 2003	Kshitij <kshitij@ti.com> - * - * SPDX-License-Identifier:	GPL-2.0+  - */ - -#include <asm/arch/omap2420.h> - -.globl reset_cpu -reset_cpu: -	ldr	r1, rstctl	/* get addr for global reset reg */ -	mov	r3, #0x2	/* full reset pll+mpu */ -	str	r3, [r1]	/* force reset */ -	mov	r0, r0 -_loop_forever: -	b	_loop_forever -rstctl: -	.word	PM_RSTCTRL_WKUP diff --git a/arch/arm/cpu/arm1136/omap24xx/timer.c b/arch/arm/cpu/arm1136/omap24xx/timer.c deleted file mode 100644 index b1eef27da..000000000 --- a/arch/arm/cpu/arm1136/omap24xx/timer.c +++ /dev/null @@ -1,136 +0,0 @@ -/* - * (C) Copyright 2004 - * Texas Instruments - * Richard Woodruff <r-woodruff2@ti.com> - * - * (C) Copyright 2002 - * Sysgo Real-Time Solutions, GmbH <www.elinos.com> - * Marius Groeger <mgroeger@sysgo.de> - * Alex Zuepke <azu@sysgo.de> - * - * (C) Copyright 2002 - * Gary Jennejohn, DENX Software Engineering, <garyj@denx.de> - * - * SPDX-License-Identifier:	GPL-2.0+ - */ - -#include <common.h> -#include <asm/io.h> -#include <asm/arch/bits.h> -#include <asm/arch/omap2420.h> - -#define TIMER_CLOCK	(CONFIG_SYS_CLK_FREQ / (2 << CONFIG_SYS_PTV)) -#define TIMER_LOAD_VAL 0 - -/* macro to read the 32 bit timer */ -#define READ_TIMER	readl(CONFIG_SYS_TIMERBASE+TCRR) \ -			/ (TIMER_CLOCK / CONFIG_SYS_HZ) - -DECLARE_GLOBAL_DATA_PTR; - -int timer_init (void) -{ -	int32_t val; - -	/* Start the counter ticking up */ -	*((int32_t *) (CONFIG_SYS_TIMERBASE + TLDR)) = TIMER_LOAD_VAL;	/* reload value on overflow*/ -	val = (CONFIG_SYS_PTV << 2) | BIT5 | BIT1 | BIT0;		/* mask to enable timer*/ -	*((int32_t *) (CONFIG_SYS_TIMERBASE + TCLR)) = val;	/* start timer */ - -	/* reset time */ -	gd->arch.lastinc = READ_TIMER;	/* capture current incrementer value */ -	gd->arch.tbl = 0;		/* start "advancing" time stamp */ - -	return(0); -} -/* - * timer without interrupts - */ -ulong get_timer (ulong base) -{ -	return get_timer_masked () - base; -} - -/* delay x useconds AND preserve advance timestamp value */ -void __udelay (unsigned long usec) -{ -	ulong tmo, tmp; - -	if (usec >= 1000) {		/* if "big" number, spread normalization to seconds */ -		tmo = usec / 1000;	/* start to normalize for usec to ticks per sec */ -		tmo *= CONFIG_SYS_HZ;	/* find number of "ticks" to wait to achieve target */ -		tmo /= 1000;		/* finish normalize. */ -	} else {			/* else small number, don't kill it prior to HZ multiply */ -		tmo = usec * CONFIG_SYS_HZ; -		tmo /= (1000*1000); -	} - -	tmp = get_timer (0);		/* get current timestamp */ -	if ((tmo + tmp + 1) < tmp) {	/* if setting this forward will roll */ -					/* time stamp, then reset time */ -		gd->arch.lastinc = READ_TIMER;	/* capture incrementer value */ -		gd->arch.tbl = 0;			/* start time stamp */ -	} else { -		tmo	+= tmp;		/* else, set advancing stamp wake up time */ -	} -	while (get_timer_masked () < tmo)/* loop till event */ -		/*NOP*/; -} - -ulong get_timer_masked (void) -{ -	ulong now = READ_TIMER;		/* current tick value */ - -	if (now >= gd->arch.lastinc) {		/* normal mode (non roll) */ -		/* move stamp fordward with absoulte diff ticks */ -		gd->arch.tbl += (now - gd->arch.lastinc); -	} else { -		/* we have rollover of incrementer */ -		gd->arch.tbl += ((0xFFFFFFFF / (TIMER_CLOCK / CONFIG_SYS_HZ)) -				 - gd->arch.lastinc) + now; -	} -	gd->arch.lastinc = now; -	return gd->arch.tbl; -} - -/* waits specified delay value and resets timestamp */ -void udelay_masked (unsigned long usec) -{ -	ulong tmo; -	ulong endtime; -	signed long diff; - -	if (usec >= 1000) {			/* if "big" number, spread normalization to seconds */ -		tmo = usec / 1000;		/* start to normalize for usec to ticks per sec */ -		tmo *= CONFIG_SYS_HZ;			/* find number of "ticks" to wait to achieve target */ -		tmo /= 1000;			/* finish normalize. */ -	} else {					/* else small number, don't kill it prior to HZ multiply */ -		tmo = usec * CONFIG_SYS_HZ; -		tmo /= (1000*1000); -	} -	endtime = get_timer_masked () + tmo; - -	do { -		ulong now = get_timer_masked (); -		diff = endtime - now; -	} while (diff >= 0); -} - -/* - * This function is derived from PowerPC code (read timebase as long long). - * On ARM it just returns the timer value. - */ -unsigned long long get_ticks(void) -{ -	return get_timer(0); -} -/* - * This function is derived from PowerPC code (timebase clock frequency). - * On ARM it returns the number of timer ticks per second. - */ -ulong get_tbclk (void) -{ -	ulong tbclk; -	tbclk = CONFIG_SYS_HZ; -	return tbclk; -} diff --git a/arch/arm/cpu/arm926ejs/davinci/da850_lowlevel.c b/arch/arm/cpu/arm926ejs/davinci/da850_lowlevel.c index f6bf1ef8c..a3bbbb869 100644 --- a/arch/arm/cpu/arm926ejs/davinci/da850_lowlevel.c +++ b/arch/arm/cpu/arm926ejs/davinci/da850_lowlevel.c @@ -299,7 +299,11 @@ int arch_cpu_init(void)  	 */  	writel((DAVINCI_UART_PWREMU_MGMT_FREE | DAVINCI_UART_PWREMU_MGMT_URRST |  		DAVINCI_UART_PWREMU_MGMT_UTRST), +#if (CONFIG_SYS_NS16550_COM1 == DAVINCI_UART0_BASE) +	       &davinci_uart0_ctrl_regs->pwremu_mgmt); +#else  	       &davinci_uart2_ctrl_regs->pwremu_mgmt); +#endif  #if defined(CONFIG_SYS_DA850_DDR_INIT)  	da850_ddr_setup(); diff --git a/arch/arm/cpu/arm926ejs/davinci/da850_pinmux.c b/arch/arm/cpu/arm926ejs/davinci/da850_pinmux.c index f603f2fe9..6105f6390 100644 --- a/arch/arm/cpu/arm926ejs/davinci/da850_pinmux.c +++ b/arch/arm/cpu/arm926ejs/davinci/da850_pinmux.c @@ -28,6 +28,11 @@ const struct pinmux_config uart0_pins_txrx[] = {  	{ pinmux(3), 2, 5 }, /* UART0_TXD */  }; +const struct pinmux_config uart0_pins_rtscts[] = { +	{ pinmux(3), 2, 6 }, +	{ pinmux(3), 2, 7 }, +}; +  const struct pinmux_config uart1_pins_txrx[] = {  	{ pinmux(4), 2, 6 }, /* UART1_RXD */  	{ pinmux(4), 2, 7 }, /* UART1_TXD */ @@ -51,6 +56,7 @@ const struct pinmux_config emac_pins_rmii[] = {  	{ pinmux(14), 8, 5 }, /* RMII_RXD[1] */  	{ pinmux(14), 8, 6 }, /* RMII_RXD[0] */  	{ pinmux(14), 8, 7 }, /* RMII_RXER */ +	{ pinmux(15), 0, 0 }, /* RMII_MHz_50_CLK */  	{ pinmux(15), 8, 1 }, /* RMII_CRS_DV */  }; diff --git a/arch/arm/cpu/armv7/Makefile b/arch/arm/cpu/armv7/Makefile index 2ba88d0a9..b723e22a5 100644 --- a/arch/arm/cpu/armv7/Makefile +++ b/arch/arm/cpu/armv7/Makefile @@ -16,7 +16,7 @@ COBJS	+= cache_v7.o  COBJS	+= cpu.o  COBJS	+= syslib.o -ifneq ($(CONFIG_AM33XX)$(CONFIG_OMAP44XX)$(CONFIG_OMAP54XX)$(CONFIG_TEGRA)$(CONFIG_MX6)$(CONFIG_TI814X),) +ifneq ($(CONFIG_AM43XX)$(CONFIG_AM33XX)$(CONFIG_OMAP44XX)$(CONFIG_OMAP54XX)$(CONFIG_TEGRA)$(CONFIG_MX6)$(CONFIG_TI81XX),)  SOBJS	+= lowlevel_init.o  endif diff --git a/arch/arm/cpu/armv7/am33xx/Makefile b/arch/arm/cpu/armv7/am33xx/Makefile index dbd1ec3c0..f6a297c9d 100644 --- a/arch/arm/cpu/armv7/am33xx/Makefile +++ b/arch/arm/cpu/armv7/am33xx/Makefile @@ -10,6 +10,13 @@ LIB	= $(obj)lib$(SOC).o  COBJS-$(CONFIG_AM33XX)	+= clock_am33xx.o  COBJS-$(CONFIG_TI814X)	+= clock_ti814x.o +COBJS-$(CONFIG_AM43XX)	+= clock_am43xx.o + +ifneq ($(CONFIG_AM43XX)$(CONFIG_AM33XX),) +COBJS	+= clock.o +endif + +COBJS-$(CONFIG_TI816X)	+= clock_ti816x.o  COBJS	+= sys_info.o  COBJS	+= mem.o  COBJS	+= ddr.o diff --git a/arch/arm/cpu/armv7/am33xx/board.c b/arch/arm/cpu/armv7/am33xx/board.c index 07ab91c3e..2ea3d698f 100644 --- a/arch/arm/cpu/armv7/am33xx/board.c +++ b/arch/arm/cpu/armv7/am33xx/board.c @@ -56,12 +56,6 @@ int cpu_mmc_init(bd_t *bis)  }  #endif -void setup_clocks_for_console(void) -{ -	/* Not yet implemented */ -	return; -} -  /* AM33XX has two MUSB controllers which can be host or gadget */  #if (defined(CONFIG_MUSB_GADGET) || defined(CONFIG_MUSB_HOST)) && \  	(defined(CONFIG_AM335X_USB0) || defined(CONFIG_AM335X_USB1)) @@ -142,8 +136,8 @@ int arch_misc_init(void)  	return 0;  } -#ifdef CONFIG_SPL_BUILD -void rtc32k_enable(void) +#if defined(CONFIG_SPL_BUILD) || defined(CONFIG_NOR_BOOT) +static void rtc32k_enable(void)  {  	struct rtc_regs *rtc = (struct rtc_regs *)RTC_BASE; @@ -159,11 +153,7 @@ void rtc32k_enable(void)  	writel((1 << 3) | (1 << 6), &rtc->osc);  } -#define UART_RESET		(0x1 << 1) -#define UART_CLK_RUNNING_MASK	0x1 -#define UART_SMART_IDLE_EN	(0x1 << 0x3) - -void uart_soft_reset(void) +static void uart_soft_reset(void)  {  	struct uart_sys *uart_base = (struct uart_sys *)DEFAULT_UART_BASE;  	u32 regval; @@ -180,4 +170,58 @@ void uart_soft_reset(void)  	regval |= UART_SMART_IDLE_EN;  	writel(regval, &uart_base->uartsyscfg);  } + +static void watchdog_disable(void) +{ +	struct wd_timer *wdtimer = (struct wd_timer *)WDT_BASE; + +	writel(0xAAAA, &wdtimer->wdtwspr); +	while (readl(&wdtimer->wdtwwps) != 0x0) +		; +	writel(0x5555, &wdtimer->wdtwspr); +	while (readl(&wdtimer->wdtwwps) != 0x0) +		; +} +#endif + +void s_init(void) +{ +	/* +	 * The ROM will only have set up sufficient pinmux to allow for the +	 * first 4KiB NOR to be read, we must finish doing what we know of +	 * the NOR mux in this space in order to continue. +	 */ +#ifdef CONFIG_NOR_BOOT +	enable_norboot_pin_mux(); +#endif +	/* +	 * Save the boot parameters passed from romcode. +	 * We cannot delay the saving further than this, +	 * to prevent overwrites. +	 */ +#ifdef CONFIG_SPL_BUILD +	save_omap_boot_params(); +#endif +#if defined(CONFIG_SPL_BUILD) || defined(CONFIG_NOR_BOOT) +	watchdog_disable(); +	timer_init(); +	set_uart_mux_conf(); +	setup_clocks_for_console(); +	uart_soft_reset();  #endif +#ifdef CONFIG_NOR_BOOT +	gd->baudrate = CONFIG_BAUDRATE; +	serial_init(); +	gd->have_console = 1; +#else +	gd = &gdata; +	preloader_console_init(); +#endif +#if defined(CONFIG_SPL_BUILD) || defined(CONFIG_NOR_BOOT) +	prcm_init(); +	set_mux_conf_regs(); +	/* Enable RTC32K clock */ +	rtc32k_enable(); +	sdram_init(); +#endif +} diff --git a/arch/arm/cpu/armv7/am33xx/clock.c b/arch/arm/cpu/armv7/am33xx/clock.c new file mode 100644 index 000000000..8e5f3c671 --- /dev/null +++ b/arch/arm/cpu/armv7/am33xx/clock.c @@ -0,0 +1,171 @@ +/* + * clock.c + * + * Clock initialization for AM33XX boards. + * Derived from OMAP4 boards + * + * Copyright (C) 2013, Texas Instruments, Incorporated - http://www.ti.com/ + * + * SPDX-License-Identifier:	GPL-2.0+ + */ +#include <common.h> +#include <asm/arch/cpu.h> +#include <asm/arch/clock.h> +#include <asm/arch/hardware.h> +#include <asm/arch/sys_proto.h> +#include <asm/io.h> + +static void setup_post_dividers(const struct dpll_regs *dpll_regs, +			 const struct dpll_params *params) +{ +	/* Setup post-dividers */ +	if (params->m2 >= 0) +		writel(params->m2, dpll_regs->cm_div_m2_dpll); +	if (params->m3 >= 0) +		writel(params->m3, dpll_regs->cm_div_m3_dpll); +	if (params->m4 >= 0) +		writel(params->m4, dpll_regs->cm_div_m4_dpll); +	if (params->m5 >= 0) +		writel(params->m5, dpll_regs->cm_div_m5_dpll); +	if (params->m6 >= 0) +		writel(params->m6, dpll_regs->cm_div_m6_dpll); +} + +static inline void do_lock_dpll(const struct dpll_regs *dpll_regs) +{ +	clrsetbits_le32(dpll_regs->cm_clkmode_dpll, +			CM_CLKMODE_DPLL_DPLL_EN_MASK, +			DPLL_EN_LOCK << CM_CLKMODE_DPLL_EN_SHIFT); +} + +static inline void wait_for_lock(const struct dpll_regs *dpll_regs) +{ +	if (!wait_on_value(ST_DPLL_CLK_MASK, ST_DPLL_CLK_MASK, +			   (void *)dpll_regs->cm_idlest_dpll, LDELAY)) { +		printf("DPLL locking failed for 0x%x\n", +		       dpll_regs->cm_clkmode_dpll); +		hang(); +	} +} + +static inline void do_bypass_dpll(const struct dpll_regs *dpll_regs) +{ +	clrsetbits_le32(dpll_regs->cm_clkmode_dpll, +			CM_CLKMODE_DPLL_DPLL_EN_MASK, +			DPLL_EN_MN_BYPASS << CM_CLKMODE_DPLL_EN_SHIFT); +} + +static inline void wait_for_bypass(const struct dpll_regs *dpll_regs) +{ +	if (!wait_on_value(ST_DPLL_CLK_MASK, 0, +			   (void *)dpll_regs->cm_idlest_dpll, LDELAY)) { +		printf("Bypassing DPLL failed 0x%x\n", +		       dpll_regs->cm_clkmode_dpll); +	} +} + +static void bypass_dpll(const struct dpll_regs *dpll_regs) +{ +	do_bypass_dpll(dpll_regs); +	wait_for_bypass(dpll_regs); +} + +void do_setup_dpll(const struct dpll_regs *dpll_regs, +		   const struct dpll_params *params) +{ +	u32 temp; + +	if (!params) +		return; + +	temp = readl(dpll_regs->cm_clksel_dpll); + +	bypass_dpll(dpll_regs); + +	/* Set M & N */ +	temp &= ~CM_CLKSEL_DPLL_M_MASK; +	temp |= (params->m << CM_CLKSEL_DPLL_M_SHIFT) & CM_CLKSEL_DPLL_M_MASK; + +	temp &= ~CM_CLKSEL_DPLL_N_MASK; +	temp |= (params->n << CM_CLKSEL_DPLL_N_SHIFT) & CM_CLKSEL_DPLL_N_MASK; + +	writel(temp, dpll_regs->cm_clksel_dpll); + +	setup_post_dividers(dpll_regs, params); + +	/* Wait till the DPLL locks */ +	do_lock_dpll(dpll_regs); +	wait_for_lock(dpll_regs); +} + +static void setup_dplls(void) +{ +	const struct dpll_params *params; +	do_setup_dpll(&dpll_core_regs, &dpll_core); +	do_setup_dpll(&dpll_mpu_regs, &dpll_mpu); +	do_setup_dpll(&dpll_per_regs, &dpll_per); +	writel(0x300, &cmwkup->clkdcoldodpllper); + +	params = get_dpll_ddr_params(); +	do_setup_dpll(&dpll_ddr_regs, params); +} + +static inline void wait_for_clk_enable(u32 *clkctrl_addr) +{ +	u32 clkctrl, idlest = MODULE_CLKCTRL_IDLEST_DISABLED; +	u32 bound = LDELAY; + +	while ((idlest == MODULE_CLKCTRL_IDLEST_DISABLED) || +		(idlest == MODULE_CLKCTRL_IDLEST_TRANSITIONING)) { +		clkctrl = readl(clkctrl_addr); +		idlest = (clkctrl & MODULE_CLKCTRL_IDLEST_MASK) >> +			 MODULE_CLKCTRL_IDLEST_SHIFT; +		if (--bound == 0) { +			printf("Clock enable failed for 0x%p idlest 0x%x\n", +			       clkctrl_addr, clkctrl); +			return; +		} +	} +} + +static inline void enable_clock_module(u32 *const clkctrl_addr, u32 enable_mode, +				       u32 wait_for_enable) +{ +	clrsetbits_le32(clkctrl_addr, MODULE_CLKCTRL_MODULEMODE_MASK, +			enable_mode << MODULE_CLKCTRL_MODULEMODE_SHIFT); +	debug("Enable clock module - %p\n", clkctrl_addr); +	if (wait_for_enable) +		wait_for_clk_enable(clkctrl_addr); +} + +static inline void enable_clock_domain(u32 *const clkctrl_reg, u32 enable_mode) +{ +	clrsetbits_le32(clkctrl_reg, CD_CLKCTRL_CLKTRCTRL_MASK, +			enable_mode << CD_CLKCTRL_CLKTRCTRL_SHIFT); +	debug("Enable clock domain - %p\n", clkctrl_reg); +} + +void do_enable_clocks(u32 *const *clk_domains, +		      u32 *const *clk_modules_explicit_en, u8 wait_for_enable) +{ +	u32 i, max = 100; + +	/* Put the clock domains in SW_WKUP mode */ +	for (i = 0; (i < max) && clk_domains[i]; i++) { +		enable_clock_domain(clk_domains[i], +				    CD_CLKCTRL_CLKTRCTRL_SW_WKUP); +	} + +	/* Clock modules that need to be put in SW_EXPLICIT_EN mode */ +	for (i = 0; (i < max) && clk_modules_explicit_en[i]; i++) { +		enable_clock_module(clk_modules_explicit_en[i], +				    MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN, +				    wait_for_enable); +	}; +} + +void prcm_init() +{ +	enable_basic_clocks(); +	setup_dplls(); +} diff --git a/arch/arm/cpu/armv7/am33xx/clock_am33xx.c b/arch/arm/cpu/armv7/am33xx/clock_am33xx.c index fb3fb43dc..e5f287b33 100644 --- a/arch/arm/cpu/armv7/am33xx/clock_am33xx.c +++ b/arch/arm/cpu/armv7/am33xx/clock_am33xx.c @@ -14,392 +14,129 @@  #include <asm/arch/hardware.h>  #include <asm/io.h> -#define PRCM_MOD_EN		0x2 -#define PRCM_FORCE_WAKEUP	0x2 -#define PRCM_FUNCTL		0x0 - -#define PRCM_EMIF_CLK_ACTIVITY	BIT(2) -#define PRCM_L3_GCLK_ACTIVITY	BIT(4) - -#define PLL_BYPASS_MODE		0x4 -#define ST_MN_BYPASS		0x00000100 -#define ST_DPLL_CLK		0x00000001 -#define CLK_SEL_MASK		0x7ffff -#define CLK_DIV_MASK		0x1f -#define CLK_DIV2_MASK		0x7f -#define CLK_SEL_SHIFT		0x8 -#define CLK_MODE_SEL		0x7 -#define CLK_MODE_MASK		0xfffffff8 -#define CLK_DIV_SEL		0xFFFFFFE0 -#define CPGMAC0_IDLE		0x30000 -#define DPLL_CLKDCOLDO_GATE_CTRL        0x300 -  #define OSC	(V_OSCK/1000000) -#define MPUPLL_M	CONFIG_SYS_MPUCLK -#define MPUPLL_N	(OSC-1) -#define MPUPLL_M2	1 +struct cm_perpll *const cmper = (struct cm_perpll *)CM_PER; +struct cm_wkuppll *const cmwkup = (struct cm_wkuppll *)CM_WKUP; +struct cm_dpll *const cmdpll = (struct cm_dpll *)CM_DPLL; +struct cm_rtc *const cmrtc = (struct cm_rtc *)CM_RTC; -/* Core PLL Fdll = 1 GHZ, */ -#define COREPLL_M	1000 -#define COREPLL_N	(OSC-1) +const struct dpll_regs dpll_mpu_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x88, +	.cm_idlest_dpll		= CM_WKUP + 0x20, +	.cm_clksel_dpll		= CM_WKUP + 0x2C, +	.cm_div_m2_dpll		= CM_WKUP + 0xA8, +}; -#define COREPLL_M4	10	/* CORE_CLKOUTM4 = 200 MHZ */ -#define COREPLL_M5	8	/* CORE_CLKOUTM5 = 250 MHZ */ -#define COREPLL_M6	4	/* CORE_CLKOUTM6 = 500 MHZ */ +const struct dpll_regs dpll_core_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x90, +	.cm_idlest_dpll		= CM_WKUP + 0x5C, +	.cm_clksel_dpll		= CM_WKUP + 0x68, +	.cm_div_m4_dpll		= CM_WKUP + 0x80, +	.cm_div_m5_dpll		= CM_WKUP + 0x84, +	.cm_div_m6_dpll		= CM_WKUP + 0xD8, +}; -/* - * USB PHY clock is 960 MHZ. Since, this comes directly from Fdll, Fdll - * frequency needs to be set to 960 MHZ. Hence, - * For clkout = 192 MHZ, Fdll = 960 MHZ, divider values are given below - */ -#define PERPLL_M	960 -#define PERPLL_N	(OSC-1) -#define PERPLL_M2	5 +const struct dpll_regs dpll_per_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x8C, +	.cm_idlest_dpll		= CM_WKUP + 0x70, +	.cm_clksel_dpll		= CM_WKUP + 0x9C, +	.cm_div_m2_dpll		= CM_WKUP + 0xAC, +}; -/* DDR Freq is 266 MHZ for now */ -/* Set Fdll = 400 MHZ , Fdll = M * 2 * CLKINP/ N + 1; clkout = Fdll /(2 * M2) */ -#define DDRPLL_M	266 -#define DDRPLL_N	(OSC-1) -#define DDRPLL_M2	1 +const struct dpll_regs dpll_ddr_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x94, +	.cm_idlest_dpll		= CM_WKUP + 0x34, +	.cm_clksel_dpll		= CM_WKUP + 0x40, +	.cm_div_m2_dpll		= CM_WKUP + 0xA0, +}; -const struct cm_perpll *cmper = (struct cm_perpll *)CM_PER; -const struct cm_wkuppll *cmwkup = (struct cm_wkuppll *)CM_WKUP; -const struct cm_dpll *cmdpll = (struct cm_dpll *)CM_DPLL; -const struct cm_rtc *cmrtc = (struct cm_rtc *)CM_RTC; +const struct dpll_params dpll_mpu = { +		CONFIG_SYS_MPUCLK, OSC-1, 1, -1, -1, -1, -1}; +const struct dpll_params dpll_core = { +		1000, OSC-1, -1, -1, 10, 8, 4}; +const struct dpll_params dpll_per = { +		960, OSC-1, 5, -1, -1, -1, -1}; -static void enable_interface_clocks(void) +void setup_clocks_for_console(void)  { -	/* Enable all the Interconnect Modules */ -	writel(PRCM_MOD_EN, &cmper->l3clkctrl); -	while (readl(&cmper->l3clkctrl) != PRCM_MOD_EN) -		; - -	writel(PRCM_MOD_EN, &cmper->l4lsclkctrl); -	while (readl(&cmper->l4lsclkctrl) != PRCM_MOD_EN) -		; +	clrsetbits_le32(&cmwkup->wkclkstctrl, CD_CLKCTRL_CLKTRCTRL_MASK, +			CD_CLKCTRL_CLKTRCTRL_SW_WKUP << +			CD_CLKCTRL_CLKTRCTRL_SHIFT); -	writel(PRCM_MOD_EN, &cmper->l4fwclkctrl); -	while (readl(&cmper->l4fwclkctrl) != PRCM_MOD_EN) -		; +	clrsetbits_le32(&cmper->l4hsclkstctrl, CD_CLKCTRL_CLKTRCTRL_MASK, +			CD_CLKCTRL_CLKTRCTRL_SW_WKUP << +			CD_CLKCTRL_CLKTRCTRL_SHIFT); -	writel(PRCM_MOD_EN, &cmwkup->wkl4wkclkctrl); -	while (readl(&cmwkup->wkl4wkclkctrl) != PRCM_MOD_EN) -		; - -	writel(PRCM_MOD_EN, &cmper->l3instrclkctrl); -	while (readl(&cmper->l3instrclkctrl) != PRCM_MOD_EN) -		; - -	writel(PRCM_MOD_EN, &cmper->l4hsclkctrl); -	while (readl(&cmper->l4hsclkctrl) != PRCM_MOD_EN) -		; - -	writel(PRCM_MOD_EN, &cmwkup->wkgpio0clkctrl); -	while (readl(&cmwkup->wkgpio0clkctrl) != PRCM_MOD_EN) -		; +	clrsetbits_le32(&cmwkup->wkup_uart0ctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT); +	clrsetbits_le32(&cmper->uart1clkctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT); +	clrsetbits_le32(&cmper->uart2clkctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT); +	clrsetbits_le32(&cmper->uart3clkctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT); +	clrsetbits_le32(&cmper->uart4clkctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT); +	clrsetbits_le32(&cmper->uart5clkctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT);  } -/* - * Force power domain wake up transition - * Ensure that the corresponding interface clock is active before - * using the peripheral - */ -static void power_domain_wkup_transition(void) +void enable_basic_clocks(void)  { -	writel(PRCM_FORCE_WAKEUP, &cmper->l3clkstctrl); -	writel(PRCM_FORCE_WAKEUP, &cmper->l4lsclkstctrl); -	writel(PRCM_FORCE_WAKEUP, &cmwkup->wkclkstctrl); -	writel(PRCM_FORCE_WAKEUP, &cmper->l4fwclkstctrl); -	writel(PRCM_FORCE_WAKEUP, &cmper->l3sclkstctrl); -} +	u32 *const clk_domains[] = { +		&cmper->l3clkstctrl, +		&cmper->l4fwclkstctrl, +		&cmper->l3sclkstctrl, +		&cmper->l4lsclkstctrl, +		&cmwkup->wkclkstctrl, +		&cmper->emiffwclkctrl, +		&cmrtc->clkstctrl, +		0 +	}; -/* - * Enable the peripheral clock for required peripherals - */ -static void enable_per_clocks(void) -{ -	/* Enable the control module though RBL would have done it*/ -	writel(PRCM_MOD_EN, &cmwkup->wkctrlclkctrl); -	while (readl(&cmwkup->wkctrlclkctrl) != PRCM_MOD_EN) -		; +	u32 *const clk_modules_explicit_en[] = { +		&cmper->l3clkctrl, +		&cmper->l4lsclkctrl, +		&cmper->l4fwclkctrl, +		&cmwkup->wkl4wkclkctrl, +		&cmper->l3instrclkctrl, +		&cmper->l4hsclkctrl, +		&cmwkup->wkgpio0clkctrl, +		&cmwkup->wkctrlclkctrl, +		&cmper->timer2clkctrl, +		&cmper->gpmcclkctrl, +		&cmper->elmclkctrl, +		&cmper->mmc0clkctrl, +		&cmper->mmc1clkctrl, +		&cmwkup->wkup_i2c0ctrl, +		&cmper->gpio1clkctrl, +		&cmper->gpio2clkctrl, +		&cmper->gpio3clkctrl, +		&cmper->i2c1clkctrl, +		&cmper->cpgmac0clkctrl, +		&cmper->spi0clkctrl, +		&cmrtc->rtcclkctrl, +		&cmper->usb0clkctrl, +		&cmper->emiffwclkctrl, +		&cmper->emifclkctrl, +		0 +	}; -	/* Enable the module clock */ -	writel(PRCM_MOD_EN, &cmper->timer2clkctrl); -	while (readl(&cmper->timer2clkctrl) != PRCM_MOD_EN) -		; +	do_enable_clocks(clk_domains, clk_modules_explicit_en, 1);  	/* Select the Master osc 24 MHZ as Timer2 clock source */  	writel(0x1, &cmdpll->clktimer2clk); - -	/* UART0 */ -	writel(PRCM_MOD_EN, &cmwkup->wkup_uart0ctrl); -	while (readl(&cmwkup->wkup_uart0ctrl) != PRCM_MOD_EN) -		; - -	/* UART1 */ -#ifdef CONFIG_SERIAL2 -	writel(PRCM_MOD_EN, &cmper->uart1clkctrl); -	while (readl(&cmper->uart1clkctrl) != PRCM_MOD_EN) -		; -#endif /* CONFIG_SERIAL2 */ - -	/* UART2 */ -#ifdef CONFIG_SERIAL3 -	writel(PRCM_MOD_EN, &cmper->uart2clkctrl); -	while (readl(&cmper->uart2clkctrl) != PRCM_MOD_EN) -		; -#endif /* CONFIG_SERIAL3 */ - -	/* UART3 */ -#ifdef CONFIG_SERIAL4 -	writel(PRCM_MOD_EN, &cmper->uart3clkctrl); -	while (readl(&cmper->uart3clkctrl) != PRCM_MOD_EN) -		; -#endif /* CONFIG_SERIAL4 */ - -	/* UART4 */ -#ifdef CONFIG_SERIAL5 -	writel(PRCM_MOD_EN, &cmper->uart4clkctrl); -	while (readl(&cmper->uart4clkctrl) != PRCM_MOD_EN) -		; -#endif /* CONFIG_SERIAL5 */ - -	/* UART5 */ -#ifdef CONFIG_SERIAL6 -	writel(PRCM_MOD_EN, &cmper->uart5clkctrl); -	while (readl(&cmper->uart5clkctrl) != PRCM_MOD_EN) -		; -#endif /* CONFIG_SERIAL6 */ - -	/* GPMC */ -	writel(PRCM_MOD_EN, &cmper->gpmcclkctrl); -	while (readl(&cmper->gpmcclkctrl) != PRCM_MOD_EN) -		; - -	/* ELM */ -	writel(PRCM_MOD_EN, &cmper->elmclkctrl); -	while (readl(&cmper->elmclkctrl) != PRCM_MOD_EN) -		; - -	/* MMC0*/ -	writel(PRCM_MOD_EN, &cmper->mmc0clkctrl); -	while (readl(&cmper->mmc0clkctrl) != PRCM_MOD_EN) -		; - -	/* MMC1 */ -	writel(PRCM_MOD_EN, &cmper->mmc1clkctrl); -	while (readl(&cmper->mmc1clkctrl) != PRCM_MOD_EN) -		; - -	/* i2c0 */ -	writel(PRCM_MOD_EN, &cmwkup->wkup_i2c0ctrl); -	while (readl(&cmwkup->wkup_i2c0ctrl) != PRCM_MOD_EN) -		; - -	/* gpio1 module */ -	writel(PRCM_MOD_EN, &cmper->gpio1clkctrl); -	while (readl(&cmper->gpio1clkctrl) != PRCM_MOD_EN) -		; - -	/* gpio2 module */ -	writel(PRCM_MOD_EN, &cmper->gpio2clkctrl); -	while (readl(&cmper->gpio2clkctrl) != PRCM_MOD_EN) -		; - -	/* gpio3 module */ -	writel(PRCM_MOD_EN, &cmper->gpio3clkctrl); -	while (readl(&cmper->gpio3clkctrl) != PRCM_MOD_EN) -		; - -	/* i2c1 */ -	writel(PRCM_MOD_EN, &cmper->i2c1clkctrl); -	while (readl(&cmper->i2c1clkctrl) != PRCM_MOD_EN) -		; - -	/* Ethernet */ -	writel(PRCM_MOD_EN, &cmper->cpgmac0clkctrl); -	while ((readl(&cmper->cpgmac0clkctrl) & CPGMAC0_IDLE) != PRCM_FUNCTL) -		; - -	/* spi0 */ -	writel(PRCM_MOD_EN, &cmper->spi0clkctrl); -	while (readl(&cmper->spi0clkctrl) != PRCM_MOD_EN) -		; - -	/* RTC */ -	writel(PRCM_MOD_EN, &cmrtc->rtcclkctrl); -	while (readl(&cmrtc->rtcclkctrl) != PRCM_MOD_EN) -		; - -	/* MUSB */ -	writel(PRCM_MOD_EN, &cmper->usb0clkctrl); -	while (readl(&cmper->usb0clkctrl) != PRCM_MOD_EN) -		; -} - -void mpu_pll_config_val(int mpull_m) -{ -	u32 clkmode, clksel, div_m2; - -	clkmode = readl(&cmwkup->clkmoddpllmpu); -	clksel = readl(&cmwkup->clkseldpllmpu); -	div_m2 = readl(&cmwkup->divm2dpllmpu); - -	/* Set the PLL to bypass Mode */ -	writel(PLL_BYPASS_MODE, &cmwkup->clkmoddpllmpu); -	while (readl(&cmwkup->idlestdpllmpu) != ST_MN_BYPASS) -		; - -	clksel = clksel & (~CLK_SEL_MASK); -	clksel = clksel | ((mpull_m << CLK_SEL_SHIFT) | MPUPLL_N); -	writel(clksel, &cmwkup->clkseldpllmpu); - -	div_m2 = div_m2 & ~CLK_DIV_MASK; -	div_m2 = div_m2 | MPUPLL_M2; -	writel(div_m2, &cmwkup->divm2dpllmpu); - -	clkmode = clkmode | CLK_MODE_SEL; -	writel(clkmode, &cmwkup->clkmoddpllmpu); - -	while (readl(&cmwkup->idlestdpllmpu) != ST_DPLL_CLK) -		; -} - -static void mpu_pll_config(void) -{ -	mpu_pll_config_val(CONFIG_SYS_MPUCLK); -} - -static void core_pll_config(void) -{ -	u32 clkmode, clksel, div_m4, div_m5, div_m6; - -	clkmode = readl(&cmwkup->clkmoddpllcore); -	clksel = readl(&cmwkup->clkseldpllcore); -	div_m4 = readl(&cmwkup->divm4dpllcore); -	div_m5 = readl(&cmwkup->divm5dpllcore); -	div_m6 = readl(&cmwkup->divm6dpllcore); - -	/* Set the PLL to bypass Mode */ -	writel(PLL_BYPASS_MODE, &cmwkup->clkmoddpllcore); - -	while (readl(&cmwkup->idlestdpllcore) != ST_MN_BYPASS) -		; - -	clksel = clksel & (~CLK_SEL_MASK); -	clksel = clksel | ((COREPLL_M << CLK_SEL_SHIFT) | COREPLL_N); -	writel(clksel, &cmwkup->clkseldpllcore); - -	div_m4 = div_m4 & ~CLK_DIV_MASK; -	div_m4 = div_m4 | COREPLL_M4; -	writel(div_m4, &cmwkup->divm4dpllcore); - -	div_m5 = div_m5 & ~CLK_DIV_MASK; -	div_m5 = div_m5 | COREPLL_M5; -	writel(div_m5, &cmwkup->divm5dpllcore); - -	div_m6 = div_m6 & ~CLK_DIV_MASK; -	div_m6 = div_m6 | COREPLL_M6; -	writel(div_m6, &cmwkup->divm6dpllcore); - -	clkmode = clkmode | CLK_MODE_SEL; -	writel(clkmode, &cmwkup->clkmoddpllcore); - -	while (readl(&cmwkup->idlestdpllcore) != ST_DPLL_CLK) -		; -} - -static void per_pll_config(void) -{ -	u32 clkmode, clksel, div_m2; - -	clkmode = readl(&cmwkup->clkmoddpllper); -	clksel = readl(&cmwkup->clkseldpllper); -	div_m2 = readl(&cmwkup->divm2dpllper); - -	/* Set the PLL to bypass Mode */ -	writel(PLL_BYPASS_MODE, &cmwkup->clkmoddpllper); - -	while (readl(&cmwkup->idlestdpllper) != ST_MN_BYPASS) -		; - -	clksel = clksel & (~CLK_SEL_MASK); -	clksel = clksel | ((PERPLL_M << CLK_SEL_SHIFT) | PERPLL_N); -	writel(clksel, &cmwkup->clkseldpllper); - -	div_m2 = div_m2 & ~CLK_DIV2_MASK; -	div_m2 = div_m2 | PERPLL_M2; -	writel(div_m2, &cmwkup->divm2dpllper); - -	clkmode = clkmode | CLK_MODE_SEL; -	writel(clkmode, &cmwkup->clkmoddpllper); - -	while (readl(&cmwkup->idlestdpllper) != ST_DPLL_CLK) -		; - -	writel(DPLL_CLKDCOLDO_GATE_CTRL, &cmwkup->clkdcoldodpllper); -} - -void ddr_pll_config(unsigned int ddrpll_m) -{ -	u32 clkmode, clksel, div_m2; - -	clkmode = readl(&cmwkup->clkmoddpllddr); -	clksel = readl(&cmwkup->clkseldpllddr); -	div_m2 = readl(&cmwkup->divm2dpllddr); - -	/* Set the PLL to bypass Mode */ -	clkmode = (clkmode & CLK_MODE_MASK) | PLL_BYPASS_MODE; -	writel(clkmode, &cmwkup->clkmoddpllddr); - -	/* Wait till bypass mode is enabled */ -	while ((readl(&cmwkup->idlestdpllddr) & ST_MN_BYPASS) -				!= ST_MN_BYPASS) -		; - -	clksel = clksel & (~CLK_SEL_MASK); -	clksel = clksel | ((ddrpll_m << CLK_SEL_SHIFT) | DDRPLL_N); -	writel(clksel, &cmwkup->clkseldpllddr); - -	div_m2 = div_m2 & CLK_DIV_SEL; -	div_m2 = div_m2 | DDRPLL_M2; -	writel(div_m2, &cmwkup->divm2dpllddr); - -	clkmode = (clkmode & CLK_MODE_MASK) | CLK_MODE_SEL; -	writel(clkmode, &cmwkup->clkmoddpllddr); - -	/* Wait till dpll is locked */ -	while ((readl(&cmwkup->idlestdpllddr) & ST_DPLL_CLK) != ST_DPLL_CLK) -		; -} - -void enable_emif_clocks(void) -{ -	/* Enable the  EMIF_FW Functional clock */ -	writel(PRCM_MOD_EN, &cmper->emiffwclkctrl); -	/* Enable EMIF0 Clock */ -	writel(PRCM_MOD_EN, &cmper->emifclkctrl); -	/* Poll if module is functional */ -	while ((readl(&cmper->emifclkctrl)) != PRCM_MOD_EN) -		; -} - -/* - * Configure the PLL/PRCM for necessary peripherals - */ -void pll_init() -{ -	mpu_pll_config(); -	core_pll_config(); -	per_pll_config(); - -	/* Enable the required interconnect clocks */ -	enable_interface_clocks(); - -	/* Power domain wake up transition */ -	power_domain_wkup_transition(); - -	/* Enable the required peripherals */ -	enable_per_clocks();  } diff --git a/arch/arm/cpu/armv7/am33xx/clock_am43xx.c b/arch/arm/cpu/armv7/am33xx/clock_am43xx.c new file mode 100644 index 000000000..c4890f2b4 --- /dev/null +++ b/arch/arm/cpu/armv7/am33xx/clock_am43xx.c @@ -0,0 +1,110 @@ +/* + * clock_am43xx.c + * + * clocks for AM43XX based boards + * Derived from AM33XX based boards + * + * Copyright (C) 2013, Texas Instruments, Incorporated - http://www.ti.com/ + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <common.h> +#include <asm/arch/cpu.h> +#include <asm/arch/clock.h> +#include <asm/arch/hardware.h> +#include <asm/arch/sys_proto.h> +#include <asm/io.h> + +struct cm_perpll *const cmper = (struct cm_perpll *)CM_PER; +struct cm_wkuppll *const cmwkup = (struct cm_wkuppll *)CM_WKUP; + +const struct dpll_regs dpll_mpu_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x560, +	.cm_idlest_dpll		= CM_WKUP + 0x564, +	.cm_clksel_dpll		= CM_WKUP + 0x56c, +	.cm_div_m2_dpll		= CM_WKUP + 0x570, +}; + +const struct dpll_regs dpll_core_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x520, +	.cm_idlest_dpll		= CM_WKUP + 0x524, +	.cm_clksel_dpll		= CM_WKUP + 0x52C, +	.cm_div_m4_dpll		= CM_WKUP + 0x538, +	.cm_div_m5_dpll		= CM_WKUP + 0x53C, +	.cm_div_m6_dpll		= CM_WKUP + 0x540, +}; + +const struct dpll_regs dpll_per_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x5E0, +	.cm_idlest_dpll		= CM_WKUP + 0x5E4, +	.cm_clksel_dpll		= CM_WKUP + 0x5EC, +	.cm_div_m2_dpll		= CM_WKUP + 0x5F0, +}; + +const struct dpll_regs dpll_ddr_regs = { +	.cm_clkmode_dpll	= CM_WKUP + 0x5A0, +	.cm_idlest_dpll		= CM_WKUP + 0x5A4, +	.cm_clksel_dpll		= CM_WKUP + 0x5AC, +	.cm_div_m2_dpll		= CM_WKUP + 0x5B0, +}; + +const struct dpll_params dpll_mpu = { +		-1, -1, -1, -1, -1, -1, -1}; +const struct dpll_params dpll_core = { +		-1, -1, -1, -1, -1, -1, -1}; +const struct dpll_params dpll_per = { +		-1, -1, -1, -1, -1, -1, -1}; + +void setup_clocks_for_console(void) +{ +	/* Do not add any spl_debug prints in this function */ +	clrsetbits_le32(&cmwkup->wkclkstctrl, CD_CLKCTRL_CLKTRCTRL_MASK, +			CD_CLKCTRL_CLKTRCTRL_SW_WKUP << +			CD_CLKCTRL_CLKTRCTRL_SHIFT); + +	/* Enable UART0 */ +	clrsetbits_le32(&cmwkup->wkup_uart0ctrl, +			MODULE_CLKCTRL_MODULEMODE_MASK, +			MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN << +			MODULE_CLKCTRL_MODULEMODE_SHIFT); +} + +void enable_basic_clocks(void) +{ +	u32 *const clk_domains[] = { +		&cmper->l3clkstctrl, +		&cmper->l3sclkstctrl, +		&cmper->l4lsclkstctrl, +		&cmwkup->wkclkstctrl, +		&cmper->emifclkstctrl, +		0 +	}; + +	u32 *const clk_modules_explicit_en[] = { +		&cmper->l3clkctrl, +		&cmper->l4lsclkctrl, +		&cmper->l4fwclkctrl, +		&cmwkup->wkl4wkclkctrl, +		&cmper->l3instrclkctrl, +		&cmper->l4hsclkctrl, +		&cmwkup->wkgpio0clkctrl, +		&cmwkup->wkctrlclkctrl, +		&cmper->timer2clkctrl, +		&cmper->gpmcclkctrl, +		&cmper->elmclkctrl, +		&cmper->mmc0clkctrl, +		&cmper->mmc1clkctrl, +		&cmwkup->wkup_i2c0ctrl, +		&cmper->gpio1clkctrl, +		&cmper->gpio2clkctrl, +		&cmper->gpio3clkctrl, +		&cmper->i2c1clkctrl, +		&cmper->emiffwclkctrl, +		&cmper->emifclkctrl, +		&cmper->otfaemifclkctrl, +		0 +	}; + +	do_enable_clocks(clk_domains, clk_modules_explicit_en, 1); +} diff --git a/arch/arm/cpu/armv7/am33xx/clock_ti814x.c b/arch/arm/cpu/armv7/am33xx/clock_ti814x.c index 658772bbe..ef14f47eb 100644 --- a/arch/arm/cpu/armv7/am33xx/clock_ti814x.c +++ b/arch/arm/cpu/armv7/am33xx/clock_ti814x.c @@ -100,103 +100,8 @@ struct ad_pll {  #define OSC_SRC_CTRL			(PLL_SUBSYS_BASE + 0x2C0) -/* PRCM */  #define ENET_CLKCTRL_CMPL		0x30000 -#define CM_DEFAULT_BASE			(PRCM_BASE + 0x0500) - -struct cm_def { -	unsigned int resv0[2]; -	unsigned int l3fastclkstctrl; -	unsigned int resv1[1]; -	unsigned int pciclkstctrl; -	unsigned int resv2[1]; -	unsigned int ducaticlkstctrl; -	unsigned int resv3[1]; -	unsigned int emif0clkctrl; -	unsigned int emif1clkctrl; -	unsigned int dmmclkctrl; -	unsigned int fwclkctrl; -	unsigned int resv4[10]; -	unsigned int usbclkctrl; -	unsigned int resv5[1]; -	unsigned int sataclkctrl; -	unsigned int resv6[4]; -	unsigned int ducaticlkctrl; -	unsigned int pciclkctrl; -}; - -#define CM_ALWON_BASE			(PRCM_BASE + 0x1400) - -struct cm_alwon { -	unsigned int l3slowclkstctrl; -	unsigned int ethclkstctrl; -	unsigned int l3medclkstctrl; -	unsigned int mmu_clkstctrl; -	unsigned int mmucfg_clkstctrl; -	unsigned int ocmc0clkstctrl; -	unsigned int vcpclkstctrl; -	unsigned int mpuclkstctrl; -	unsigned int sysclk4clkstctrl; -	unsigned int sysclk5clkstctrl; -	unsigned int sysclk6clkstctrl; -	unsigned int rtcclkstctrl; -	unsigned int l3fastclkstctrl; -	unsigned int resv0[67]; -	unsigned int mcasp0clkctrl; -	unsigned int mcasp1clkctrl; -	unsigned int mcasp2clkctrl; -	unsigned int mcbspclkctrl; -	unsigned int uart0clkctrl; -	unsigned int uart1clkctrl; -	unsigned int uart2clkctrl; -	unsigned int gpio0clkctrl; -	unsigned int gpio1clkctrl; -	unsigned int i2c0clkctrl; -	unsigned int i2c1clkctrl; -	unsigned int mcasp345clkctrl; -	unsigned int atlclkctrl; -	unsigned int mlbclkctrl; -	unsigned int pataclkctrl; -	unsigned int resv1[1]; -	unsigned int uart3clkctrl; -	unsigned int uart4clkctrl; -	unsigned int uart5clkctrl; -	unsigned int wdtimerclkctrl; -	unsigned int spiclkctrl; -	unsigned int mailboxclkctrl; -	unsigned int spinboxclkctrl; -	unsigned int mmudataclkctrl; -	unsigned int resv2[2]; -	unsigned int mmucfgclkctrl; -	unsigned int resv3[2]; -	unsigned int ocmc0clkctrl; -	unsigned int vcpclkctrl; -	unsigned int resv4[2]; -	unsigned int controlclkctrl; -	unsigned int resv5[2]; -	unsigned int gpmcclkctrl; -	unsigned int ethernet0clkctrl; -	unsigned int ethernet1clkctrl; -	unsigned int mpuclkctrl; -	unsigned int debugssclkctrl; -	unsigned int l3clkctrl; -	unsigned int l4hsclkctrl; -	unsigned int l4lsclkctrl; -	unsigned int rtcclkctrl; -	unsigned int tpccclkctrl; -	unsigned int tptc0clkctrl; -	unsigned int tptc1clkctrl; -	unsigned int tptc2clkctrl; -	unsigned int tptc3clkctrl; -	unsigned int resv7[4]; -	unsigned int dcan01clkctrl; -	unsigned int mmchs0clkctrl; -	unsigned int mmchs1clkctrl; -	unsigned int mmchs2clkctrl; -	unsigned int custefuseclkctrl; -}; -  #define SATA_PLL_BASE			(CTRL_BASE + 0x0720)  struct sata_pll { @@ -264,11 +169,6 @@ const struct sata_pll *spll = (struct sata_pll *)SATA_PLL_BASE;   */  static void enable_per_clocks(void)  { -	/* UART0 */ -	writel(PRCM_MOD_EN, &cmalwon->uart0clkctrl); -	while (readl(&cmalwon->uart0clkctrl) != PRCM_MOD_EN) -		; -  	/* HSMMC1 */  	writel(PRCM_MOD_EN, &cmalwon->mmchs1clkctrl);  	while (readl(&cmalwon->mmchs1clkctrl) != PRCM_MOD_EN) @@ -282,6 +182,12 @@ static void enable_per_clocks(void)  	writel(PRCM_MOD_EN, &cmalwon->ethernet1clkctrl);  	while ((readl(&cmalwon->ethernet1clkctrl) & ENET_CLKCTRL_CMPL) != 0)  		; + +	/* RTC clocks */ +	writel(PRCM_MOD_EN, &cmalwon->rtcclkstctrl); +	writel(PRCM_MOD_EN, &cmalwon->rtcclkctrl); +	while (readl(&cmalwon->rtcclkctrl) != PRCM_MOD_EN) +		;  }  /* @@ -455,8 +361,6 @@ void sata_pll_config(void)  		;  } -void enable_emif_clocks(void) {}; -  void enable_dmm_clocks(void)  {  	writel(PRCM_MOD_EN, &cmdef->fwclkctrl); @@ -477,13 +381,19 @@ void enable_dmm_clocks(void)  		;  } +void setup_clocks_for_console(void) +{ +	unlock_pll_control_mmr(); +	/* UART0 */ +	writel(PRCM_MOD_EN, &cmalwon->uart0clkctrl); +	while (readl(&cmalwon->uart0clkctrl) != PRCM_MOD_EN) +		; +}  /*   * Configure the PLL/PRCM for necessary peripherals   */ -void pll_init() +void prcm_init(void)  { -	unlock_pll_control_mmr(); -  	/* Enable the control module */  	writel(PRCM_MOD_EN, &cmalwon->controlclkctrl); diff --git a/arch/arm/cpu/armv7/am33xx/clock_ti816x.c b/arch/arm/cpu/armv7/am33xx/clock_ti816x.c new file mode 100644 index 000000000..ace4a5afe --- /dev/null +++ b/arch/arm/cpu/armv7/am33xx/clock_ti816x.c @@ -0,0 +1,445 @@ +/* + * clock_ti816x.c + * + * Clocks for TI816X based boards + * + * Copyright (C) 2013, Adeneo Embedded <www.adeneo-embedded.com> + * Antoine Tenart, <atenart@adeneo-embedded.com> + * + * Based on TI-PSP-04.00.02.14 : + * + * Copyright (C) 2009, Texas Instruments, Incorporated + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR /PURPOSE.  See the + * GNU General Public License for more details. + */ + +#include <common.h> +#include <asm/arch/ddr_defs.h> +#include <asm/arch/cpu.h> +#include <asm/arch/clock.h> +#include <asm/arch/hardware.h> +#include <asm/io.h> + +#include <asm/emif.h> + +#define CM_PLL_BASE		(CTRL_BASE + 0x0400) + +/* Main PLL */ +#define MAIN_N			64 +#define MAIN_P			0x1 +#define MAIN_INTFREQ1		0x8 +#define MAIN_FRACFREQ1		0x800000 +#define MAIN_MDIV1		0x2 +#define MAIN_INTFREQ2		0xE +#define MAIN_FRACFREQ2		0x0 +#define MAIN_MDIV2		0x1 +#define MAIN_INTFREQ3		0x8 +#define MAIN_FRACFREQ3		0xAAAAB0 +#define MAIN_MDIV3		0x3 +#define MAIN_INTFREQ4		0x9 +#define MAIN_FRACFREQ4		0x55554F +#define MAIN_MDIV4		0x3 +#define MAIN_INTFREQ5		0x9 +#define MAIN_FRACFREQ5		0x374BC6 +#define MAIN_MDIV5		0xC +#define MAIN_MDIV6		0x48 +#define MAIN_MDIV7		0x4 + +/* DDR PLL */ +#if defined(CONFIG_TI816X_DDR_PLL_400) /* 400 MHz */ +#define DDR_N			59 +#define DDR_P			0x1 +#define DDR_MDIV1		0x4 +#define DDR_INTFREQ2		0x8 +#define DDR_FRACFREQ2		0xD99999 +#define DDR_MDIV2		0x1E +#define DDR_INTFREQ3		0x8 +#define DDR_FRACFREQ3		0x0 +#define DDR_MDIV3		0x4 +#define DDR_INTFREQ4		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ4		0x0 +#define DDR_MDIV4		0x4 +#define DDR_INTFREQ5		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ5		0x0 +#define DDR_MDIV5		0x4 +#elif defined(CONFIG_TI816X_DDR_PLL_531) /* 531 MHz */ +#define DDR_N			59 +#define DDR_P			0x1 +#define DDR_MDIV1		0x3 +#define DDR_INTFREQ2		0x8 +#define DDR_FRACFREQ2		0xD99999 +#define DDR_MDIV2		0x1E +#define DDR_INTFREQ3		0x8 +#define DDR_FRACFREQ3		0x0 +#define DDR_MDIV3		0x4 +#define DDR_INTFREQ4		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ4		0x0 +#define DDR_MDIV4		0x4 +#define DDR_INTFREQ5		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ5		0x0 +#define DDR_MDIV5		0x4 +#elif defined(CONFIG_TI816X_DDR_PLL_675) /* 675 MHz */ +#define DDR_N			50 +#define DDR_P			0x1 +#define DDR_MDIV1		0x2 +#define DDR_INTFREQ2		0x9 +#define DDR_FRACFREQ2		0x0 +#define DDR_MDIV2		0x19 +#define DDR_INTFREQ3		0x13 +#define DDR_FRACFREQ3		0x800000 +#define DDR_MDIV3		0x2 +#define DDR_INTFREQ4		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ4		0x0 +#define DDR_MDIV4		0x4 +#define DDR_INTFREQ5		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ5		0x0 +#define DDR_MDIV5		0x4 +#elif defined(CONFIG_TI816X_DDR_PLL_796) /* 796 MHz */ +#define DDR_N			59 +#define DDR_P			0x1 +#define DDR_MDIV1		0x2 +#define DDR_INTFREQ2		0x8 +#define DDR_FRACFREQ2		0xD99999 +#define DDR_MDIV2		0x1E +#define DDR_INTFREQ3		0x8 +#define DDR_FRACFREQ3		0x0 +#define DDR_MDIV3		0x4 +#define DDR_INTFREQ4		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ4		0x0 +#define DDR_MDIV4		0x4 +#define DDR_INTFREQ5		0xE /* Expansion DDR clk */ +#define DDR_FRACFREQ5		0x0 +#define DDR_MDIV5		0x4 +#endif + +#define CONTROL_STATUS			(CTRL_BASE + 0x40) +#define DDR_RCD				(CTRL_BASE + 0x070C) +#define CM_TIMER1_CLKSEL		(PRCM_BASE + 0x390) +#define DMM_PAT_BASE_ADDR		(DMM_BASE + 0x420) +#define CM_ALWON_CUST_EFUSE_CLKCTRL	(PRCM_BASE + 0x1628) + +#define INTCPS_SYSCONFIG	0x48200010 +#define CM_SYSCLK10_CLKSEL	0x48180324 + +struct cm_pll { +	unsigned int mainpll_ctrl;	/* offset 0x400 */ +	unsigned int mainpll_pwd; +	unsigned int mainpll_freq1; +	unsigned int mainpll_div1; +	unsigned int mainpll_freq2; +	unsigned int mainpll_div2; +	unsigned int mainpll_freq3; +	unsigned int mainpll_div3; +	unsigned int mainpll_freq4; +	unsigned int mainpll_div4; +	unsigned int mainpll_freq5; +	unsigned int mainpll_div5; +	unsigned int resv0[1]; +	unsigned int mainpll_div6; +	unsigned int resv1[1]; +	unsigned int mainpll_div7; +	unsigned int ddrpll_ctrl;	/* offset 0x440 */ +	unsigned int ddrpll_pwd; +	unsigned int resv2[1]; +	unsigned int ddrpll_div1; +	unsigned int ddrpll_freq2; +	unsigned int ddrpll_div2; +	unsigned int ddrpll_freq3; +	unsigned int ddrpll_div3; +	unsigned int ddrpll_freq4; +	unsigned int ddrpll_div4; +	unsigned int ddrpll_freq5; +	unsigned int ddrpll_div5; +	unsigned int videopll_ctrl;	/* offset 0x470 */ +	unsigned int videopll_pwd; +	unsigned int videopll_freq1; +	unsigned int videopll_div1; +	unsigned int videopll_freq2; +	unsigned int videopll_div2; +	unsigned int videopll_freq3; +	unsigned int videopll_div3; +	unsigned int resv3[4]; +	unsigned int audiopll_ctrl;	/* offset 0x4A0 */ +	unsigned int audiopll_pwd; +	unsigned int resv4[2]; +	unsigned int audiopll_freq2; +	unsigned int audiopll_div2; +	unsigned int audiopll_freq3; +	unsigned int audiopll_div3; +	unsigned int audiopll_freq4; +	unsigned int audiopll_div4; +	unsigned int audiopll_freq5; +	unsigned int audiopll_div5; +}; + +const struct cm_alwon *cmalwon = (struct cm_alwon *)CM_ALWON_BASE; +const struct cm_def *cmdef = (struct cm_def *)CM_DEFAULT_BASE; +const struct cm_pll *cmpll = (struct cm_pll *)CM_PLL_BASE; +const struct wd_timer *wdtimer = (struct wd_timer *)WDT_BASE; + +void enable_dmm_clocks(void) +{ +	writel(PRCM_MOD_EN, &cmdef->l3fastclkstctrl); +	writel(PRCM_MOD_EN, &cmdef->emif0clkctrl); +	writel(PRCM_MOD_EN, &cmdef->emif1clkctrl); + +	/* Wait for clocks to be active */ +	while ((readl(&cmdef->l3fastclkstctrl) & 0x300) != 0x300) +		; +	/* Wait for emif0 to be fully functional, including OCP */ +	while (((readl(&cmdef->emif0clkctrl) >> 17) & 0x3) != 0) +		; +	/* Wait for emif1 to be fully functional, including OCP */ +	while (((readl(&cmdef->emif1clkctrl) >> 17) & 0x3) != 0) +		; + +	writel(PRCM_MOD_EN, &cmdef->dmmclkctrl); +	/* Wait for dmm to be fully functional, including OCP */ +	while (((readl(&cmdef->dmmclkctrl) >> 17) & 0x3) != 0) +		; + +	/* Enable Tiled Access */ +	writel(0x80000000, DMM_PAT_BASE_ADDR); +} + +/* assume delay is aprox at least 1us */ +static void ddr_delay(int d) +{ +	int i; + +	/* +	 * read a control register. +	 * this is a bit more delay and cannot be optimized by the compiler +	 * assuming one read takes 200 cycles and A8 is runing 1 GHz +	 * somewhat conservative setting +	 */ +	for (i = 0; i < 50*d; i++) +		readl(CONTROL_STATUS); +} + +static void main_pll_init_ti816x(void) +{ +	u32 main_pll_ctrl = 0; + +	/* Put the PLL in bypass mode by setting BIT2 in its ctrl reg */ +	main_pll_ctrl = readl(&cmpll->mainpll_ctrl); +	main_pll_ctrl &= 0xFFFFFFFB; +	main_pll_ctrl |= BIT(2); +	writel(main_pll_ctrl, &cmpll->mainpll_ctrl); + +	/* Enable PLL by setting BIT3 in its ctrl reg */ +	main_pll_ctrl = readl(&cmpll->mainpll_ctrl); +	main_pll_ctrl &= 0xFFFFFFF7; +	main_pll_ctrl |= BIT(3); +	writel(main_pll_ctrl, &cmpll->mainpll_ctrl); + +	/* Write the values of N,P in the CTRL reg  */ +	main_pll_ctrl = readl(&cmpll->mainpll_ctrl); +	main_pll_ctrl &= 0xFF; +	main_pll_ctrl |= (MAIN_N<<16 | MAIN_P<<8); +	writel(main_pll_ctrl, &cmpll->mainpll_ctrl); + +	/* Power up clock1-7 */ +	writel(0x0, &cmpll->mainpll_pwd); + +	/* Program the freq and divider values for clock1-7 */ +	writel((1<<31 | 1<<28 | (MAIN_INTFREQ1<<24) | MAIN_FRACFREQ1), +		&cmpll->mainpll_freq1); +	writel(((1<<8) | MAIN_MDIV1), &cmpll->mainpll_div1); + +	writel((1<<31 | 1<<28 | (MAIN_INTFREQ2<<24) | MAIN_FRACFREQ2), +		&cmpll->mainpll_freq2); +	writel(((1<<8) | MAIN_MDIV2), &cmpll->mainpll_div2); + +	writel((1<<31 | 1<<28 | (MAIN_INTFREQ3<<24) | MAIN_FRACFREQ3), +		&cmpll->mainpll_freq3); +	writel(((1<<8) | MAIN_MDIV3), &cmpll->mainpll_div3); + +	writel((1<<31 | 1<<28 | (MAIN_INTFREQ4<<24) | MAIN_FRACFREQ4), +		&cmpll->mainpll_freq4); +	writel(((1<<8) | MAIN_MDIV4), &cmpll->mainpll_div4); + +	writel((1<<31 | 1<<28 | (MAIN_INTFREQ5<<24) | MAIN_FRACFREQ5), +		&cmpll->mainpll_freq5); +	writel(((1<<8) | MAIN_MDIV5), &cmpll->mainpll_div5); + +	writel((1<<8 | MAIN_MDIV6), &cmpll->mainpll_div6); + +	writel((1<<8 | MAIN_MDIV7), &cmpll->mainpll_div7); + +	/* Wait for PLL to lock */ +	while ((readl(&cmpll->mainpll_ctrl) & BIT(7)) != BIT(7)) +		; + +	/* Put the PLL in normal mode, disable bypass */ +	main_pll_ctrl = readl(&cmpll->mainpll_ctrl); +	main_pll_ctrl &= 0xFFFFFFFB; +	writel(main_pll_ctrl, &cmpll->mainpll_ctrl); +} + +static void ddr_pll_bypass_ti816x(void) +{ +	u32 ddr_pll_ctrl = 0; + +	/* Put the PLL in bypass mode by setting BIT2 in its ctrl reg */ +	ddr_pll_ctrl = readl(&cmpll->ddrpll_ctrl); +	ddr_pll_ctrl &= 0xFFFFFFFB; +	ddr_pll_ctrl |= BIT(2); +	writel(ddr_pll_ctrl, &cmpll->ddrpll_ctrl); +} + +static void ddr_pll_init_ti816x(void) +{ +	u32 ddr_pll_ctrl = 0; +	/* Enable PLL by setting BIT3 in its ctrl reg */ +	ddr_pll_ctrl = readl(&cmpll->ddrpll_ctrl); +	ddr_pll_ctrl &= 0xFFFFFFF7; +	ddr_pll_ctrl |= BIT(3); +	writel(ddr_pll_ctrl, &cmpll->ddrpll_ctrl); + +	/* Write the values of N,P in the CTRL reg  */ +	ddr_pll_ctrl = readl(&cmpll->ddrpll_ctrl); +	ddr_pll_ctrl &= 0xFF; +	ddr_pll_ctrl |= (DDR_N<<16 | DDR_P<<8); +	writel(ddr_pll_ctrl, &cmpll->ddrpll_ctrl); + +	ddr_delay(10); + +	/* Power up clock1-5 */ +	writel(0x0, &cmpll->ddrpll_pwd); + +	/* Program the freq and divider values for clock1-3 */ +	writel(((0<<8) | DDR_MDIV1), &cmpll->ddrpll_div1); +	ddr_delay(1); +	writel(((1<<8) | DDR_MDIV1), &cmpll->ddrpll_div1); +	writel((1<<31 | 1<<28 | (DDR_INTFREQ2<<24) | DDR_FRACFREQ2), +		&cmpll->ddrpll_freq2); +	writel(((1<<8) | DDR_MDIV2), &cmpll->ddrpll_div2); +	writel(((0<<8) | DDR_MDIV3), &cmpll->ddrpll_div3); +	ddr_delay(1); +	writel(((1<<8) | DDR_MDIV3), &cmpll->ddrpll_div3); +	ddr_delay(1); +	writel((0<<31 | 1<<28 | (DDR_INTFREQ3<<24) | DDR_FRACFREQ3), +		&cmpll->ddrpll_freq3); +	ddr_delay(1); +	writel((1<<31 | 1<<28 | (DDR_INTFREQ3<<24) | DDR_FRACFREQ3), +		&cmpll->ddrpll_freq3); + +	ddr_delay(5); + +	/* Wait for PLL to lock */ +	while ((readl(&cmpll->ddrpll_ctrl) & BIT(7)) != BIT(7)) +		; + +	/* Power up RCD */ +	writel(BIT(0), DDR_RCD); +} + +static void peripheral_enable(void) +{ +	/* Wake-up the l3_slow clock */ +	writel(PRCM_MOD_EN, &cmalwon->l3slowclkstctrl); + +	/* +	 * Note on Timers: +	 * There are 8 timers(0-7) out of which timer 0 is a secure timer. +	 * Timer 0 mux should not be changed +	 * +	 * To access the timer registers we need the to be +	 * enabled which is what we do in the first step +	 */ + +	/* Enable timer1 */ +	writel(PRCM_MOD_EN, &cmalwon->timer1clkctrl); +	/* Select timer1 clock to be CLKIN (27MHz) */ +	writel(BIT(1), CM_TIMER1_CLKSEL); + +	/* Wait for timer1 to be ON-ACTIVE */ +	while (((readl(&cmalwon->l3slowclkstctrl) +					& (0x80000<<1))>>20) != 1) +		; +	/* Wait for timer1 to be enabled */ +	while (((readl(&cmalwon->timer1clkctrl) & 0x30000)>>16) != 0) +		; +	/* Active posted mode */ +	writel(PRCM_MOD_EN, (DM_TIMER1_BASE + 0x54)); +	while (readl(DM_TIMER1_BASE + 0x10) & BIT(0)) +		; +	/* Start timer1  */ +	writel(BIT(0), (DM_TIMER1_BASE + 0x38)); + +	/* eFuse */ +	writel(PRCM_MOD_EN, CM_ALWON_CUST_EFUSE_CLKCTRL); +	while (readl(CM_ALWON_CUST_EFUSE_CLKCTRL) != PRCM_MOD_EN) +		; + +	/* Enable gpio0 */ +	writel(PRCM_MOD_EN, &cmalwon->gpio0clkctrl); +	while (readl(&cmalwon->gpio0clkctrl) != PRCM_MOD_EN) +		; +	writel((BIT(8)), &cmalwon->gpio0clkctrl); + +	/* Enable spi */ +	writel(PRCM_MOD_EN, &cmalwon->spiclkctrl); +	while (readl(&cmalwon->spiclkctrl) != PRCM_MOD_EN) +		; + +	/* Enable i2c0 */ +	writel(PRCM_MOD_EN, &cmalwon->i2c0clkctrl); +	while (readl(&cmalwon->i2c0clkctrl) != PRCM_MOD_EN) +		; + +	/* Enable ethernet0 */ +	writel(PRCM_MOD_EN, &cmalwon->ethclkstctrl); +	writel(PRCM_MOD_EN, &cmalwon->ethernet0clkctrl); +	writel(PRCM_MOD_EN, &cmalwon->ethernet1clkctrl); + +	/* Enable hsmmc */ +	writel(PRCM_MOD_EN, &cmalwon->sdioclkctrl); +	while (readl(&cmalwon->sdioclkctrl) != PRCM_MOD_EN) +		; +} + +void setup_clocks_for_console(void) +{ +	/* Fix ROM code bug - from TI-PSP-04.00.02.14 */ +	writel(0x0, CM_SYSCLK10_CLKSEL); + +	ddr_pll_bypass_ti816x(); + +	/* Enable uart0-2 */ +	writel(PRCM_MOD_EN, &cmalwon->uart0clkctrl); +	while (readl(&cmalwon->uart0clkctrl) != PRCM_MOD_EN) +		; +	writel(PRCM_MOD_EN, &cmalwon->uart1clkctrl); +	while (readl(&cmalwon->uart1clkctrl) != PRCM_MOD_EN) +		; +	writel(PRCM_MOD_EN, &cmalwon->uart2clkctrl); +	while (readl(&cmalwon->uart2clkctrl) != PRCM_MOD_EN) +		; +	while ((readl(&cmalwon->l3slowclkstctrl) & 0x2100) != 0x2100) +		; +} + +void prcm_init(void) +{ +	/* Enable the control */ +	writel(PRCM_MOD_EN, &cmalwon->controlclkctrl); + +	main_pll_init_ti816x(); +	ddr_pll_init_ti816x(); + +	/* +	 * With clk freqs setup to desired values, +	 * enable the required peripherals +	 */ +	peripheral_enable(); +} diff --git a/arch/arm/cpu/armv7/am33xx/emif4.c b/arch/arm/cpu/armv7/am33xx/emif4.c index ad7b70f93..59ad25c5b 100644 --- a/arch/arm/cpu/armv7/am33xx/emif4.c +++ b/arch/arm/cpu/armv7/am33xx/emif4.c @@ -35,16 +35,21 @@ void dram_init_banksize(void)  } -#ifdef CONFIG_SPL_BUILD +#if defined(CONFIG_SPL_BUILD) || defined(CONFIG_NOR_BOOT) +#ifdef CONFIG_TI81XX  static struct dmm_lisa_map_regs *hw_lisa_map_regs =  				(struct dmm_lisa_map_regs *)DMM_BASE; +#endif +#ifndef CONFIG_TI816X  static struct vtp_reg *vtpreg[2] = {  				(struct vtp_reg *)VTP0_CTRL_ADDR,  				(struct vtp_reg *)VTP1_CTRL_ADDR}; +#endif  #ifdef CONFIG_AM33XX  static struct ddr_ctrl *ddrctrl = (struct ddr_ctrl *)DDR_CTRL_ADDR;  #endif +#ifdef CONFIG_TI81XX  void config_dmm(const struct dmm_lisa_map_regs *regs)  {  	enable_dmm_clocks(); @@ -59,7 +64,9 @@ void config_dmm(const struct dmm_lisa_map_regs *regs)  	writel(regs->dmm_lisa_map_1, &hw_lisa_map_regs->dmm_lisa_map_1);  	writel(regs->dmm_lisa_map_0, &hw_lisa_map_regs->dmm_lisa_map_0);  } +#endif +#ifndef CONFIG_TI816X  static void config_vtp(int nr)  {  	writel(readl(&vtpreg[nr]->vtp0ctrlreg) | VTP_CTRL_ENABLE, @@ -74,14 +81,20 @@ static void config_vtp(int nr)  			VTP_CTRL_READY)  		;  } +#endif + +void __weak ddr_pll_config(unsigned int ddrpll_m) +{ +}  void config_ddr(unsigned int pll, unsigned int ioctrl,  		const struct ddr_data *data, const struct cmd_control *ctrl,  		const struct emif_regs *regs, int nr)  { -	enable_emif_clocks();  	ddr_pll_config(pll); +#ifndef CONFIG_TI816X  	config_vtp(nr); +#endif  	config_cmd_ctrl(ctrl, nr);  	config_ddr_data(data, nr); diff --git a/arch/arm/cpu/armv7/am33xx/mem.c b/arch/arm/cpu/armv7/am33xx/mem.c index f81c9a8ba..b6eb46678 100644 --- a/arch/arm/cpu/armv7/am33xx/mem.c +++ b/arch/arm/cpu/armv7/am33xx/mem.c @@ -69,9 +69,13 @@ void gpmc_init(void)  #endif  	/* global settings */  	writel(0x00000008, &gpmc_cfg->sysconfig); -	writel(0x00000100, &gpmc_cfg->irqstatus); -	writel(0x00000100, &gpmc_cfg->irqenable); +	writel(0x00000000, &gpmc_cfg->irqstatus); +	writel(0x00000000, &gpmc_cfg->irqenable); +#ifdef CONFIG_NOR +	writel(0x00000200, &gpmc_cfg->config); +#else  	writel(0x00000012, &gpmc_cfg->config); +#endif  	/*  	 * Disable the GPMC0 config set by ROM code  	 */ diff --git a/arch/arm/cpu/armv7/highbank/timer.c b/arch/arm/cpu/armv7/highbank/timer.c index 792a828cb..b61cd69bc 100644 --- a/arch/arm/cpu/armv7/highbank/timer.c +++ b/arch/arm/cpu/armv7/highbank/timer.c @@ -15,7 +15,7 @@  #undef SYSTIMER_BASE  #define SYSTIMER_BASE		0xFFF34000	/* Timer 0 and 1 base	*/ -#define SYSTIMER_RATE		150000000 +#define SYSTIMER_RATE		(150000000 / 256)  static ulong timestamp;  static ulong lastinc; @@ -29,11 +29,11 @@ int timer_init(void)  	/*  	 * Setup timer0  	 */ +	writel(0, &systimer_base->timer0control);  	writel(SYSTIMER_RELOAD, &systimer_base->timer0load);  	writel(SYSTIMER_RELOAD, &systimer_base->timer0value); -	writel(SYSTIMER_EN | SYSTIMER_32BIT, &systimer_base->timer0control); - -	reset_timer_masked(); +	writel(SYSTIMER_EN | SYSTIMER_32BIT | SYSTIMER_PRESC_256, +		&systimer_base->timer0control);  	return 0; @@ -113,5 +113,5 @@ ulong get_timer_masked(void)  ulong get_tbclk(void)  { -	return CONFIG_SYS_HZ; +	return SYSTIMER_RATE;  } diff --git a/arch/arm/cpu/armv7/mx5/clock.c b/arch/arm/cpu/armv7/mx5/clock.c index fbbb365cb..6bef25445 100644 --- a/arch/arm/cpu/armv7/mx5/clock.c +++ b/arch/arm/cpu/armv7/mx5/clock.c @@ -85,7 +85,7 @@ void set_usboh3_clk(void)  			MXC_CCM_CSCDR1_USBOH3_CLK_PODF(1));  } -void enable_usboh3_clk(unsigned char enable) +void enable_usboh3_clk(bool enable)  {  	unsigned int cg = enable ? MXC_CCM_CCGR_CG_ON : MXC_CCM_CCGR_CG_OFF; @@ -122,7 +122,7 @@ void set_usb_phy_clk(void)  }  #if defined(CONFIG_MX51) -void enable_usb_phy1_clk(unsigned char enable) +void enable_usb_phy1_clk(bool enable)  {  	unsigned int cg = enable ? MXC_CCM_CCGR_CG_ON : MXC_CCM_CCGR_CG_OFF; @@ -131,12 +131,12 @@ void enable_usb_phy1_clk(unsigned char enable)  			MXC_CCM_CCGR2_USB_PHY(cg));  } -void enable_usb_phy2_clk(unsigned char enable) +void enable_usb_phy2_clk(bool enable)  {  	/* i.MX51 has a single USB PHY clock, so do nothing here. */  }  #elif defined(CONFIG_MX53) -void enable_usb_phy1_clk(unsigned char enable) +void enable_usb_phy1_clk(bool enable)  {  	unsigned int cg = enable ? MXC_CCM_CCGR_CG_ON : MXC_CCM_CCGR_CG_OFF; @@ -145,7 +145,7 @@ void enable_usb_phy1_clk(unsigned char enable)  			MXC_CCM_CCGR4_USB_PHY1(cg));  } -void enable_usb_phy2_clk(unsigned char enable) +void enable_usb_phy2_clk(bool enable)  {  	unsigned int cg = enable ? MXC_CCM_CCGR_CG_ON : MXC_CCM_CCGR_CG_OFF; diff --git a/arch/arm/cpu/armv7/mx6/clock.c b/arch/arm/cpu/armv7/mx6/clock.c index 3bdb553ff..7efb0d209 100644 --- a/arch/arm/cpu/armv7/mx6/clock.c +++ b/arch/arm/cpu/armv7/mx6/clock.c @@ -452,6 +452,14 @@ int do_mx6_showclocks(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])  	return 0;  } +void enable_ipu_clock(void) +{ +	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR; +	int reg; +	reg = readl(&mxc_ccm->CCGR3); +	reg |= MXC_CCM_CCGR3_IPU1_IPU_DI0_OFFSET; +	writel(reg, &mxc_ccm->CCGR3); +}  /***************************************************/  U_BOOT_CMD( diff --git a/arch/arm/cpu/armv7/mx6/soc.c b/arch/arm/cpu/armv7/mx6/soc.c index 32572eea6..8150bffb8 100644 --- a/arch/arm/cpu/armv7/mx6/soc.c +++ b/arch/arm/cpu/armv7/mx6/soc.c @@ -16,6 +16,8 @@  #include <asm/imx-common/boot_mode.h>  #include <asm/imx-common/dma.h>  #include <stdbool.h> +#include <asm/arch/mxc_hdmi.h> +#include <asm/arch/crm_regs.h>  struct scu_regs {  	u32	ctrl; @@ -212,3 +214,44 @@ const struct boot_mode soc_boot_modes[] = {  void s_init(void)  {  } + +#ifdef CONFIG_IMX_HDMI +void imx_enable_hdmi_phy(void) +{ +	struct hdmi_regs *hdmi = (struct hdmi_regs *)HDMI_ARB_BASE_ADDR; +	u8 reg; +	reg = readb(&hdmi->phy_conf0); +	reg |= HDMI_PHY_CONF0_PDZ_MASK; +	writeb(reg, &hdmi->phy_conf0); +	udelay(3000); +	reg |= HDMI_PHY_CONF0_ENTMDS_MASK; +	writeb(reg, &hdmi->phy_conf0); +	udelay(3000); +	reg |= HDMI_PHY_CONF0_GEN2_TXPWRON_MASK; +	writeb(reg, &hdmi->phy_conf0); +	writeb(HDMI_MC_PHYRSTZ_ASSERT, &hdmi->mc_phyrstz); +} + +void imx_setup_hdmi(void) +{ +	struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR; +	struct hdmi_regs *hdmi  = (struct hdmi_regs *)HDMI_ARB_BASE_ADDR; +	int reg; + +	/* Turn on HDMI PHY clock */ +	reg = readl(&mxc_ccm->CCGR2); +	reg |=  MXC_CCM_CCGR2_HDMI_TX_IAHBCLK_MASK| +		 MXC_CCM_CCGR2_HDMI_TX_ISFRCLK_MASK; +	writel(reg, &mxc_ccm->CCGR2); +	writeb(HDMI_MC_PHYRSTZ_DEASSERT, &hdmi->mc_phyrstz); +	reg = readl(&mxc_ccm->chsccdr); +	reg &= ~(MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_MASK| +		 MXC_CCM_CHSCCDR_IPU1_DI0_PODF_MASK| +		 MXC_CCM_CHSCCDR_IPU1_DI0_CLK_SEL_MASK); +	reg |= (CHSCCDR_PODF_DIVIDE_BY_3 +		 << MXC_CCM_CHSCCDR_IPU1_DI0_PODF_OFFSET) +		 |(CHSCCDR_IPU_PRE_CLK_540M_PFD +		 << MXC_CCM_CHSCCDR_IPU1_DI0_PRE_CLK_SEL_OFFSET); +	writel(reg, &mxc_ccm->chsccdr); +} +#endif diff --git a/arch/arm/cpu/armv7/omap-common/Makefile b/arch/arm/cpu/armv7/omap-common/Makefile index 98f29d466..75b375326 100644 --- a/arch/arm/cpu/armv7/omap-common/Makefile +++ b/arch/arm/cpu/armv7/omap-common/Makefile @@ -21,7 +21,7 @@ COBJS	+= vc.o  COBJS	+= abb.o  endif -ifneq ($(CONFIG_AM33XX)$(CONFIG_OMAP44XX)$(CONFIG_OMAP54XX)$(CONFIG_TI814X),) +ifeq ($(CONFIG_OMAP34XX),)  COBJS	+= boot-common.o  SOBJS	+= lowlevel_init.o  endif diff --git a/arch/arm/cpu/armv7/omap-common/boot-common.c b/arch/arm/cpu/armv7/omap-common/boot-common.c index 6b9ce369f..6b4772b68 100644 --- a/arch/arm/cpu/armv7/omap-common/boot-common.c +++ b/arch/arm/cpu/armv7/omap-common/boot-common.c @@ -40,7 +40,8 @@ void save_omap_boot_params(void)  	if ((boot_device >= MMC_BOOT_DEVICES_START) &&  	    (boot_device <= MMC_BOOT_DEVICES_END)) { -#if !defined(CONFIG_AM33XX) && !defined(CONFIG_TI81XX) +#if !defined(CONFIG_AM33XX) && !defined(CONFIG_TI81XX) && \ +	!defined(CONFIG_AM43XX)  		if ((omap_hw_init_context() ==  				      OMAP_INIT_CONTEXT_UBOOT_AFTER_SPL)) {  			gd->arch.omap_boot_params.omap_bootmode = diff --git a/arch/arm/cpu/armv7/omap-common/clocks-common.c b/arch/arm/cpu/armv7/omap-common/clocks-common.c index 20fa678f9..758059407 100644 --- a/arch/arm/cpu/armv7/omap-common/clocks-common.c +++ b/arch/arm/cpu/armv7/omap-common/clocks-common.c @@ -196,6 +196,18 @@ static const struct dpll_params *get_ddr_dpll_params  	return &dpll_data->ddr[sysclk_ind];  } +#ifdef CONFIG_DRIVER_TI_CPSW +static const struct dpll_params *get_gmac_dpll_params +			(struct dplls const *dpll_data) +{ +	u32 sysclk_ind = get_sys_clk_index(); + +	if (!dpll_data->gmac) +		return NULL; +	return &dpll_data->gmac[sysclk_ind]; +} +#endif +  static void do_setup_dpll(u32 const base, const struct dpll_params *params,  				u8 lock, char *dpll)  { @@ -398,6 +410,12 @@ static void setup_dplls(void)  	params = get_ddr_dpll_params(*dplls_data);  	do_setup_dpll((*prcm)->cm_clkmode_dpll_ddrphy,  		      params, DPLL_LOCK, "ddr"); + +#ifdef CONFIG_DRIVER_TI_CPSW +	params = get_gmac_dpll_params(*dplls_data); +	do_setup_dpll((*prcm)->cm_clkmode_dpll_gmac, params, +		      DPLL_LOCK, "gmac"); +#endif  }  #ifdef CONFIG_SYS_CLOCKS_ENABLE_ALL diff --git a/arch/arm/cpu/armv7/omap-common/emif-common.c b/arch/arm/cpu/armv7/omap-common/emif-common.c index ece365507..b0e1caa35 100644 --- a/arch/arm/cpu/armv7/omap-common/emif-common.c +++ b/arch/arm/cpu/armv7/omap-common/emif-common.c @@ -153,7 +153,7 @@ static void lpddr2_init(u32 base, const struct emif_regs *regs)  	 * un-locked frequency & default RL  	 */  	writel(regs->sdram_config_init, &emif->emif_sdram_config); -	writel(regs->emif_ddr_phy_ctlr_1, &emif->emif_ddr_phy_ctrl_1); +	writel(regs->emif_ddr_phy_ctlr_1_init, &emif->emif_ddr_phy_ctrl_1);  	do_ext_phy_settings(base, regs); diff --git a/arch/arm/cpu/armv7/omap3/clock.c b/arch/arm/cpu/armv7/omap3/clock.c index 3acbc9c86..e903ed9ac 100644 --- a/arch/arm/cpu/armv7/omap3/clock.c +++ b/arch/arm/cpu/armv7/omap3/clock.c @@ -478,6 +478,24 @@ static void dpll4_init_36xx(u32 sil_index, u32 clk_index)  	wait_on_value(ST_PERIPH_CLK, 2, &prcm_base->idlest_ckgen, LDELAY);  } +static void dpll5_init_36xx(u32 sil_index, u32 clk_index) +{ +	struct prcm *prcm_base = (struct prcm *)PRCM_BASE; +	dpll_param *ptr = (dpll_param *) get_36x_per2_dpll_param(); + +	/* Moving it to the right sysclk base */ +	ptr = ptr + clk_index; + +	/* PER2 DPLL (DPLL5) */ +	sr32(&prcm_base->clken2_pll, 0, 3, PLL_STOP); +	wait_on_value(1, 0, &prcm_base->idlest2_ckgen, LDELAY); +	sr32(&prcm_base->clksel5_pll, 0, 5, ptr->m2); /* set M2 (usbtll_fck) */ +	sr32(&prcm_base->clksel4_pll, 8, 11, ptr->m); /* set m (11-bit multiplier) */ +	sr32(&prcm_base->clksel4_pll, 0, 7, ptr->n); /* set n (7-bit divider)*/ +	sr32(&prcm_base->clken2_pll, 0, 3, PLL_LOCK);   /* lock mode */ +	wait_on_value(1, 1, &prcm_base->idlest2_ckgen, LDELAY); +} +  static void mpu_init_36xx(u32 sil_index, u32 clk_index)  {  	struct prcm *prcm_base = (struct prcm *)PRCM_BASE; @@ -582,7 +600,7 @@ void prcm_init(void)  		dpll3_init_36xx(0, clk_index);  		dpll4_init_36xx(0, clk_index); -		dpll5_init_34xx(0, clk_index); +		dpll5_init_36xx(0, clk_index);  		iva_init_36xx(0, clk_index);  		mpu_init_36xx(0, clk_index); diff --git a/arch/arm/cpu/armv7/omap3/lowlevel_init.S b/arch/arm/cpu/armv7/omap3/lowlevel_init.S index bdf74ea3c..98c3c03a0 100644 --- a/arch/arm/cpu/armv7/omap3/lowlevel_init.S +++ b/arch/arm/cpu/armv7/omap3/lowlevel_init.S @@ -464,6 +464,19 @@ per_36x_dpll_param:  .word 26000,    432,   12,     9,      16,     9,     4,      3,      1  .word 38400,    360,   15,     9,      16,     5,     4,      3,      1 +per2_36x_dpll_param: +/* 12MHz */ +.word PER2_36XX_M_12, PER2_36XX_N_12, 0, PER2_36XX_M2_12 +/* 13MHz */ +.word PER2_36XX_M_13, PER2_36XX_N_13, 0, PER2_36XX_M2_13 +/* 19.2MHz */ +.word PER2_36XX_M_19P2, PER2_36XX_N_19P2, 0, PER2_36XX_M2_19P2 +/* 26MHz */ +.word PER2_36XX_M_26, PER2_36XX_N_26, 0, PER2_36XX_M2_26 +/* 38.4MHz */ +.word PER2_36XX_M_38P4, PER2_36XX_N_38P4, 0, PER2_36XX_M2_38P4 + +  ENTRY(get_36x_mpu_dpll_param)  	adr	r0, mpu_36x_dpll_param  	mov	pc, lr @@ -483,3 +496,8 @@ ENTRY(get_36x_per_dpll_param)  	adr	r0, per_36x_dpll_param  	mov	pc, lr  ENDPROC(get_36x_per_dpll_param) + +ENTRY(get_36x_per2_dpll_param) +	adr	r0, per2_36x_dpll_param +	mov	pc, lr +ENDPROC(get_36x_per2_dpll_param) diff --git a/arch/arm/cpu/armv7/omap3/mem.c b/arch/arm/cpu/armv7/omap3/mem.c index 1832affa5..e64940965 100644 --- a/arch/arm/cpu/armv7/omap3/mem.c +++ b/arch/arm/cpu/armv7/omap3/mem.c @@ -21,6 +21,17 @@  struct gpmc *gpmc_cfg;  #if defined(CONFIG_CMD_NAND) +#if defined(GPMC_NAND_ECC_SP_x8_LAYOUT) || defined(GPMC_NAND_ECC_LP_x8_LAYOUT) +static const u32 gpmc_m_nand[GPMC_MAX_REG] = { +	SMNAND_GPMC_CONFIG1, +	SMNAND_GPMC_CONFIG2, +	SMNAND_GPMC_CONFIG3, +	SMNAND_GPMC_CONFIG4, +	SMNAND_GPMC_CONFIG5, +	SMNAND_GPMC_CONFIG6, +	0, +}; +#else  static const u32 gpmc_m_nand[GPMC_MAX_REG] = {  	M_NAND_GPMC_CONFIG1,  	M_NAND_GPMC_CONFIG2, @@ -29,6 +40,7 @@ static const u32 gpmc_m_nand[GPMC_MAX_REG] = {  	M_NAND_GPMC_CONFIG5,  	M_NAND_GPMC_CONFIG6, 0  }; +#endif  #endif /* CONFIG_CMD_NAND */  #if defined(CONFIG_CMD_ONENAND) diff --git a/arch/arm/cpu/armv7/omap3/sys_info.c b/arch/arm/cpu/armv7/omap3/sys_info.c index 9a3303f70..258786b50 100644 --- a/arch/arm/cpu/armv7/omap3/sys_info.c +++ b/arch/arm/cpu/armv7/omap3/sys_info.c @@ -342,9 +342,9 @@ int print_cpuinfo (void)  	}  	if (CPU_OMAP36XX == get_cpu_family()) -		printf("%s%s-%s ES%s, CPU-OPP2, L3-165MHz, Max CPU Clock %s\n", -			cpu_family_s, cpu_s, sec_s, -			rev_s_37xx[get_cpu_rev()], max_clk); +		printf("%s%s-%s ES%s, CPU-OPP2, L3-200MHz, Max CPU Clock %s\n", +		       cpu_family_s, cpu_s, sec_s, +		       rev_s_37xx[get_cpu_rev()], max_clk);  	else  		printf("%s%s-%s ES%s, CPU-OPP2, L3-165MHz, Max CPU Clock %s\n",  			cpu_family_s, cpu_s, sec_s, diff --git a/arch/arm/cpu/armv7/omap5/hw_data.c b/arch/arm/cpu/armv7/omap5/hw_data.c index ea3554d97..fbbc48662 100644 --- a/arch/arm/cpu/armv7/omap5/hw_data.c +++ b/arch/arm/cpu/armv7/omap5/hw_data.c @@ -247,6 +247,16 @@ static const struct dpll_params ddr_dpll_params_2128mhz[NUM_SYS_CLKS] = {  	{665, 23, 2, 1, 8, -1, -1, -1, -1, -1, -1, -1},		/* 38.4 MHz */  }; +static const struct dpll_params gmac_dpll_params_2000mhz[NUM_SYS_CLKS] = { +	{250, 2, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1},		/* 12 MHz   */ +	{250, 4, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1},		/* 20 MHz   */ +	{119, 1, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1},		/* 16.8 MHz */ +	{625, 11, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1},	/* 19.2 MHz */ +	{500, 12, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1},	/* 26 MHz   */ +	{-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1},	/* 27 MHz   */ +	{625, 23, 4, 10, 40, 8, 10, -1, -1, -1, -1, -1},	/* 38.4 MHz */ +}; +  struct dplls omap5_dplls_es1 = {  	.mpu = mpu_dpll_params_800mhz,  	.core = core_dpll_params_2128mhz_ddr532, @@ -283,6 +293,7 @@ struct dplls dra7xx_dplls = {  	.iva = iva_dpll_params_2330mhz_dra7xx,  	.usb = usb_dpll_params_1920mhz,  	.ddr = ddr_dpll_params_2128mhz, +	.gmac = gmac_dpll_params_2000mhz,  };  struct pmic_data palmas = { @@ -382,6 +393,9 @@ void enable_basic_clocks(void)  		(*prcm)->cm_l3init_clkstctrl,  		(*prcm)->cm_memif_clkstctrl,  		(*prcm)->cm_l4cfg_clkstctrl, +#ifdef CONFIG_DRIVER_TI_CPSW +		(*prcm)->cm_gmac_clkstctrl, +#endif  		0  	}; @@ -409,6 +423,9 @@ void enable_basic_clocks(void)  		(*prcm)->cm_wkup_wdtimer2_clkctrl,  		(*prcm)->cm_l4per_uart3_clkctrl,  		(*prcm)->cm_l4per_i2c1_clkctrl, +#ifdef CONFIG_DRIVER_TI_CPSW +		(*prcm)->cm_gmac_gmac_clkctrl, +#endif  		0  	}; @@ -465,7 +482,6 @@ void enable_basic_uboot_clocks(void)  		(*prcm)->cm_l3init_fsusb_clkctrl,  		0  	}; -  	do_enable_clocks(clk_domains_essential,  			 clk_modules_hw_auto_essential,  			 clk_modules_explicit_en_essential, diff --git a/arch/arm/cpu/armv7/omap5/prcm-regs.c b/arch/arm/cpu/armv7/omap5/prcm-regs.c index 54d8c2b68..579818d55 100644 --- a/arch/arm/cpu/armv7/omap5/prcm-regs.c +++ b/arch/arm/cpu/armv7/omap5/prcm-regs.c @@ -378,6 +378,10 @@ struct omap_sys_ctrl_regs const omap5_ctrl = {  struct omap_sys_ctrl_regs const dra7xx_ctrl = {  	.control_status				= 0x4A002134, +	.control_core_mac_id_0_lo		= 0x4A002514, +	.control_core_mac_id_0_hi		= 0x4A002518, +	.control_core_mac_id_1_lo		= 0x4A00251C, +	.control_core_mac_id_1_hi		= 0x4A002520,  	.control_core_mmr_lock1			= 0x4A002540,  	.control_core_mmr_lock2			= 0x4A002544,  	.control_core_mmr_lock3			= 0x4A002548, @@ -798,6 +802,7 @@ struct prcm_regs const dra7xx_prcm = {  	.cm_ssc_deltamstep_dpll_ddrphy		= 0x4a00522c,  	.cm_clkmode_dpll_dsp			= 0x4a005234,  	.cm_shadow_freq_config1			= 0x4a005260, +	.cm_clkmode_dpll_gmac			= 0x4a0052a8,  	/* cm1.mpu */  	.cm_mpu_mpu_clkctrl			= 0x4a005320, @@ -895,6 +900,8 @@ struct prcm_regs const dra7xx_prcm = {  	.cm_l3init_hsusbhost_clkctrl		= 0x4a009340,  	.cm_l3init_hsusbotg_clkctrl		= 0x4a009348,  	.cm_l3init_hsusbtll_clkctrl		= 0x4a009350, +	.cm_gmac_clkstctrl			= 0x4a0093c0, +	.cm_gmac_gmac_clkctrl			= 0x4a0093d0,  	.cm_l3init_ocp2scp1_clkctrl		= 0x4a0093e0,  	/* cm2.l4per */ diff --git a/arch/arm/imx-common/cmd_hdmidet.c b/arch/arm/imx-common/cmd_hdmidet.c index d6ec7c469..e9fd9553c 100644 --- a/arch/arm/imx-common/cmd_hdmidet.c +++ b/arch/arm/imx-common/cmd_hdmidet.c @@ -11,8 +11,7 @@  static int do_hdmidet(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])  {  	struct hdmi_regs *hdmi	= (struct hdmi_regs *)HDMI_ARB_BASE_ADDR; -	u8 reg = readb(&hdmi->phy_stat0) & HDMI_PHY_HPD; -	return (reg&HDMI_PHY_HPD) ? 0 : 1; +	return (readb(&hdmi->phy_stat0) & HDMI_DVI_STAT) ? 0 : 1;  }  U_BOOT_CMD(hdmidet, 1, 1, do_hdmidet, diff --git a/arch/arm/include/asm/arch-am33xx/clock.h b/arch/arm/include/asm/arch-am33xx/clock.h index 44c1e5dab..519249e4a 100644 --- a/arch/arm/include/asm/arch-am33xx/clock.h +++ b/arch/arm/include/asm/arch-am33xx/clock.h @@ -13,4 +13,102 @@  #include <asm/arch/clocks_am33xx.h> +#ifdef CONFIG_TI81XX +#include <asm/arch/clock_ti81xx.h> +#endif + +#define LDELAY 1000000 + +/*CM_<clock_domain>__CLKCTRL */ +#define CD_CLKCTRL_CLKTRCTRL_SHIFT		0 +#define CD_CLKCTRL_CLKTRCTRL_MASK		3 + +#define CD_CLKCTRL_CLKTRCTRL_NO_SLEEP		0 +#define CD_CLKCTRL_CLKTRCTRL_SW_SLEEP		1 +#define CD_CLKCTRL_CLKTRCTRL_SW_WKUP		2 + +/* CM_<clock_domain>_<module>_CLKCTRL */ +#define MODULE_CLKCTRL_MODULEMODE_SHIFT		0 +#define MODULE_CLKCTRL_MODULEMODE_MASK		3 +#define MODULE_CLKCTRL_IDLEST_SHIFT		16 +#define MODULE_CLKCTRL_IDLEST_MASK		(3 << 16) + +#define MODULE_CLKCTRL_MODULEMODE_SW_DISABLE		0 +#define MODULE_CLKCTRL_MODULEMODE_SW_EXPLICIT_EN	2 + +#define MODULE_CLKCTRL_IDLEST_FULLY_FUNCTIONAL	0 +#define MODULE_CLKCTRL_IDLEST_TRANSITIONING	1 +#define MODULE_CLKCTRL_IDLEST_IDLE		2 +#define MODULE_CLKCTRL_IDLEST_DISABLED		3 + +/* CM_CLKMODE_DPLL */ +#define CM_CLKMODE_DPLL_REGM4XEN_SHIFT		11 +#define CM_CLKMODE_DPLL_REGM4XEN_MASK		(1 << 11) +#define CM_CLKMODE_DPLL_LPMODE_EN_SHIFT		10 +#define CM_CLKMODE_DPLL_LPMODE_EN_MASK		(1 << 10) +#define CM_CLKMODE_DPLL_RELOCK_RAMP_EN_SHIFT	9 +#define CM_CLKMODE_DPLL_RELOCK_RAMP_EN_MASK	(1 << 9) +#define CM_CLKMODE_DPLL_DRIFTGUARD_EN_SHIFT	8 +#define CM_CLKMODE_DPLL_DRIFTGUARD_EN_MASK	(1 << 8) +#define CM_CLKMODE_DPLL_RAMP_RATE_SHIFT		5 +#define CM_CLKMODE_DPLL_RAMP_RATE_MASK		(0x7 << 5) +#define CM_CLKMODE_DPLL_EN_SHIFT		0 +#define CM_CLKMODE_DPLL_EN_MASK			(0x7 << 0) + +#define CM_CLKMODE_DPLL_DPLL_EN_SHIFT		0 +#define CM_CLKMODE_DPLL_DPLL_EN_MASK		7 + +#define DPLL_EN_STOP			1 +#define DPLL_EN_MN_BYPASS		4 +#define DPLL_EN_LOW_POWER_BYPASS	5 +#define DPLL_EN_LOCK			7 + +/* CM_IDLEST_DPLL fields */ +#define ST_DPLL_CLK_MASK		1 + +/* CM_CLKSEL_DPLL */ +#define CM_CLKSEL_DPLL_M_SHIFT			8 +#define CM_CLKSEL_DPLL_M_MASK			(0x7FF << 8) +#define CM_CLKSEL_DPLL_N_SHIFT			0 +#define CM_CLKSEL_DPLL_N_MASK			0x7F + +struct dpll_params { +	u32 m; +	u32 n; +	s8 m2; +	s8 m3; +	s8 m4; +	s8 m5; +	s8 m6; +}; + +struct dpll_regs { +	u32 cm_clkmode_dpll; +	u32 cm_idlest_dpll; +	u32 cm_autoidle_dpll; +	u32 cm_clksel_dpll; +	u32 cm_div_m2_dpll; +	u32 cm_div_m3_dpll; +	u32 cm_div_m4_dpll; +	u32 cm_div_m5_dpll; +	u32 cm_div_m6_dpll; +}; + +extern const struct dpll_regs dpll_mpu_regs; +extern const struct dpll_regs dpll_core_regs; +extern const struct dpll_regs dpll_per_regs; +extern const struct dpll_regs dpll_ddr_regs; +extern const struct dpll_params dpll_mpu; +extern const struct dpll_params dpll_core; +extern const struct dpll_params dpll_per; +extern const struct dpll_params dpll_ddr; + +extern struct cm_wkuppll *const cmwkup; + +const struct dpll_params *get_dpll_ddr_params(void); +void do_setup_dpll(const struct dpll_regs *, const struct dpll_params *); +void prcm_init(void); +void enable_basic_clocks(void); +void do_enable_clocks(u32 *const *, u32 *const *, u8); +  #endif diff --git a/arch/arm/include/asm/arch-am33xx/clock_ti81xx.h b/arch/arm/include/asm/arch-am33xx/clock_ti81xx.h new file mode 100644 index 000000000..f0699229a --- /dev/null +++ b/arch/arm/include/asm/arch-am33xx/clock_ti81xx.h @@ -0,0 +1,142 @@ +/* + * ti81xx.h + * + * Copyright (C) 2013, Adeneo Embedded <www.adeneo-embedded.com> + * Antoine Tenart, <atenart@adeneo-embedded.com> + * + * This file is released under the terms of GPL v2 and any later version. + * See the file COPYING in the root directory of the source tree for details. + */ + +#ifndef _CLOCK_TI81XX_H_ +#define _CLOCK_TI81XX_H_ + +#define PRCM_MOD_EN     0x2 + +#define CM_DEFAULT_BASE (PRCM_BASE + 0x0500) +#define CM_ALWON_BASE   (PRCM_BASE + 0x1400) + +struct cm_def { +	unsigned int resv0[2]; +	unsigned int l3fastclkstctrl; +	unsigned int resv1[1]; +	unsigned int pciclkstctrl; +	unsigned int resv2[1]; +	unsigned int ducaticlkstctrl; +	unsigned int resv3[1]; +	unsigned int emif0clkctrl; +	unsigned int emif1clkctrl; +	unsigned int dmmclkctrl; +	unsigned int fwclkctrl; +	unsigned int resv4[10]; +	unsigned int usbclkctrl; +	unsigned int resv5[1]; +	unsigned int sataclkctrl; +	unsigned int resv6[4]; +	unsigned int ducaticlkctrl; +	unsigned int pciclkctrl; +}; + +struct cm_alwon { +	unsigned int l3slowclkstctrl; +	unsigned int ethclkstctrl; +	unsigned int l3medclkstctrl; +	unsigned int mmu_clkstctrl; +	unsigned int mmucfg_clkstctrl; +	unsigned int ocmc0clkstctrl; +#if defined(CONFIG_TI814X) +	unsigned int vcpclkstctrl; +#elif defined(CONFIG_TI816X) +	unsigned int ocmc1clkstctrl; +#endif +	unsigned int mpuclkstctrl; +	unsigned int sysclk4clkstctrl; +	unsigned int sysclk5clkstctrl; +	unsigned int sysclk6clkstctrl; +	unsigned int rtcclkstctrl; +	unsigned int l3fastclkstctrl; +	unsigned int resv0[67]; +	unsigned int mcasp0clkctrl; +	unsigned int mcasp1clkctrl; +	unsigned int mcasp2clkctrl; +	unsigned int mcbspclkctrl; +	unsigned int uart0clkctrl; +	unsigned int uart1clkctrl; +	unsigned int uart2clkctrl; +	unsigned int gpio0clkctrl; +	unsigned int gpio1clkctrl; +	unsigned int i2c0clkctrl; +	unsigned int i2c1clkctrl; +#if defined(CONFIG_TI814X) +	unsigned int mcasp345clkctrl; +	unsigned int atlclkctrl; +	unsigned int mlbclkctrl; +	unsigned int pataclkctrl; +	unsigned int resv1[1]; +	unsigned int uart3clkctrl; +	unsigned int uart4clkctrl; +	unsigned int uart5clkctrl; +#elif defined(CONFIG_TI816X) +	unsigned int resv1[1]; +	unsigned int timer1clkctrl; +	unsigned int timer2clkctrl; +	unsigned int timer3clkctrl; +	unsigned int timer4clkctrl; +	unsigned int timer5clkctrl; +	unsigned int timer6clkctrl; +	unsigned int timer7clkctrl; +#endif +	unsigned int wdtimerclkctrl; +	unsigned int spiclkctrl; +	unsigned int mailboxclkctrl; +	unsigned int spinboxclkctrl; +	unsigned int mmudataclkctrl; +	unsigned int resv2[2]; +	unsigned int mmucfgclkctrl; +#if defined(CONFIG_TI814X) +	unsigned int resv3[2]; +#elif defined(CONFIG_TI816X) +	unsigned int resv3[1]; +	unsigned int sdioclkctrl; +#endif +	unsigned int ocmc0clkctrl; +#if defined(CONFIG_TI814X) +	unsigned int vcpclkctrl; +#elif defined(CONFIG_TI816X) +	unsigned int ocmc1clkctrl; +#endif +	unsigned int resv4[2]; +	unsigned int controlclkctrl; +	unsigned int resv5[2]; +	unsigned int gpmcclkctrl; +	unsigned int ethernet0clkctrl; +	unsigned int ethernet1clkctrl; +	unsigned int mpuclkctrl; +#if defined(CONFIG_TI814X) +	unsigned int debugssclkctrl; +#elif defined(CONFIG_TI816X) +	unsigned int resv6[1]; +#endif +	unsigned int l3clkctrl; +	unsigned int l4hsclkctrl; +	unsigned int l4lsclkctrl; +	unsigned int rtcclkctrl; +	unsigned int tpccclkctrl; +	unsigned int tptc0clkctrl; +	unsigned int tptc1clkctrl; +	unsigned int tptc2clkctrl; +	unsigned int tptc3clkctrl; +#if defined(CONFIG_TI814X) +	unsigned int resv6[4]; +	unsigned int dcan01clkctrl; +	unsigned int mmchs0clkctrl; +	unsigned int mmchs1clkctrl; +	unsigned int mmchs2clkctrl; +	unsigned int custefuseclkctrl; +#elif defined(CONFIG_TI816X) +	unsigned int sr0clkctrl; +	unsigned int sr1clkctrl; +#endif +}; + +#endif /* _CLOCK_TI81XX_H_ */ diff --git a/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h b/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h index 80e189916..140379fb3 100644 --- a/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h +++ b/arch/arm/include/asm/arch-am33xx/clocks_am33xx.h @@ -16,8 +16,10 @@  #define CONFIG_SYS_MPUCLK	550  #endif -extern void pll_init(void); -extern void enable_emif_clocks(void); +#define UART_RESET		(0x1 << 1) +#define UART_CLK_RUNNING_MASK	0x1 +#define UART_SMART_IDLE_EN	(0x1 << 0x3) +  extern void enable_dmm_clocks(void);  #endif	/* endif _CLOCKS_AM33XX_H_ */ diff --git a/arch/arm/include/asm/arch-am33xx/cpu.h b/arch/arm/include/asm/arch-am33xx/cpu.h index bcb4c5037..10b56e0db 100644 --- a/arch/arm/include/asm/arch-am33xx/cpu.h +++ b/arch/arm/include/asm/arch-am33xx/cpu.h @@ -43,13 +43,6 @@  #define SYSBOOT_MASK			(BIT(0) | BIT(1) | BIT(2)\  					| BIT(3) | BIT(4)) -/* Reset control */ -#ifdef CONFIG_AM33XX -#define PRM_RSTCTRL			(PRCM_BASE + 0x0F00) -#elif defined(CONFIG_TI814X) -#define PRM_RSTCTRL			(PRCM_BASE + 0x00A0) -#endif -#define PRM_RSTST			(PRM_RSTCTRL + 8)  #define PRM_RSTCTRL_RESET		0x01  #define PRM_RSTST_WARM_RESET_MASK	0x232 @@ -108,6 +101,7 @@ struct gpmc {  /* Used for board specific gpmc initialization */  extern struct gpmc *gpmc_cfg; +#ifndef CONFIG_AM43XX  /* Encapsulating core pll registers */  struct cm_wkuppll {  	unsigned int wkclkstctrl;	/* offset 0x00 */ @@ -211,6 +205,162 @@ struct cm_perpll {  	unsigned int resv10[8];  	unsigned int cpswclkstctrl;	/* offset 0x144 */  }; +#else +/* Encapsulating core pll registers */ +struct cm_wkuppll { +	unsigned int resv0[136]; +	unsigned int wkl4wkclkctrl;	/* offset 0x220 */ +	unsigned int resv1[55]; +	unsigned int wkclkstctrl;	/* offset 0x300 */ +	unsigned int resv2[15]; +	unsigned int wkup_i2c0ctrl;	/* offset 0x340 */ +	unsigned int resv3; +	unsigned int wkup_uart0ctrl;	/* offset 0x348 */ +	unsigned int resv4[5]; +	unsigned int wkctrlclkctrl;	/* offset 0x360 */ +	unsigned int resv5; +	unsigned int wkgpio0clkctrl;	/* offset 0x368 */ + +	unsigned int resv6[109]; +	unsigned int clkmoddpllcore;	/* offset 0x520 */ +	unsigned int idlestdpllcore;	/* offset 0x524 */ +	unsigned int resv61; +	unsigned int clkseldpllcore;	/* offset 0x52C */ +	unsigned int resv7[2]; +	unsigned int divm4dpllcore;	/* offset 0x538 */ +	unsigned int divm5dpllcore;	/* offset 0x53C */ +	unsigned int divm6dpllcore;	/* offset 0x540 */ + +	unsigned int resv8[7]; +	unsigned int clkmoddpllmpu;	/* offset 0x560 */ +	unsigned int idlestdpllmpu;	/* offset 0x564 */ +	unsigned int resv9; +	unsigned int clkseldpllmpu;	/* offset 0x56c */ +	unsigned int divm2dpllmpu;	/* offset 0x570 */ + +	unsigned int resv10[11]; +	unsigned int clkmoddpllddr;	/* offset 0x5A0 */ +	unsigned int idlestdpllddr;	/* offset 0x5A4 */ +	unsigned int resv11; +	unsigned int clkseldpllddr;	/* offset 0x5AC */ +	unsigned int divm2dpllddr;	/* offset 0x5B0 */ + +	unsigned int resv12[11]; +	unsigned int clkmoddpllper;	/* offset 0x5E0 */ +	unsigned int idlestdpllper;	/* offset 0x5E4 */ +	unsigned int resv13; +	unsigned int clkseldpllper;	/* offset 0x5EC */ +	unsigned int divm2dpllper;	/* offset 0x5F0 */ +	unsigned int resv14[8]; +	unsigned int clkdcoldodpllper;	/* offset 0x614 */ + +	unsigned int resv15[2]; +	unsigned int clkmoddplldisp;	/* offset 0x620 */ +	unsigned int resv16[2]; +	unsigned int clkseldplldisp;	/* offset 0x62C */ +	unsigned int divm2dplldisp;	/* offset 0x630 */ +}; + +/* + * Encapsulating peripheral functional clocks + * pll registers + */ +struct cm_perpll { +	unsigned int l3clkstctrl;	/* offset 0x00 */ +	unsigned int resv0[7]; +	unsigned int l3clkctrl;		/* Offset 0x20 */ +	unsigned int resv1[7]; +	unsigned int l3instrclkctrl;	/* offset 0x40 */ +	unsigned int resv2[3]; +	unsigned int ocmcramclkctrl;	/* offset 0x50 */ +	unsigned int resv3[9]; +	unsigned int tpccclkctrl;	/* offset 0x78 */ +	unsigned int resv4; +	unsigned int tptc0clkctrl;	/* offset 0x80 */ + +	unsigned int resv5[7]; +	unsigned int l4hsclkctrl;	/* offset 0x0A0 */ +	unsigned int resv6; +	unsigned int l4fwclkctrl;	/* offset 0x0A8 */ +	unsigned int resv7[85]; +	unsigned int l3sclkstctrl;	/* offset 0x200 */ +	unsigned int resv8[7]; +	unsigned int gpmcclkctrl;	/* offset 0x220 */ +	unsigned int resv9[5]; +	unsigned int mcasp0clkctrl;	/* offset 0x238 */ +	unsigned int resv10; +	unsigned int mcasp1clkctrl;	/* offset 0x240 */ +	unsigned int resv11; +	unsigned int mmc2clkctrl;	/* offset 0x248 */ +	unsigned int resv12[5]; +	unsigned int usb0clkctrl;	/* offset 0x260 */ +	unsigned int resv13[103]; +	unsigned int l4lsclkstctrl;	/* offset 0x400 */ +	unsigned int resv14[7]; +	unsigned int l4lsclkctrl;	/* offset 0x420 */ +	unsigned int resv15; +	unsigned int dcan0clkctrl;	/* offset 0x428 */ +	unsigned int resv16; +	unsigned int dcan1clkctrl;	/* offset 0x430 */ +	unsigned int resv17[13]; +	unsigned int elmclkctrl;	/* offset 0x468 */ + +	unsigned int resv18[3]; +	unsigned int gpio1clkctrl;	/* offset 0x478 */ +	unsigned int resv19; +	unsigned int gpio2clkctrl;	/* offset 0x480 */ +	unsigned int resv20; +	unsigned int gpio3clkctrl;	/* offset 0x488 */ +	unsigned int resv21[7]; + +	unsigned int i2c1clkctrl;	/* offset 0x4A8 */ +	unsigned int resv22; +	unsigned int i2c2clkctrl;	/* offset 0x4B0 */ +	unsigned int resv23[3]; +	unsigned int mmc0clkctrl;	/* offset 0x4C0 */ +	unsigned int resv24; +	unsigned int mmc1clkctrl;	/* offset 0x4C8 */ + +	unsigned int resv25[13]; +	unsigned int spi0clkctrl;	/* offset 0x500 */ +	unsigned int resv26; +	unsigned int spi1clkctrl;	/* offset 0x508 */ +	unsigned int resv27[9]; +	unsigned int timer2clkctrl;	/* offset 0x530 */ +	unsigned int resv28; +	unsigned int timer3clkctrl;	/* offset 0x538 */ +	unsigned int resv29; +	unsigned int timer4clkctrl;	/* offset 0x540 */ +	unsigned int resv30[5]; +	unsigned int timer7clkctrl;	/* offset 0x558 */ + +	unsigned int resv31[9]; +	unsigned int uart1clkctrl;	/* offset 0x580 */ +	unsigned int resv32; +	unsigned int uart2clkctrl;	/* offset 0x588 */ +	unsigned int resv33; +	unsigned int uart3clkctrl;	/* offset 0x590 */ +	unsigned int resv34; +	unsigned int uart4clkctrl;	/* offset 0x598 */ +	unsigned int resv35; +	unsigned int uart5clkctrl;	/* offset 0x5A0 */ +	unsigned int resv36[87]; + +	unsigned int emifclkstctrl;	/* offset 0x700 */ +	unsigned int resv361[7]; +	unsigned int emifclkctrl;	/* offset 0x720 */ +	unsigned int resv37[3]; +	unsigned int emiffwclkctrl;	/* offset 0x730 */ +	unsigned int resv371; +	unsigned int otfaemifclkctrl;	/* offset 0x738 */ +	unsigned int resv38[57]; +	unsigned int lcdclkctrl;	/* offset 0x820 */ +	unsigned int resv39[183]; +	unsigned int cpswclkstctrl;	/* offset 0xB00 */ +	unsigned int resv40[7]; +	unsigned int cpgmac0clkctrl;	/* offset 0xB20 */ +}; +#endif /* CONFIG_AM43XX */  /* Encapsulating Display pll registers */  struct cm_dpll { diff --git a/arch/arm/include/asm/arch-am33xx/ddr_defs.h b/arch/arm/include/asm/arch-am33xx/ddr_defs.h index 18d7d99a4..95f7a9ad4 100644 --- a/arch/arm/include/asm/arch-am33xx/ddr_defs.h +++ b/arch/arm/include/asm/arch-am33xx/ddr_defs.h @@ -192,37 +192,46 @@ struct ddr_data_regs {   * correspond to DATA1 registers defined here.   */  struct ddr_regs { -	unsigned int resv0[7]; -	unsigned int cm0csratio;	/* offset 0x01C */ +	unsigned int resv0[3]; +	unsigned int cm0config;		/* offset 0x00C */ +	unsigned int cm0configclk;	/* offset 0x010 */  	unsigned int resv1[2]; +	unsigned int cm0csratio;	/* offset 0x01C */ +	unsigned int resv2[2];  	unsigned int cm0dldiff;		/* offset 0x028 */  	unsigned int cm0iclkout;	/* offset 0x02C */ -	unsigned int resv2[8]; +	unsigned int resv3[4]; +	unsigned int cm1config;		/* offset 0x040 */ +	unsigned int cm1configclk;	/* offset 0x044 */ +	unsigned int resv4[2];  	unsigned int cm1csratio;	/* offset 0x050 */ -	unsigned int resv3[2]; +	unsigned int resv5[2];  	unsigned int cm1dldiff;		/* offset 0x05C */  	unsigned int cm1iclkout;	/* offset 0x060 */ -	unsigned int resv4[8]; +	unsigned int resv6[4]; +	unsigned int cm2config;		/* offset 0x074 */ +	unsigned int cm2configclk;	/* offset 0x078 */ +	unsigned int resv7[2];  	unsigned int cm2csratio;	/* offset 0x084 */ -	unsigned int resv5[2]; +	unsigned int resv8[2];  	unsigned int cm2dldiff;		/* offset 0x090 */  	unsigned int cm2iclkout;	/* offset 0x094 */ -	unsigned int resv6[12]; +	unsigned int resv9[12];  	unsigned int dt0rdsratio0;	/* offset 0x0C8 */ -	unsigned int resv7[4]; +	unsigned int resv10[4];  	unsigned int dt0wdsratio0;	/* offset 0x0DC */ -	unsigned int resv8[4]; +	unsigned int resv11[4];  	unsigned int dt0wiratio0;	/* offset 0x0F0 */ -	unsigned int resv9; +	unsigned int resv12;  	unsigned int dt0wimode0;	/* offset 0x0F8 */  	unsigned int dt0giratio0;	/* offset 0x0FC */ -	unsigned int resv10; +	unsigned int resv13;  	unsigned int dt0gimode0;	/* offset 0x104 */  	unsigned int dt0fwsratio0;	/* offset 0x108 */ -	unsigned int resv11[4]; +	unsigned int resv14[4];  	unsigned int dt0dqoffset;	/* offset 0x11C */  	unsigned int dt0wrsratio0;	/* offset 0x120 */ -	unsigned int resv12[4]; +	unsigned int resv15[4];  	unsigned int dt0rdelays0;	/* offset 0x134 */  	unsigned int dt0dldiff0;	/* offset 0x138 */  }; diff --git a/arch/arm/include/asm/arch-am33xx/hardware.h b/arch/arm/include/asm/arch-am33xx/hardware.h index 02f5f8a8d..ee5fce0da 100644 --- a/arch/arm/include/asm/arch-am33xx/hardware.h +++ b/arch/arm/include/asm/arch-am33xx/hardware.h @@ -15,8 +15,12 @@  #include <asm/arch/omap.h>  #ifdef CONFIG_AM33XX  #include <asm/arch/hardware_am33xx.h> +#elif defined(CONFIG_TI816X) +#include <asm/arch/hardware_ti816x.h>  #elif defined(CONFIG_TI814X)  #include <asm/arch/hardware_ti814x.h> +#elif defined(CONFIG_AM43XX) +#include <asm/arch/hardware_am43xx.h>  #endif  /* @@ -45,37 +49,24 @@  #define EMIF4_1_CFG_BASE		0x4D000000  /* PLL related registers */ -#define CM_PER				0x44E00000 -#define CM_WKUP				0x44E00400  #define CM_DPLL				0x44E00500  #define CM_DEVICE			0x44E00700  #define CM_RTC				0x44E00800  #define CM_CEFUSE			0x44E00A00  #define PRM_DEVICE			0x44E00F00 -/* VTP Base address */ -#define VTP1_CTRL_ADDR			0x48140E10 -  /* DDR Base address */  #define DDR_CTRL_ADDR			0x44E10E04  #define DDR_CONTROL_BASE_ADDR		0x44E11404 -#define DDR_PHY_CMD_ADDR2		0x47C0C800 -#define DDR_PHY_DATA_ADDR2		0x47C0C8C8  /* UART */  #define DEFAULT_UART_BASE		UART0_BASE -#define DDRPHY_0_CONFIG_BASE		(CTRL_BASE + 0x1400) -#define DDRPHY_CONFIG_BASE		DDRPHY_0_CONFIG_BASE -  /* GPMC Base address */  #define GPMC_BASE			0x50000000  /* CPSW Config space */  #define CPSW_BASE			0x4A100000 -/* OTG */ -#define USB0_OTG_BASE			0x47401000 -#define USB1_OTG_BASE			0x47401800 - +int clk_get(int clk);  #endif /* __AM33XX_HARDWARE_H */ diff --git a/arch/arm/include/asm/arch-am33xx/hardware_am33xx.h b/arch/arm/include/asm/arch-am33xx/hardware_am33xx.h index 432f0c764..8973fd884 100644 --- a/arch/arm/include/asm/arch-am33xx/hardware_am33xx.h +++ b/arch/arm/include/asm/arch-am33xx/hardware_am33xx.h @@ -28,19 +28,34 @@  /* PRCM Base Address */  #define PRCM_BASE			0x44E00000 +#define CM_PER				0x44E00000 +#define CM_WKUP				0x44E00400 + +#define PRM_RSTCTRL			(PRCM_BASE + 0x0F00) +#define PRM_RSTST			(PRM_RSTCTRL + 8)  /* VTP Base address */  #define VTP0_CTRL_ADDR			0x44E10E0C +#define VTP1_CTRL_ADDR			0x48140E10  /* DDR Base address */  #define DDR_PHY_CMD_ADDR		0x44E12000  #define DDR_PHY_DATA_ADDR		0x44E120C8 +#define DDR_PHY_CMD_ADDR2		0x47C0C800 +#define DDR_PHY_DATA_ADDR2		0x47C0C8C8  #define DDR_DATA_REGS_NR		2 +#define DDRPHY_0_CONFIG_BASE		(CTRL_BASE + 0x1400) +#define DDRPHY_CONFIG_BASE		DDRPHY_0_CONFIG_BASE +  /* CPSW Config space */  #define CPSW_MDIO_BASE			0x4A101000  /* RTC base address */  #define RTC_BASE			0x44E3E000 +/* OTG */ +#define USB0_OTG_BASE			0x47401000 +#define USB1_OTG_BASE			0x47401800 +  #endif /* __AM33XX_HARDWARE_AM33XX_H */ diff --git a/arch/arm/include/asm/arch-am33xx/hardware_am43xx.h b/arch/arm/include/asm/arch-am33xx/hardware_am43xx.h new file mode 100644 index 000000000..303c594d2 --- /dev/null +++ b/arch/arm/include/asm/arch-am33xx/hardware_am43xx.h @@ -0,0 +1,54 @@ +/* + * hardware_am43xx.h + * + * AM43xx hardware specific header + * + * Copyright (C) 2013, Texas Instruments, Incorporated - http://www.ti.com/ + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef __AM43XX_HARDWARE_AM43XX_H +#define __AM43XX_HARDWARE_AM43XX_H + +/* Module base addresses */ + +/* UART Base Address */ +#define UART0_BASE			0x44E09000 + +/* GPIO Base address */ +#define GPIO2_BASE			0x481AC000 + +/* Watchdog Timer */ +#define WDT_BASE			0x44E35000 + +/* Control Module Base Address */ +#define CTRL_BASE			0x44E10000 +#define CTRL_DEVICE_BASE		0x44E10600 + +/* PRCM Base Address */ +#define PRCM_BASE			0x44DF0000 +#define	CM_WKUP				0x44DF2800 +#define	CM_PER				0x44DF8800 + +#define PRM_RSTCTRL			(PRCM_BASE + 0x4000) +#define PRM_RSTST			(PRM_RSTCTRL + 4) + +/* VTP Base address */ +#define VTP0_CTRL_ADDR			0x44E10E0C +#define VTP1_CTRL_ADDR			0x48140E10 + +/* DDR Base address */ +#define DDR_PHY_CMD_ADDR		0x44E12000 +#define DDR_PHY_DATA_ADDR		0x44E120C8 +#define DDR_PHY_CMD_ADDR2		0x47C0C800 +#define DDR_PHY_DATA_ADDR2		0x47C0C8C8 +#define DDR_DATA_REGS_NR		2 + +/* CPSW Config space */ +#define CPSW_MDIO_BASE			0x4A101000 + +/* RTC base address */ +#define RTC_BASE			0x44E3E000 + +#endif /* __AM43XX_HARDWARE_AM43XX_H */ diff --git a/arch/arm/include/asm/arch-am33xx/hardware_ti814x.h b/arch/arm/include/asm/arch-am33xx/hardware_ti814x.h index 451d935b1..4509a237d 100644 --- a/arch/arm/include/asm/arch-am33xx/hardware_ti814x.h +++ b/arch/arm/include/asm/arch-am33xx/hardware_ti814x.h @@ -25,22 +25,37 @@  /* PRCM Base Address */  #define PRCM_BASE			0x48180000 +#define CM_PER				0x44E00000 +#define CM_WKUP				0x44E00400 + +#define PRM_RSTCTRL			(PRCM_BASE + 0x00A0) +#define PRM_RSTST			(PRM_RSTCTRL + 8)  /* PLL Subsystem Base Address */  #define PLL_SUBSYS_BASE			0x481C5000  /* VTP Base address */  #define VTP0_CTRL_ADDR			0x48140E0C +#define VTP1_CTRL_ADDR			0x48140E10  /* DDR Base address */  #define DDR_PHY_CMD_ADDR		0x47C0C400  #define DDR_PHY_DATA_ADDR		0x47C0C4C8 +#define DDR_PHY_CMD_ADDR2		0x47C0C800 +#define DDR_PHY_DATA_ADDR2		0x47C0C8C8  #define DDR_DATA_REGS_NR		4 +#define DDRPHY_0_CONFIG_BASE		(CTRL_BASE + 0x1400) +#define DDRPHY_CONFIG_BASE		DDRPHY_0_CONFIG_BASE +  /* CPSW Config space */  #define CPSW_MDIO_BASE			0x4A100800  /* RTC base address */  #define RTC_BASE			0x480C0000 +/* OTG */ +#define USB0_OTG_BASE			0x47401000 +#define USB1_OTG_BASE			0x47401800 +  #endif /* __AM33XX_HARDWARE_TI814X_H */ diff --git a/arch/arm/include/asm/arch-am33xx/hardware_ti816x.h b/arch/arm/include/asm/arch-am33xx/hardware_ti816x.h new file mode 100644 index 000000000..3c680649a --- /dev/null +++ b/arch/arm/include/asm/arch-am33xx/hardware_ti816x.h @@ -0,0 +1,61 @@ +/* + * hardware_ti816x.h + * + * TI816x hardware specific header + * + * Copyright (C) 2013, Adeneo Embedded <www.adeneo-embedded.com> + * Antoine Tenart, <atenart@adeneo-embedded.com> + * Based on TI-PSP-04.00.02.14 + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR /PURPOSE.  See the + * GNU General Public License for more details. + */ + +#ifndef __AM33XX_HARDWARE_TI816X_H +#define __AM33XX_HARDWARE_TI816X_H + +/* UART */ +#define UART0_BASE		0x48020000 +#define UART1_BASE		0x48022000 +#define UART2_BASE		0x48024000 + +/* Watchdog Timer */ +#define WDT_BASE		0x480C2000 + +/* Control Module Base Address */ +#define CTRL_BASE		0x48140000 + +/* PRCM Base Address */ +#define PRCM_BASE		0x48180000 + +#define PRM_RSTCTRL		(PRCM_BASE + 0x00A0) +#define PRM_RSTST		(PRM_RSTCTRL + 8) + +/* VTP Base address */ +#define VTP0_CTRL_ADDR		0x48198358 +#define VTP1_CTRL_ADDR		0x4819A358 + +/* DDR Base address */ +#define DDR_PHY_CMD_ADDR	0x48198000 +#define DDR_PHY_DATA_ADDR	0x481980C8 +#define DDR_PHY_CMD_ADDR2	0x4819A000 +#define DDR_PHY_DATA_ADDR2	0x4819A0C8 +#define DDR_DATA_REGS_NR	4 + + +#define DDRPHY_0_CONFIG_BASE	0x48198000 +#define DDRPHY_1_CONFIG_BASE	0x4819A000 +#define DDRPHY_CONFIG_BASE	((emif == 0) ? \ +	DDRPHY_0_CONFIG_BASE : DDRPHY_1_CONFIG_BASE) + +/* RTC base address */ +#define RTC_BASE		0x480C0000 + +#endif /* __AM33XX_HARDWARE_TI816X_H */ diff --git a/arch/arm/include/asm/arch-am33xx/mem.h b/arch/arm/include/asm/arch-am33xx/mem.h index aef4e82fc..983ea28dc 100644 --- a/arch/arm/include/asm/arch-am33xx/mem.h +++ b/arch/arm/include/asm/arch-am33xx/mem.h @@ -30,6 +30,7 @@   *   * Currently valid part Names are (PART):   * M_NAND - Micron NAND + * STNOR - STMicrolelctronics M29W128GL   */  #define GPMC_SIZE_256M		0x0  #define GPMC_SIZE_128M		0x8 @@ -45,6 +46,14 @@  #define M_NAND_GPMC_CONFIG6	0x16000f80  #define M_NAND_GPMC_CONFIG7	0x00000008 +#define STNOR_GPMC_CONFIG1	0x00001200 +#define STNOR_GPMC_CONFIG2	0x00101000 +#define STNOR_GPMC_CONFIG3	0x00030301 +#define STNOR_GPMC_CONFIG4	0x10041004 +#define STNOR_GPMC_CONFIG5	0x000C1010 +#define STNOR_GPMC_CONFIG6	0x08070280 +#define STNOR_GPMC_CONFIG7	0x00000F48 +  /* max number of GPMC Chip Selects */  #define GPMC_MAX_CS		8  /* max number of GPMC regs */ diff --git a/arch/arm/include/asm/arch-am33xx/mmc_host_def.h b/arch/arm/include/asm/arch-am33xx/mmc_host_def.h index 51ba79190..724e25294 100644 --- a/arch/arm/include/asm/arch-am33xx/mmc_host_def.h +++ b/arch/arm/include/asm/arch-am33xx/mmc_host_def.h @@ -27,6 +27,9 @@  #if defined(CONFIG_TI814X)  #undef MMC_CLOCK_REFERENCE  #define MMC_CLOCK_REFERENCE	192 /* MHz */ +#elif defined(CONFIG_TI816X) +#undef MMC_CLOCK_REFERENCE +#define MMC_CLOCK_REFERENCE	48 /* MHz */  #endif  #endif /* MMC_HOST_DEF_H */ diff --git a/arch/arm/include/asm/arch-am33xx/mux.h b/arch/arm/include/asm/arch-am33xx/mux.h index 1c6b65f4a..324943726 100644 --- a/arch/arm/include/asm/arch-am33xx/mux.h +++ b/arch/arm/include/asm/arch-am33xx/mux.h @@ -23,6 +23,10 @@  #include <asm/arch/mux_am33xx.h>  #elif defined(CONFIG_TI814X)  #include <asm/arch/mux_ti814x.h> +#elif defined(CONFIG_TI816X) +#include <asm/arch/mux_ti816x.h> +#elif defined(CONFIG_AM43XX) +#include <asm/arch/mux_am43xx.h>  #endif  struct module_pin_mux { diff --git a/arch/arm/include/asm/arch-am33xx/mux_am43xx.h b/arch/arm/include/asm/arch-am33xx/mux_am43xx.h new file mode 100644 index 000000000..0206912d5 --- /dev/null +++ b/arch/arm/include/asm/arch-am33xx/mux_am43xx.h @@ -0,0 +1,142 @@ +/* + * mux_am43xx.h + * + * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com/ + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#ifndef _MUX_AM43XX_H_ +#define _MUX_AM43XX_H_ + +#include <common.h> +#include <asm/io.h> + +#define MUX_CFG(value, offset)	\ +	__raw_writel(value, (CTRL_BASE + offset)); + +/* PAD Control Fields */ +#define SLEWCTRL	(0x1 << 19) +#define RXACTIVE	(0x1 << 18) +#define PULLDOWN_EN	(0x0 << 17) /* Pull Down Selection */ +#define PULLUP_EN	(0x1 << 17) /* Pull Up Selection */ +#define PULLUDEN	(0x0 << 16) /* Pull up/down enable */ +#define PULLUDDIS	(0x1 << 16) /* Pull up/down disable */ +#define MODE(val)	val	/* used for Readability */ + +/* + * PAD CONTROL OFFSETS + * Field names corresponds to the pad signal name + */ +struct pad_signals { +	int gpmc_ad0; +	int gpmc_ad1; +	int gpmc_ad2; +	int gpmc_ad3; +	int gpmc_ad4; +	int gpmc_ad5; +	int gpmc_ad6; +	int gpmc_ad7; +	int gpmc_ad8; +	int gpmc_ad9; +	int gpmc_ad10; +	int gpmc_ad11; +	int gpmc_ad12; +	int gpmc_ad13; +	int gpmc_ad14; +	int gpmc_ad15; +	int gpmc_a0; +	int gpmc_a1; +	int gpmc_a2; +	int gpmc_a3; +	int gpmc_a4; +	int gpmc_a5; +	int gpmc_a6; +	int gpmc_a7; +	int gpmc_a8; +	int gpmc_a9; +	int gpmc_a10; +	int gpmc_a11; +	int gpmc_wait0; +	int gpmc_wpn; +	int gpmc_be1n; +	int gpmc_csn0; +	int gpmc_csn1; +	int gpmc_csn2; +	int gpmc_csn3; +	int gpmc_clk; +	int gpmc_advn_ale; +	int gpmc_oen_ren; +	int gpmc_wen; +	int gpmc_be0n_cle; +	int lcd_data0; +	int lcd_data1; +	int lcd_data2; +	int lcd_data3; +	int lcd_data4; +	int lcd_data5; +	int lcd_data6; +	int lcd_data7; +	int lcd_data8; +	int lcd_data9; +	int lcd_data10; +	int lcd_data11; +	int lcd_data12; +	int lcd_data13; +	int lcd_data14; +	int lcd_data15; +	int lcd_vsync; +	int lcd_hsync; +	int lcd_pclk; +	int lcd_ac_bias_en; +	int mmc0_dat3; +	int mmc0_dat2; +	int mmc0_dat1; +	int mmc0_dat0; +	int mmc0_clk; +	int mmc0_cmd; +	int mii1_col; +	int mii1_crs; +	int mii1_rxerr; +	int mii1_txen; +	int mii1_rxdv; +	int mii1_txd3; +	int mii1_txd2; +	int mii1_txd1; +	int mii1_txd0; +	int mii1_txclk; +	int mii1_rxclk; +	int mii1_rxd3; +	int mii1_rxd2; +	int mii1_rxd1; +	int mii1_rxd0; +	int rmii1_refclk; +	int mdio_data; +	int mdio_clk; +	int spi0_sclk; +	int spi0_d0; +	int spi0_d1; +	int spi0_cs0; +	int spi0_cs1; +	int ecap0_in_pwm0_out; +	int uart0_ctsn; +	int uart0_rtsn; +	int uart0_rxd; +	int uart0_txd; +	int uart1_ctsn; +	int uart1_rtsn; +	int uart1_rxd; +	int uart1_txd; +	int i2c0_sda; +	int i2c0_scl; +	int mcasp0_aclkx; +	int mcasp0_fsx; +	int mcasp0_axr0; +	int mcasp0_ahclkr; +	int mcasp0_aclkr; +	int mcasp0_fsr; +	int mcasp0_axr1; +	int mcasp0_ahclkx; +}; + +#endif /* _MUX_AM43XX_H_ */ diff --git a/arch/arm/include/asm/arch-am33xx/mux_ti816x.h b/arch/arm/include/asm/arch-am33xx/mux_ti816x.h new file mode 100644 index 000000000..e4e5a48ad --- /dev/null +++ b/arch/arm/include/asm/arch-am33xx/mux_ti816x.h @@ -0,0 +1,363 @@ +/* + * mux_ti816x.h + * + * Copyright (C) 2013, Adeneo Embedded <www.adeneo-embedded.com> + * Antoine Tenart, <atenart@adeneo-embedded.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation version 2. + * + * This program is distributed "as is" WITHOUT ANY WARRANTY of any + * kind, whether express or implied; without even the implied warranty + * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ + +#ifndef _MUX_TI816X_H_ +#define _MUX_TI816X_H_ + +#include <common.h> +#include <asm/io.h> + +#define MUX_CFG(value, offset)  \ +	__raw_writel(value, (CTRL_BASE + offset)); + +#define PULLDOWN_EN	(0x0 << 4)	/* Pull Down Selection */ +#define PULLUP_EN	(0x1 << 4)	/* Pull Up Selection */ +#define PULLUDEN	(0x0 << 3)	/* Pull up enabled */ +#define PULLUDDIS	(0x1 << 3)	/* Pull up disabled */ +#define MODE(val)	(val)		/* used for Readability */ + + +/* + * PAD CONTROL OFFSETS + * Field names corresponds to the pad signal name + */ +struct pad_signals { +	int pincntl1; +	int pincntl2; +	int pincntl3; +	int pincntl4; +	int pincntl5; +	int pincntl6; +	int pincntl7; +	int pincntl8; +	int pincntl9; +	int pincntl10; +	int pincntl11; +	int pincntl12; +	int pincntl13; +	int pincntl14; +	int pincntl15; +	int pincntl16; +	int pincntl17; +	int pincntl18; +	int pincntl19; +	int pincntl20; +	int pincntl21; +	int pincntl22; +	int pincntl23; +	int pincntl24; +	int pincntl25; +	int pincntl26; +	int pincntl27; +	int pincntl28; +	int pincntl29; +	int pincntl30; +	int pincntl31; +	int pincntl32; +	int pincntl33; +	int pincntl34; +	int pincntl35; +	int pincntl36; +	int pincntl37; +	int pincntl38; +	int pincntl39; +	int pincntl40; +	int pincntl41; +	int pincntl42; +	int pincntl43; +	int pincntl44; +	int pincntl45; +	int pincntl46; +	int pincntl47; +	int pincntl48; +	int pincntl49; +	int pincntl50; +	int pincntl51; +	int pincntl52; +	int pincntl53; +	int pincntl54; +	int pincntl55; +	int pincntl56; +	int pincntl57; +	int pincntl58; +	int pincntl59; +	int pincntl60; +	int pincntl61; +	int pincntl62; +	int pincntl63; +	int pincntl64; +	int pincntl65; +	int pincntl66; +	int pincntl67; +	int pincntl68; +	int pincntl69; +	int pincntl70; +	int pincntl71; +	int pincntl72; +	int pincntl73; +	int pincntl74; +	int pincntl75; +	int pincntl76; +	int pincntl77; +	int pincntl78; +	int pincntl79; +	int pincntl80; +	int pincntl81; +	int pincntl82; +	int pincntl83; +	int pincntl84; +	int pincntl85; +	int pincntl86; +	int pincntl87; +	int pincntl88; +	int pincntl89; +	int pincntl90; +	int pincntl91; +	int pincntl92; +	int pincntl93; +	int pincntl94; +	int pincntl95; +	int pincntl96; +	int pincntl97; +	int pincntl98; +	int pincntl99; +	int pincntl100; +	int pincntl101; +	int pincntl102; +	int pincntl103; +	int pincntl104; +	int pincntl105; +	int pincntl106; +	int pincntl107; +	int pincntl108; +	int pincntl109; +	int pincntl110; +	int pincntl111; +	int pincntl112; +	int pincntl113; +	int pincntl114; +	int pincntl115; +	int pincntl116; +	int pincntl117; +	int pincntl118; +	int pincntl119; +	int pincntl120; +	int pincntl121; +	int pincntl122; +	int pincntl123; +	int pincntl124; +	int pincntl125; +	int pincntl126; +	int pincntl127; +	int pincntl128; +	int pincntl129; +	int pincntl130; +	int pincntl131; +	int pincntl132; +	int pincntl133; +	int pincntl134; +	int pincntl135; +	int pincntl136; +	int pincntl137; +	int pincntl138; +	int pincntl139; +	int pincntl140; +	int pincntl141; +	int pincntl142; +	int pincntl143; +	int pincntl144; +	int pincntl145; +	int pincntl146; +	int pincntl147; +	int pincntl148; +	int pincntl149; +	int pincntl150; +	int pincntl151; +	int pincntl152; +	int pincntl153; +	int pincntl154; +	int pincntl155; +	int pincntl156; +	int pincntl157; +	int pincntl158; +	int pincntl159; +	int pincntl160; +	int pincntl161; +	int pincntl162; +	int pincntl163; +	int pincntl164; +	int pincntl165; +	int pincntl166; +	int pincntl167; +	int pincntl168; +	int pincntl169; +	int pincntl170; +	int pincntl171; +	int pincntl172; +	int pincntl173; +	int pincntl174; +	int pincntl175; +	int pincntl176; +	int pincntl177; +	int pincntl178; +	int pincntl179; +	int pincntl180; +	int pincntl181; +	int pincntl182; +	int pincntl183; +	int pincntl184; +	int pincntl185; +	int pincntl186; +	int pincntl187; +	int pincntl188; +	int pincntl189; +	int pincntl190; +	int pincntl191; +	int pincntl192; +	int pincntl193; +	int pincntl194; +	int pincntl195; +	int pincntl196; +	int pincntl197; +	int pincntl198; +	int pincntl199; +	int pincntl200; +	int pincntl201; +	int pincntl202; +	int pincntl203; +	int pincntl204; +	int pincntl205; +	int pincntl206; +	int pincntl207; +	int pincntl208; +	int pincntl209; +	int pincntl210; +	int pincntl211; +	int pincntl212; +	int pincntl213; +	int pincntl214; +	int pincntl215; +	int pincntl216; +	int pincntl217; +	int pincntl218; +	int pincntl219; +	int pincntl220; +	int pincntl221; +	int pincntl222; +	int pincntl223; +	int pincntl224; +	int pincntl225; +	int pincntl226; +	int pincntl227; +	int pincntl228; +	int pincntl229; +	int pincntl230; +	int pincntl231; +	int pincntl232; +	int pincntl233; +	int pincntl234; +	int pincntl235; +	int pincntl236; +	int pincntl237; +	int pincntl238; +	int pincntl239; +	int pincntl240; +	int pincntl241; +	int pincntl242; +	int pincntl243; +	int pincntl244; +	int pincntl245; +	int pincntl246; +	int pincntl247; +	int pincntl248; +	int pincntl249; +	int pincntl250; +	int pincntl251; +	int pincntl252; +	int pincntl253; +	int pincntl254; +	int pincntl255; +	int pincntl256; +	int pincntl257; +	int pincntl258; +	int pincntl259; +	int pincntl260; +	int pincntl261; +	int pincntl262; +	int pincntl263; +	int pincntl264; +	int pincntl265; +	int pincntl266; +	int pincntl267; +	int pincntl268; +	int pincntl269; +	int pincntl270; +	int pincntl271; +	int pincntl272; +	int pincntl273; +	int pincntl274; +	int pincntl275; +	int pincntl276; +	int pincntl277; +	int pincntl278; +	int pincntl279; +	int pincntl280; +	int pincntl281; +	int pincntl282; +	int pincntl283; +	int pincntl284; +	int pincntl285; +	int pincntl286; +	int pincntl287; +	int pincntl288; +	int pincntl289; +	int pincntl290; +	int pincntl291; +	int pincntl292; +	int pincntl293; +	int pincntl294; +	int pincntl295; +	int pincntl296; +	int pincntl297; +	int pincntl298; +	int pincntl299; +	int pincntl300; +	int pincntl301; +	int pincntl302; +	int pincntl303; +	int pincntl304; +	int pincntl305; +	int pincntl306; +	int pincntl307; +	int pincntl308; +	int pincntl309; +	int pincntl310; +	int pincntl311; +	int pincntl312; +	int pincntl313; +	int pincntl314; +	int pincntl315; +	int pincntl316; +	int pincntl317; +	int pincntl318; +	int pincntl319; +	int pincntl320; +	int pincntl321; +	int pincntl322; +	int pincntl323; +}; + +#endif /* endif _MUX_TI816X_H_ */ diff --git a/arch/arm/include/asm/arch-am33xx/omap.h b/arch/arm/include/asm/arch-am33xx/omap.h index 66c61e54f..1f8431196 100644 --- a/arch/arm/include/asm/arch-am33xx/omap.h +++ b/arch/arm/include/asm/arch-am33xx/omap.h @@ -15,18 +15,17 @@  #ifndef _OMAP_H_  #define _OMAP_H_ -/* - * Non-secure SRAM Addresses - * Non-secure RAM starts at 0x40300000 for GP devices. But we keep SRAM_BASE - * at 0x40304000(EMU base) so that our code works for both EMU and GP - */  #ifdef CONFIG_AM33XX  #define NON_SECURE_SRAM_START	0x402F0400  #define NON_SECURE_SRAM_END	0x40310000  #define SRAM_SCRATCH_SPACE_ADDR	0x4030C000 -#elif defined(CONFIG_TI814X) +#elif defined(CONFIG_TI81XX)  #define NON_SECURE_SRAM_START	0x40300000  #define NON_SECURE_SRAM_END	0x40320000  #define SRAM_SCRATCH_SPACE_ADDR	0x4031B800 +#elif defined(CONFIG_AM43XX) +#define NON_SECURE_SRAM_START	0x402F0400 +#define NON_SECURE_SRAM_END	0x40340000 +#define SRAM_SCRATCH_SPACE_ADDR	0x4033C000  #endif  #endif diff --git a/arch/arm/include/asm/arch-am33xx/spl.h b/arch/arm/include/asm/arch-am33xx/spl.h index e428512b1..95de9aa23 100644 --- a/arch/arm/include/asm/arch-am33xx/spl.h +++ b/arch/arm/include/asm/arch-am33xx/spl.h @@ -7,9 +7,17 @@  #ifndef	_ASM_ARCH_SPL_H_  #define	_ASM_SPL_H_ +#if defined(CONFIG_TI816X) +#define BOOT_DEVICE_XIP		2 +#define BOOT_DEVICE_NAND	3 +#define BOOT_DEVICE_MMC1	6 +#define BOOT_DEVICE_MMC2	5 +#define BOOT_DEVICE_UART	0x43 +#define BOOT_DEVICE_MMC2_2	0xFF +#else  #define BOOT_DEVICE_XIP       	2  #define BOOT_DEVICE_NAND	5 -#ifdef CONFIG_AM33XX +#if defined(CONFIG_AM33XX) || defined(CONFIG_AM43XX)  #define BOOT_DEVICE_MMC1	8  #define BOOT_DEVICE_MMC2	9	/* eMMC or daughter card */  #elif defined(CONFIG_TI814X) @@ -21,11 +29,12 @@  #define BOOT_DEVICE_USBETH	68  #define BOOT_DEVICE_CPGMAC	70  #define BOOT_DEVICE_MMC2_2      0xFF +#endif -#ifdef CONFIG_AM33XX +#if defined(CONFIG_AM33XX) || defined(CONFIG_AM43XX)  #define MMC_BOOT_DEVICES_START	BOOT_DEVICE_MMC1  #define MMC_BOOT_DEVICES_END	BOOT_DEVICE_MMC2 -#elif defined(CONFIG_TI814X) +#elif defined(CONFIG_TI81XX)  #define MMC_BOOT_DEVICES_START	BOOT_DEVICE_MMC2  #define MMC_BOOT_DEVICES_END	BOOT_DEVICE_MMC1  #endif diff --git a/arch/arm/include/asm/arch-am33xx/sys_proto.h b/arch/arm/include/asm/arch-am33xx/sys_proto.h index 1424f90bf..c6070a3fc 100644 --- a/arch/arm/include/asm/arch-am33xx/sys_proto.h +++ b/arch/arm/include/asm/arch-am33xx/sys_proto.h @@ -35,6 +35,11 @@ void enable_gpmc_cs_config(const u32 *gpmc_config, struct gpmc_cs *cs, u32 base,  			u32 size);  void omap_nand_switch_ecc(uint32_t, uint32_t); -void rtc32k_enable(void); -void uart_soft_reset(void); +void set_uart_mux_conf(void); +void set_mux_conf_regs(void); +void sdram_init(void); +u32 wait_on_value(u32, u32, void *, u32); +#ifdef CONFIG_NOR_BOOT +void enable_norboot_pin_mux(void); +#endif  #endif diff --git a/arch/arm/include/asm/arch-armv7/systimer.h b/arch/arm/include/asm/arch-armv7/systimer.h index b86ab691f..a0412bd34 100644 --- a/arch/arm/include/asm/arch-armv7/systimer.h +++ b/arch/arm/include/asm/arch-armv7/systimer.h @@ -14,6 +14,8 @@  #define SYSTIMER_RELOAD		0xFFFFFFFF  #define SYSTIMER_EN		(1 << 7)  #define SYSTIMER_32BIT		(1 << 1) +#define SYSTIMER_PRESC_16	(1 << 2) +#define SYSTIMER_PRESC_256	(1 << 3)  struct systimer {  	u32 timer0load;		/* 0x00 */ diff --git a/arch/arm/include/asm/arch-davinci/da8xx-fb.h b/arch/arm/include/asm/arch-davinci/da8xx-fb.h deleted file mode 100644 index c115034f0..000000000 --- a/arch/arm/include/asm/arch-davinci/da8xx-fb.h +++ /dev/null @@ -1,113 +0,0 @@ -/* - * Porting to u-boot: - * - * (C) Copyright 2011 - * Stefano Babic, DENX Software Engineering, sbabic@denx.de. - * - * Copyright (C) 2008-2009 MontaVista Software Inc. - * Copyright (C) 2008-2009 Texas Instruments Inc - * - * Based on the LCD driver for TI Avalanche processors written by - * Ajay Singh and Shalom Hai. - * - * SPDX-License-Identifier:	GPL-2.0+ - */ - -#ifndef DA8XX_FB_H -#define DA8XX_FB_H - -enum panel_type { -	QVGA = 0 -}; - -enum panel_shade { -	MONOCHROME = 0, -	COLOR_ACTIVE, -	COLOR_PASSIVE, -}; - -enum raster_load_mode { -	LOAD_DATA = 1, -	LOAD_PALETTE, -}; - -struct display_panel { -	enum panel_type panel_type; /* QVGA */ -	int max_bpp; -	int min_bpp; -	enum panel_shade panel_shade; -}; - -struct da8xx_panel { -	const char	name[25];	/* Full name <vendor>_<model> */ -	unsigned short	width; -	unsigned short	height; -	int		hfp;		/* Horizontal front porch */ -	int		hbp;		/* Horizontal back porch */ -	int		hsw;		/* Horizontal Sync Pulse Width */ -	int		vfp;		/* Vertical front porch */ -	int		vbp;		/* Vertical back porch */ -	int		vsw;		/* Vertical Sync Pulse Width */ -	unsigned int	pxl_clk;	/* Pixel clock */ -	unsigned char	invert_pxl_clk;	/* Invert Pixel clock */ -}; - -struct da8xx_lcdc_platform_data { -	const char manu_name[10]; -	void *controller_data; -	const char type[25]; -	void (*panel_power_ctrl)(int); -}; - -struct lcd_ctrl_config { -	const struct display_panel *p_disp_panel; - -	/* AC Bias Pin Frequency */ -	int ac_bias; - -	/* AC Bias Pin Transitions per Interrupt */ -	int ac_bias_intrpt; - -	/* DMA burst size */ -	int dma_burst_sz; - -	/* Bits per pixel */ -	int bpp; - -	/* FIFO DMA Request Delay */ -	int fdd; - -	/* TFT Alternative Signal Mapping (Only for active) */ -	unsigned char tft_alt_mode; - -	/* 12 Bit Per Pixel (5-6-5) Mode (Only for passive) */ -	unsigned char stn_565_mode; - -	/* Mono 8-bit Mode: 1=D0-D7 or 0=D0-D3 */ -	unsigned char mono_8bit_mode; - -	/* Invert line clock */ -	unsigned char invert_line_clock; - -	/* Invert frame clock  */ -	unsigned char invert_frm_clock; - -	/* Horizontal and Vertical Sync Edge: 0=rising 1=falling */ -	unsigned char sync_edge; - -	/* Horizontal and Vertical Sync: Control: 0=ignore */ -	unsigned char sync_ctrl; - -	/* Raster Data Order Select: 1=Most-to-least 0=Least-to-most */ -	unsigned char raster_order; -}; - -struct lcd_sync_arg { -	int back_porch; -	int front_porch; -	int pulse_width; -}; - -void da8xx_video_init(const struct da8xx_panel *panel, int bits_pixel); - -#endif  /* ifndef DA8XX_FB_H */ diff --git a/arch/arm/include/asm/arch-davinci/pinmux_defs.h b/arch/arm/include/asm/arch-davinci/pinmux_defs.h index 4d45799a6..2d82af554 100644 --- a/arch/arm/include/asm/arch-davinci/pinmux_defs.h +++ b/arch/arm/include/asm/arch-davinci/pinmux_defs.h @@ -23,12 +23,13 @@ extern const struct pinmux_config spi1_pins_scs0[1];  /* UART pin muxer settings */  extern const struct pinmux_config uart0_pins_txrx[2]; +extern const struct pinmux_config uart0_pins_rtscts[2];  extern const struct pinmux_config uart1_pins_txrx[2];  extern const struct pinmux_config uart2_pins_txrx[2];  extern const struct pinmux_config uart2_pins_rtscts[2];  /* EMAC pin muxer settings*/ -extern const struct pinmux_config emac_pins_rmii[7]; +extern const struct pinmux_config emac_pins_rmii[8];  extern const struct pinmux_config emac_pins_rmii_clk_source[1];  extern const struct pinmux_config emac_pins_mii[15];  extern const struct pinmux_config emac_pins_mdio[2]; diff --git a/arch/arm/include/asm/arch-exynos/mipi_dsim.h b/arch/arm/include/asm/arch-exynos/mipi_dsim.h index 8916d9d16..498a9ffc0 100644 --- a/arch/arm/include/asm/arch-exynos/mipi_dsim.h +++ b/arch/arm/include/asm/arch-exynos/mipi_dsim.h @@ -291,7 +291,7 @@ struct exynos_platform_mipi_dsim {   */  struct mipi_dsim_master_ops {  	int (*cmd_write)(struct mipi_dsim_device *dsim, unsigned int data_id, -		unsigned int data0, unsigned int data1); +		const unsigned char *data0, unsigned int data1);  	int (*cmd_read)(struct mipi_dsim_device *dsim, unsigned int data_id,  		unsigned int data0, unsigned int data1);  	int (*get_dsim_frame_done)(struct mipi_dsim_device *dsim); diff --git a/arch/arm/include/asm/arch-mx5/clock.h b/arch/arm/include/asm/arch-mx5/clock.h index 406d150ae..9ee79aede 100644 --- a/arch/arm/include/asm/arch-mx5/clock.h +++ b/arch/arm/include/asm/arch-mx5/clock.h @@ -46,10 +46,10 @@ u32 imx_get_fecclk(void);  unsigned int mxc_get_clock(enum mxc_clock clk);  int mxc_set_clock(u32 ref, u32 freq, u32 clk_type);  void set_usb_phy_clk(void); -void enable_usb_phy1_clk(unsigned char enable); -void enable_usb_phy2_clk(unsigned char enable); +void enable_usb_phy1_clk(bool enable); +void enable_usb_phy2_clk(bool enable);  void set_usboh3_clk(void); -void enable_usboh3_clk(unsigned char enable); +void enable_usboh3_clk(bool enable);  void mxc_set_sata_internal_clock(void);  int enable_i2c_clk(unsigned char enable, unsigned i2c_num);  void enable_nfc_clk(unsigned char enable); diff --git a/arch/arm/include/asm/arch-mx6/clock.h b/arch/arm/include/asm/arch-mx6/clock.h index 21a4fbb59..c49368765 100644 --- a/arch/arm/include/asm/arch-mx6/clock.h +++ b/arch/arm/include/asm/arch-mx6/clock.h @@ -49,5 +49,5 @@ void enable_ocotp_clk(unsigned char enable);  void enable_usboh3_clk(unsigned char enable);  int enable_sata_clock(void);  int enable_i2c_clk(unsigned char enable, unsigned i2c_num); - +void enable_ipu_clock(void);  #endif /* __ASM_ARCH_CLOCK_H */ diff --git a/arch/arm/include/asm/arch-mx6/mxc_hdmi.h b/arch/arm/include/asm/arch-mx6/mxc_hdmi.h index 561e8ff82..e5e3eff59 100644 --- a/arch/arm/include/asm/arch-mx6/mxc_hdmi.h +++ b/arch/arm/include/asm/arch-mx6/mxc_hdmi.h @@ -9,6 +9,11 @@  #ifndef __MXC_HDMI_H__  #define __MXC_HDMI_H__ +#ifdef CONFIG_IMX_HDMI +void imx_enable_hdmi_phy(void); +void imx_setup_hdmi(void); +#endif +  /*   * Hdmi controller registers   */ @@ -884,6 +889,9 @@ enum {  	HDMI_PHY_HPD = 0x02,  	HDMI_PHY_TX_PHY_LOCK = 0x01, +/* Convenience macro RX_SENSE | HPD */ +	HDMI_DVI_STAT = 0xF2, +  /* PHY_I2CM_SLAVE_ADDR field values */  	HDMI_PHY_I2CM_SLAVE_ADDR_PHY_GEN2 = 0x69,  	HDMI_PHY_I2CM_SLAVE_ADDR_HEAC_PHY = 0x49, diff --git a/arch/arm/include/asm/arch-omap3/clock.h b/arch/arm/include/asm/arch-omap3/clock.h index da776cf5b..514839c77 100644 --- a/arch/arm/include/asm/arch-omap3/clock.h +++ b/arch/arm/include/asm/arch-omap3/clock.h @@ -61,6 +61,7 @@ extern dpll_param *get_36x_mpu_dpll_param(void);  extern dpll_param *get_36x_iva_dpll_param(void);  extern dpll_param *get_36x_core_dpll_param(void);  extern dpll_param *get_36x_per_dpll_param(void); +extern dpll_param *get_36x_per2_dpll_param(void);  extern void *_end_vect, *_start; diff --git a/arch/arm/include/asm/arch-omap3/clocks_omap3.h b/arch/arm/include/asm/arch-omap3/clocks_omap3.h index bf7fa0020..df73c4b2e 100644 --- a/arch/arm/include/asm/arch-omap3/clocks_omap3.h +++ b/arch/arm/include/asm/arch-omap3/clocks_omap3.h @@ -323,4 +323,26 @@  #define PER_36XX_FSEL_38P4	0x07  #define PER_36XX_M2_38P4	0x09 +/* 36XX PER2 DPLL */ + +#define PER2_36XX_M_12		0x50 +#define PER2_36XX_N_12		0x00 +#define PER2_36XX_M2_12		0x08 + +#define PER2_36XX_M_13		0x1BB +#define PER2_36XX_N_13		0x05 +#define PER2_36XX_M2_13		0x08 + +#define PER2_36XX_M_19P2		0x32 +#define PER2_36XX_N_19P2		0x00 +#define PER2_36XX_M2_19P2		0x08 + +#define PER2_36XX_M_26		0x1BB +#define PER2_36XX_N_26		0x0B +#define PER2_36XX_M2_26		0x08 + +#define PER2_36XX_M_38P4		0x19 +#define PER2_36XX_N_38P4		0x00 +#define PER2_36XX_M2_38P4		0x08 +  #endif	/* endif _CLOCKS_OMAP3_H_ */ diff --git a/arch/arm/include/asm/arch-omap3/gpio.h b/arch/arm/include/asm/arch-omap3/gpio.h index d72f5e50a..f664c1199 100644 --- a/arch/arm/include/asm/arch-omap3/gpio.h +++ b/arch/arm/include/asm/arch-omap3/gpio.h @@ -2,20 +2,7 @@   * Copyright (c) 2009 Wind River Systems, Inc.   * Tom Rix <Tom.Rix@windriver.com>   * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA + * SPDX-License-Identifier:	GPL-2.0   *   * This work is derived from the linux 2.6.27 kernel source   * To fetch, use the kernel repository @@ -30,10 +17,6 @@   *   * Copyright (C) 2003-2005 Nokia Corporation   * Written by Juha Yrjölä <juha.yrjola@nokia.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation.   */  #ifndef _GPIO_OMAP3_H  #define _GPIO_OMAP3_H diff --git a/arch/arm/include/asm/arch-omap4/gpio.h b/arch/arm/include/asm/arch-omap4/gpio.h index fdf65edab..72ba1d71a 100644 --- a/arch/arm/include/asm/arch-omap4/gpio.h +++ b/arch/arm/include/asm/arch-omap4/gpio.h @@ -2,20 +2,7 @@   * Copyright (c) 2009 Wind River Systems, Inc.   * Tom Rix <Tom.Rix@windriver.com>   * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA + * SPDX-License-Identifier:	GPL-2.0   *   * This work is derived from the linux 2.6.27 kernel source   * To fetch, use the kernel repository @@ -30,10 +17,6 @@   *   * Copyright (C) 2003-2005 Nokia Corporation   * Written by Juha Yrjölä <juha.yrjola@nokia.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation.   */  #ifndef _GPIO_OMAP4_H  #define _GPIO_OMAP4_H diff --git a/arch/arm/include/asm/arch-omap5/clock.h b/arch/arm/include/asm/arch-omap5/clock.h index 3adfc090f..9a2166ce4 100644 --- a/arch/arm/include/asm/arch-omap5/clock.h +++ b/arch/arm/include/asm/arch-omap5/clock.h @@ -149,6 +149,23 @@  /* CM_L3INIT_USBPHY_CLKCTRL */  #define USBPHY_CLKCTRL_OPTFCLKEN_PHY_48M_MASK	8 +/* CM_L3INIT_USB_HOST_HS_CLKCTRL */ +#define OPTFCLKEN_FUNC48M_CLK			(1 << 15) +#define OPTFCLKEN_HSIC480M_P2_CLK		(1 << 14) +#define OPTFCLKEN_HSIC480M_P1_CLK		(1 << 13) +#define OPTFCLKEN_HSIC60M_P2_CLK		(1 << 12) +#define OPTFCLKEN_HSIC60M_P1_CLK		(1 << 11) +#define OPTFCLKEN_UTMI_P3_CLK			(1 << 10) +#define OPTFCLKEN_UTMI_P2_CLK			(1 << 9) +#define OPTFCLKEN_UTMI_P1_CLK			(1 << 8) +#define OPTFCLKEN_HSIC480M_P3_CLK		(1 << 7) +#define OPTFCLKEN_HSIC60M_P3_CLK		(1 << 6) + +/* CM_L3INIT_USB_TLL_HS_CLKCTRL */ +#define OPTFCLKEN_USB_CH0_CLK_ENABLE	(1 << 8) +#define OPTFCLKEN_USB_CH1_CLK_ENABLE	(1 << 9) +#define OPTFCLKEN_USB_CH2_CLK_ENABLE	(1 << 10) +  /* CM_MPU_MPU_CLKCTRL */  #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_SHIFT	24  #define MPU_CLKCTRL_CLKSEL_EMIF_DIV_MODE_MASK	(3 << 24) diff --git a/arch/arm/include/asm/arch-omap5/cpu.h b/arch/arm/include/asm/arch-omap5/cpu.h index 3de598494..fb5a568b6 100644 --- a/arch/arm/include/asm/arch-omap5/cpu.h +++ b/arch/arm/include/asm/arch-omap5/cpu.h @@ -99,6 +99,8 @@ struct watchdog {  #endif /* __ASSEMBLY__ */  #endif /* __KERNEL_STRICT_NAMES */ +#define BIT(x)				(1 << (x)) +  #define WD_UNLOCK1		0xAAAA  #define WD_UNLOCK2		0x5555 @@ -158,4 +160,8 @@ struct watchdog {  #define PRM_RSTST		(PRM_DEVICE_BASE + 0x4)  #define PRM_RSTST_WARM_RESET_MASK	0x7FEA +/* DRA7XX CPSW Config space */ +#define CPSW_BASE			0x48484000 +#define CPSW_MDIO_BASE			0x48485000 +  #endif /* _CPU_H */ diff --git a/arch/arm/include/asm/arch-omap5/ehci.h b/arch/arm/include/asm/arch-omap5/ehci.h new file mode 100644 index 000000000..3921e4ab4 --- /dev/null +++ b/arch/arm/include/asm/arch-omap5/ehci.h @@ -0,0 +1,43 @@ +/* + * Copyright (C) 2013 Texas Instruments Incorporated - http://www.ti.com* + * Author: Govindraj R <govindraj.raja@ti.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License as + * published by the Free Software Foundation; either version 2 of + * the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, + * MA 02111-1307 USA + */ + +#ifndef _EHCI_H +#define _EHCI_H + +#define OMAP_EHCI_BASE				(OMAP54XX_L4_CORE_BASE + 0x64C00) +#define OMAP_UHH_BASE				(OMAP54XX_L4_CORE_BASE + 0x64000) +#define OMAP_USBTLL_BASE			(OMAP54XX_L4_CORE_BASE + 0x62000) + +/* TLL Register Set */ +#define OMAP_USBTLL_SYSCONFIG_SIDLEMODE		(1 << 3) +#define OMAP_USBTLL_SYSCONFIG_ENAWAKEUP		(1 << 2) +#define OMAP_USBTLL_SYSCONFIG_SOFTRESET		(1 << 1) +#define OMAP_USBTLL_SYSCONFIG_CACTIVITY		(1 << 8) +#define OMAP_USBTLL_SYSSTATUS_RESETDONE		1 + +#define OMAP_UHH_SYSCONFIG_SOFTRESET		1 +#define OMAP_UHH_SYSSTATUS_EHCI_RESETDONE	(1 << 2) +#define OMAP_UHH_SYSCONFIG_NOIDLE		(1 << 2) +#define OMAP_UHH_SYSCONFIG_NOSTDBY		(1 << 4) + +#define OMAP_UHH_SYSCONFIG_VAL	(OMAP_UHH_SYSCONFIG_NOIDLE | \ +					OMAP_UHH_SYSCONFIG_NOSTDBY) + +#endif /* _EHCI_H */ diff --git a/arch/arm/include/asm/arch-omap5/gpio.h b/arch/arm/include/asm/arch-omap5/gpio.h index 7c82f9036..9dd03c9fa 100644 --- a/arch/arm/include/asm/arch-omap5/gpio.h +++ b/arch/arm/include/asm/arch-omap5/gpio.h @@ -2,20 +2,7 @@   * Copyright (c) 2009 Wind River Systems, Inc.   * Tom Rix <Tom.Rix@windriver.com>   * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA + * SPDX-License-Identifier:	GPL-2.0   *   * This work is derived from the linux 2.6.27 kernel source   * To fetch, use the kernel repository @@ -30,10 +17,6 @@   *   * Copyright (C) 2003-2005 Nokia Corporation   * Written by Juha Yrjölä <juha.yrjola@nokia.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation.   */  #ifndef _GPIO_OMAP5_H  #define _GPIO_OMAP5_H diff --git a/arch/arm/include/asm/arch-omap5/omap.h b/arch/arm/include/asm/arch-omap5/omap.h index d08fcff8b..597c692b9 100644 --- a/arch/arm/include/asm/arch-omap5/omap.h +++ b/arch/arm/include/asm/arch-omap5/omap.h @@ -192,6 +192,27 @@ struct s32ktimer {  #define OMAP5_ABB_LDOVBBMPU_MUX_CTRL_MASK	(0x1 << 10)  #define OMAP5_ABB_LDOVBBMPU_VSET_OUT_MASK	(0x1f << 0) +/* IO Delay module defines */ +#define CFG_IO_DELAY_BASE		0x4844A000 +#define CFG_IO_DELAY_LOCK		(CFG_IO_DELAY_BASE + 0x02C) + +/* CPSW IO Delay registers*/ +#define CFG_RGMII0_TXCTL		(CFG_IO_DELAY_BASE + 0x74C) +#define CFG_RGMII0_TXD0			(CFG_IO_DELAY_BASE + 0x758) +#define CFG_RGMII0_TXD1			(CFG_IO_DELAY_BASE + 0x764) +#define CFG_RGMII0_TXD2			(CFG_IO_DELAY_BASE + 0x770) +#define CFG_RGMII0_TXD3			(CFG_IO_DELAY_BASE + 0x77C) +#define CFG_VIN2A_D13			(CFG_IO_DELAY_BASE + 0xA7C) +#define CFG_VIN2A_D17			(CFG_IO_DELAY_BASE + 0xAAC) +#define CFG_VIN2A_D16			(CFG_IO_DELAY_BASE + 0xAA0) +#define CFG_VIN2A_D15			(CFG_IO_DELAY_BASE + 0xA94) +#define CFG_VIN2A_D14			(CFG_IO_DELAY_BASE + 0xA88) + +#define CFG_IO_DELAY_UNLOCK_KEY		0x0000AAAA +#define CFG_IO_DELAY_LOCK_KEY		0x0000AAAB +#define CFG_IO_DELAY_ACCESS_PATTERN	0x00029000 +#define CFG_IO_DELAY_LOCK_MASK		0x400 +  #ifndef __ASSEMBLY__  struct srcomp_params {  	s8 divide_factor; @@ -208,5 +229,10 @@ struct ctrl_ioregs {  	u32 ctrl_emif_sdram_config_ext;  	u32 ctrl_ddr_ctrl_ext_0;  }; + +struct io_delay { +	u32 addr; +	u32 dly; +};  #endif /* __ASSEMBLY__ */  #endif diff --git a/arch/arm/include/asm/arch-zynq/hardware.h b/arch/arm/include/asm/arch-zynq/hardware.h index ca56d8a2d..cd6967772 100644 --- a/arch/arm/include/asm/arch-zynq/hardware.h +++ b/arch/arm/include/asm/arch-zynq/hardware.h @@ -17,6 +17,8 @@  #define ZYNQ_SDHCI_BASEADDR1		0xE0101000  #define ZYNQ_I2C_BASEADDR0		0xE0004000  #define ZYNQ_I2C_BASEADDR1		0xE0005000 +#define ZYNQ_SPI_BASEADDR0		0xE0006000 +#define ZYNQ_SPI_BASEADDR1		0xE0007000  #define ZYNQ_DDRC_BASEADDR		0xF8006000  /* Reflect slcr offsets */ diff --git a/arch/arm/include/asm/ehci-omap.h b/arch/arm/include/asm/ehci-omap.h index 77e81701b..ac83a539a 100644 --- a/arch/arm/include/asm/ehci-omap.h +++ b/arch/arm/include/asm/ehci-omap.h @@ -42,6 +42,7 @@ enum usbhs_omap_port_mode {  /* Values of UHH_REVISION - Note: these are not given in the TRM */  #define OMAP_USBHS_REV1					0x00000010 /* OMAP3 */  #define OMAP_USBHS_REV2					0x50700100 /* OMAP4 */ +#define OMAP_USBHS_REV2_1				0x50700101 /* OMAP5 */  /* UHH Register Set */  #define OMAP_UHH_HOSTCONFIG_INCR4_BURST_EN		(1 << 2) @@ -60,6 +61,7 @@ enum usbhs_omap_port_mode {  #define OMAP_P2_MODE_CLEAR				(3 << 18)  #define OMAP_P2_MODE_TLL				(1 << 18)  #define OMAP_P2_MODE_HSIC				(3 << 18) +#define OMAP_P3_MODE_CLEAR				(3 << 20)  #define OMAP_P3_MODE_HSIC				(3 << 20)  /* EHCI Register Set */ diff --git a/arch/arm/include/asm/imx-common/dma.h b/arch/arm/include/asm/imx-common/dma.h index 5f516ef6e..d5c1f7f25 100644 --- a/arch/arm/include/asm/imx-common/dma.h +++ b/arch/arm/include/asm/imx-common/dma.h @@ -161,4 +161,6 @@ void mxs_dma_init(void);  int mxs_dma_init_channel(int chan);  int mxs_dma_release(int chan); +void mxs_dma_circ_start(int chan, struct mxs_dma_desc *pdesc); +  #endif	/* __DMA_H__ */ diff --git a/arch/arm/include/asm/omap_common.h b/arch/arm/include/asm/omap_common.h index b56e9493e..66f416f99 100644 --- a/arch/arm/include/asm/omap_common.h +++ b/arch/arm/include/asm/omap_common.h @@ -73,6 +73,7 @@ struct prcm_regs {  	u32 cm_ssc_deltamstep_dpll_ddrphy;  	u32 cm_clkmode_dpll_dsp;  	u32 cm_shadow_freq_config1; +	u32 cm_clkmode_dpll_gmac;  	u32 cm_mpu_mpu_clkctrl;  	/* cm1.dsp */ @@ -339,10 +340,18 @@ struct prcm_regs {  	/* SCRM stuff, used by some boards */  	u32 scrm_auxclk0;  	u32 scrm_auxclk1; + +	/* GMAC Clk Ctrl */ +	u32 cm_gmac_gmac_clkctrl; +	u32 cm_gmac_clkstctrl;  };  struct omap_sys_ctrl_regs {  	u32 control_status; +	u32 control_core_mac_id_0_lo; +	u32 control_core_mac_id_0_hi; +	u32 control_core_mac_id_1_lo; +	u32 control_core_mac_id_1_hi;  	u32 control_std_fuse_opp_vdd_mpu_2;  	u32 control_core_mmr_lock1;  	u32 control_core_mmr_lock2; @@ -483,6 +492,7 @@ struct dplls {  	const struct dpll_params *iva;  	const struct dpll_params *usb;  	const struct dpll_params *ddr; +	const struct dpll_params *gmac;  };  struct pmic_data { diff --git a/arch/arm/include/asm/omap_gpio.h b/arch/arm/include/asm/omap_gpio.h index 1ebfa8694..5d25d04c3 100644 --- a/arch/arm/include/asm/omap_gpio.h +++ b/arch/arm/include/asm/omap_gpio.h @@ -2,20 +2,7 @@   * Copyright (c) 2009 Wind River Systems, Inc.   * Tom Rix <Tom.Rix@windriver.com>   * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA + * SPDX-License-Identifier:	GPL-2.0   *   * This work is derived from the linux 2.6.27 kernel source   * To fetch, use the kernel repository @@ -30,10 +17,6 @@   *   * Copyright (C) 2003-2005 Nokia Corporation   * Written by Juha Yrjölä <juha.yrjola@nokia.com> - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License version 2 as - * published by the Free Software Foundation.   */  #ifndef _GPIO_H  #define _GPIO_H diff --git a/arch/arm/lib/board.c b/arch/arm/lib/board.c index 9c72a5353..34f50b08a 100644 --- a/arch/arm/lib/board.c +++ b/arch/arm/lib/board.c @@ -435,6 +435,7 @@ void board_init_f(ulong bootflag)  	addr_sp += 128;	/* leave 32 words for abort-stack   */  	gd->irq_sp = addr_sp;  #endif +	interrupt_init();  	debug("New Stack Pointer is: %08lx\n", addr_sp); @@ -636,8 +637,6 @@ void board_init_r(gd_t *id, ulong dest_addr)  	misc_init_r();  #endif -	 /* set up exceptions */ -	interrupt_init();  	/* enable exceptions */  	enable_interrupts(); diff --git a/arch/arm/lib/spl.c b/arch/arm/lib/spl.c index 583bdb3ac..26d0be47e 100644 --- a/arch/arm/lib/spl.c +++ b/arch/arm/lib/spl.c @@ -45,12 +45,17 @@ void __weak board_init_f(ulong dummy)  #ifdef CONFIG_SPL_OS_BOOT  void __noreturn jump_to_image_linux(void *arg)  { +	unsigned long machid = 0xffffffff; +#ifdef CONFIG_MACH_TYPE +	machid = CONFIG_MACH_TYPE; +#endif +  	debug("Entering kernel arg pointer: 0x%p\n", arg);  	typedef void (*image_entry_arg_t)(int, int, void *)  		__attribute__ ((noreturn));  	image_entry_arg_t image_entry =  		(image_entry_arg_t) spl_image.entry_point;  	cleanup_before_linux(); -	image_entry(0, CONFIG_MACH_TYPE, arg); +	image_entry(0, machid, arg);  }  #endif diff --git a/arch/microblaze/lib/board.c b/arch/microblaze/lib/board.c index 8267191fd..f7182f27e 100644 --- a/arch/microblaze/lib/board.c +++ b/arch/microblaze/lib/board.c @@ -16,6 +16,7 @@  #include <stdio_dev.h>  #include <serial.h>  #include <net.h> +#include <spi.h>  #include <linux/compiler.h>  #include <asm/processor.h>  #include <asm/microblaze_intc.h> @@ -147,6 +148,10 @@ void board_init_f(ulong not_used)  	}  #endif +#ifdef CONFIG_SPI +	spi_init(); +#endif +  	/* relocate environment function pointers etc. */  	env_relocate(); diff --git a/arch/mips/include/asm/config.h b/arch/mips/include/asm/config.h index cd2973478..3a891ba62 100644 --- a/arch/mips/include/asm/config.h +++ b/arch/mips/include/asm/config.h @@ -7,4 +7,7 @@  #ifndef _ASM_CONFIG_H_  #define _ASM_CONFIG_H_ +#define CONFIG_LMB +#define CONFIG_SYS_BOOT_RAMDISK_HIGH +  #endif diff --git a/arch/mips/lib/Makefile b/arch/mips/lib/Makefile index e9f82f711..f91406c06 100644 --- a/arch/mips/lib/Makefile +++ b/arch/mips/lib/Makefile @@ -19,11 +19,7 @@ LGOBJS	:= $(addprefix $(obj),$(GLSOBJS))  SOBJS-y	+=  COBJS-y	+= board.o -ifeq ($(CONFIG_QEMU_MIPS),y) -COBJS-$(CONFIG_CMD_BOOTM) += bootm_qemu_mips.o -else  COBJS-$(CONFIG_CMD_BOOTM) += bootm.o -endif  SRCS	:= $(SOBJS-y:.o=.S) $(COBJS-y:.o=.c)  OBJS	:= $(addprefix $(obj),$(SOBJS-y) $(COBJS-y)) diff --git a/arch/mips/lib/bootm.c b/arch/mips/lib/bootm.c index ade9af47e..66340ea47 100644 --- a/arch/mips/lib/bootm.c +++ b/arch/mips/lib/bootm.c @@ -17,23 +17,148 @@ DECLARE_GLOBAL_DATA_PTR;  #define	LINUX_MAX_ENVS		256  #define	LINUX_MAX_ARGS		256 +#if defined(CONFIG_QEMU_MALTA) +#define mips_boot_qemu_malta	1 +#else +#define mips_boot_qemu_malta	0 +#endif +  static int linux_argc;  static char **linux_argv; +static char *linux_argp;  static char **linux_env;  static char *linux_env_p;  static int linux_env_idx; -static void linux_params_init(ulong start, char *commandline); -static void linux_env_set(char *env_name, char *env_val); +static ulong arch_get_sp(void) +{ +	ulong ret; + +	__asm__ __volatile__("move %0, $sp" : "=r"(ret) : ); + +	return ret; +} + +void arch_lmb_reserve(struct lmb *lmb) +{ +	ulong sp; + +	sp = arch_get_sp(); +	debug("## Current stack ends at 0x%08lx\n", sp); + +	/* adjust sp by 4K to be safe */ +	sp -= 4096; +	lmb_reserve(lmb, sp, CONFIG_SYS_SDRAM_BASE + gd->ram_size - sp); +} + +static void linux_cmdline_init(void) +{ +	linux_argc = 1; +	linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params); +	linux_argv[0] = 0; +	linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS); +} + +static void linux_cmdline_set(const char *value, size_t len) +{ +	linux_argv[linux_argc] = linux_argp; +	memcpy(linux_argp, value, len); +	linux_argp[len] = 0; + +	linux_argp += len + 1; +	linux_argc++; +} + +static void linux_cmdline_dump(void) +{ +	int i; + +	debug("## cmdline argv at 0x%p, argp at 0x%p\n", +	      linux_argv, linux_argp); + +	for (i = 1; i < linux_argc; i++) +		debug("   arg %03d: %s\n", i, linux_argv[i]); +} + +static void boot_cmdline_linux(bootm_headers_t *images) +{ +	const char *bootargs, *next, *quote; + +	linux_cmdline_init(); + +	bootargs = getenv("bootargs"); +	if (!bootargs) +		return; + +	next = bootargs; + +	while (bootargs && *bootargs && linux_argc < LINUX_MAX_ARGS) { +		quote = strchr(bootargs, '"'); +		next = strchr(bootargs, ' '); + +		while (next && quote && quote < next) { +			/* +			 * we found a left quote before the next blank +			 * now we have to find the matching right quote +			 */ +			next = strchr(quote + 1, '"'); +			if (next) { +				quote = strchr(next + 1, '"'); +				next = strchr(next + 1, ' '); +			} +		} + +		if (!next) +			next = bootargs + strlen(bootargs); + +		linux_cmdline_set(bootargs, next - bootargs); + +		if (*next) +			next++; + +		bootargs = next; +	} + +	linux_cmdline_dump(); +} + +static void linux_env_init(void) +{ +	linux_env = (char **)(((ulong) linux_argp + 15) & ~15); +	linux_env[0] = 0; +	linux_env_p = (char *)(linux_env + LINUX_MAX_ENVS); +	linux_env_idx = 0; +} + +static void linux_env_set(const char *env_name, const char *env_val) +{ +	if (linux_env_idx < LINUX_MAX_ENVS - 1) { +		linux_env[linux_env_idx] = linux_env_p; + +		strcpy(linux_env_p, env_name); +		linux_env_p += strlen(env_name); + +		if (mips_boot_qemu_malta) { +			linux_env_p++; +			linux_env[++linux_env_idx] = linux_env_p; +		} else { +			*linux_env_p++ = '='; +		} + +		strcpy(linux_env_p, env_val); +		linux_env_p += strlen(env_val); + +		linux_env_p++; +		linux_env[++linux_env_idx] = 0; +	} +}  static void boot_prep_linux(bootm_headers_t *images)  { -	char *commandline = getenv("bootargs");  	char env_buf[12]; -	char *cp; - -	linux_params_init(UNCACHED_SDRAM(gd->bd->bi_boot_params), commandline); +	const char *cp; +	ulong rd_start, rd_size;  #ifdef CONFIG_MEMSIZE_IN_BYTES  	sprintf(env_buf, "%lu", (ulong)gd->ram_size); @@ -41,15 +166,20 @@ static void boot_prep_linux(bootm_headers_t *images)  #else  	sprintf(env_buf, "%lu", (ulong)(gd->ram_size >> 20));  	debug("## Giving linux memsize in MB, %lu\n", -		(ulong)(gd->ram_size >> 20)); +	      (ulong)(gd->ram_size >> 20));  #endif /* CONFIG_MEMSIZE_IN_BYTES */ +	rd_start = UNCACHED_SDRAM(images->initrd_start); +	rd_size = images->initrd_end - images->initrd_start; + +	linux_env_init(); +  	linux_env_set("memsize", env_buf); -	sprintf(env_buf, "0x%08X", (uint) UNCACHED_SDRAM(images->rd_start)); +	sprintf(env_buf, "0x%08lX", rd_start);  	linux_env_set("initrd_start", env_buf); -	sprintf(env_buf, "0x%X", (uint) (images->rd_end - images->rd_start)); +	sprintf(env_buf, "0x%lX", rd_size);  	linux_env_set("initrd_size", env_buf);  	sprintf(env_buf, "0x%08X", (uint) (gd->bd->bi_flashstart)); @@ -65,33 +195,42 @@ static void boot_prep_linux(bootm_headers_t *images)  	cp = getenv("eth1addr");  	if (cp)  		linux_env_set("eth1addr", cp); + +	if (mips_boot_qemu_malta) +		linux_env_set("modetty0", "38400n8r");  }  static void boot_jump_linux(bootm_headers_t *images)  { -	void (*theKernel) (int, char **, char **, int *); - -	/* find kernel entry point */ -	theKernel = (void (*)(int, char **, char **, int *))images->ep; +	typedef void __noreturn (*kernel_entry_t)(int, ulong, ulong, ulong); +	kernel_entry_t kernel = (kernel_entry_t) images->ep; +	ulong linux_extra = 0; -	debug("## Transferring control to Linux (at address %08lx) ...\n", -		(ulong) theKernel); +	debug("## Transferring control to Linux (at address %p) ...\n", kernel);  	bootstage_mark(BOOTSTAGE_ID_RUN_OS); +	if (mips_boot_qemu_malta) +		linux_extra = gd->ram_size; +  	/* we assume that the kernel is in place */  	printf("\nStarting kernel ...\n\n"); -	theKernel(linux_argc, linux_argv, linux_env, 0); +	kernel(linux_argc, (ulong)linux_argv, (ulong)linux_env, linux_extra);  }  int do_bootm_linux(int flag, int argc, char * const argv[],  			bootm_headers_t *images)  {  	/* No need for those on MIPS */ -	if (flag & BOOTM_STATE_OS_BD_T || flag & BOOTM_STATE_OS_CMDLINE) +	if (flag & BOOTM_STATE_OS_BD_T)  		return -1; +	if (flag & BOOTM_STATE_OS_CMDLINE) { +		boot_cmdline_linux(images); +		return 0; +	} +  	if (flag & BOOTM_STATE_OS_PREP) {  		boot_prep_linux(images);  		return 0; @@ -102,76 +241,10 @@ int do_bootm_linux(int flag, int argc, char * const argv[],  		return 0;  	} +	boot_cmdline_linux(images);  	boot_prep_linux(images);  	boot_jump_linux(images);  	/* does not return */  	return 1;  } - -static void linux_params_init(ulong start, char *line) -{ -	char *next, *quote, *argp; - -	linux_argc = 1; -	linux_argv = (char **) start; -	linux_argv[0] = 0; -	argp = (char *) (linux_argv + LINUX_MAX_ARGS); - -	next = line; - -	while (line && *line && linux_argc < LINUX_MAX_ARGS) { -		quote = strchr(line, '"'); -		next = strchr(line, ' '); - -		while (next && quote && quote < next) { -			/* we found a left quote before the next blank -			 * now we have to find the matching right quote -			 */ -			next = strchr(quote + 1, '"'); -			if (next) { -				quote = strchr(next + 1, '"'); -				next = strchr(next + 1, ' '); -			} -		} - -		if (!next) -			next = line + strlen(line); - -		linux_argv[linux_argc] = argp; -		memcpy(argp, line, next - line); -		argp[next - line] = 0; - -		argp += next - line + 1; -		linux_argc++; - -		if (*next) -			next++; - -		line = next; -	} - -	linux_env = (char **) (((ulong) argp + 15) & ~15); -	linux_env[0] = 0; -	linux_env_p = (char *) (linux_env + LINUX_MAX_ENVS); -	linux_env_idx = 0; -} - -static void linux_env_set(char *env_name, char *env_val) -{ -	if (linux_env_idx < LINUX_MAX_ENVS - 1) { -		linux_env[linux_env_idx] = linux_env_p; - -		strcpy(linux_env_p, env_name); -		linux_env_p += strlen(env_name); - -		strcpy(linux_env_p, "="); -		linux_env_p += 1; - -		strcpy(linux_env_p, env_val); -		linux_env_p += strlen(env_val); - -		linux_env_p++; -		linux_env[++linux_env_idx] = 0; -	} -} diff --git a/arch/mips/lib/bootm_qemu_mips.c b/arch/mips/lib/bootm_qemu_mips.c deleted file mode 100644 index 910ab7363..000000000 --- a/arch/mips/lib/bootm_qemu_mips.c +++ /dev/null @@ -1,62 +0,0 @@ -/* - * (C) Copyright 2008 - * Jean-Christophe PLAGNIOL-VILLARD <jcplagniol@jcrosoft.com> - * - * SPDX-License-Identifier:	GPL-2.0+ - */ - -#include <common.h> -#include <command.h> -#include <image.h> -#include <asm/byteorder.h> -#include <asm/addrspace.h> - -DECLARE_GLOBAL_DATA_PTR; - -int do_bootm_linux(int flag, int argc, char * const argv[], -			bootm_headers_t *images) -{ -	void (*theKernel) (int, char **, char **, int *); -	char *bootargs = getenv("bootargs"); -	char *start; -	uint len; - -	/* find kernel entry point */ -	theKernel = (void (*)(int, char **, char **, int *))images->ep; - -	bootstage_mark(BOOTSTAGE_ID_RUN_OS); - -	debug("## Transferring control to Linux (at address %08lx) ...\n", -		(ulong) theKernel); - -	gd->bd->bi_boot_params = gd->bd->bi_memstart + (16 << 20) - 256; -	debug("%-12s= 0x%08lX\n", "boot_params", (ulong)gd->bd->bi_boot_params); - -	/* set Magic */ -	*(int32_t *)(gd->bd->bi_boot_params - 4) = 0x12345678; -	/* set ram_size */ -	*(int32_t *)(gd->bd->bi_boot_params - 8) = gd->ram_size; - -	start = (char *)gd->bd->bi_boot_params; - -	len = strlen(bootargs); - -	strncpy(start, bootargs, len + 1); - -	start += len; - -	len = images->rd_end - images->rd_start; -	if (len > 0) { -		start += sprintf(start, " rd_start=0x%08X rd_size=0x%0X", -		(uint) UNCACHED_SDRAM(images->rd_start), -		(uint) len); -	} - -	/* we assume that the kernel is in place */ -	printf("\nStarting kernel ...\n\n"); - -	theKernel(0, NULL, NULL, 0); - -	/* does not return */ -	return 1; -} diff --git a/arch/powerpc/cpu/mpc824x/cpu.c b/arch/powerpc/cpu/mpc824x/cpu.c index ee69e495b..eaa4e8707 100644 --- a/arch/powerpc/cpu/mpc824x/cpu.c +++ b/arch/powerpc/cpu/mpc824x/cpu.c @@ -45,12 +45,10 @@ int checkcpu (void)  		return -1;		/* no valid CPU revision info */  	} -	printf (" at %s MHz:", strmhz (buf, clock)); +	printf(" at %s MHz: ", strmhz(buf, clock)); -	printf (" %u kB I-Cache", checkicache () >> 10); -	printf (" %u kB D-Cache", checkdcache () >> 10); - -	puts ("\n"); +	print_size(checkicache(), " I-Cache "); +	print_size(checkdcache(), " D-Cache\n");  	return 0;  } diff --git a/arch/powerpc/cpu/mpc83xx/pcie.c b/arch/powerpc/cpu/mpc83xx/pcie.c index 09970b058..28c25e5fe 100644 --- a/arch/powerpc/cpu/mpc83xx/pcie.c +++ b/arch/powerpc/cpu/mpc83xx/pcie.c @@ -299,6 +299,8 @@ static void mpc83xx_pcie_init_bus(int bus, struct pci_region *reg)  	printf("PCIE%d: ", bus); +#define PCI_LTSSM	0x404 /* PCIe Link Training, Status State Machine */ +#define PCI_LTSSM_L0	0x16 /* L0 state */  	reg16 = in_le16(hose_cfg_base + PCI_LTSSM);  	if (reg16 >= PCI_LTSSM_L0)  		printf("link\n"); diff --git a/arch/powerpc/cpu/mpc85xx/Makefile b/arch/powerpc/cpu/mpc85xx/Makefile index 0d1e8f1f0..f70f0d747 100644 --- a/arch/powerpc/cpu/mpc85xx/Makefile +++ b/arch/powerpc/cpu/mpc85xx/Makefile @@ -46,6 +46,7 @@ COBJS-$(CONFIG_MPC8568) += ddr-gen2.o  COBJS-$(CONFIG_MPC8544) += ddr-gen2.o  # supports ddr1/2/3 +COBJS-$(CONFIG_PPC_C29X)	+= ddr-gen3.o  COBJS-$(CONFIG_MPC8572) += ddr-gen3.o  COBJS-$(CONFIG_MPC8536) += ddr-gen3.o  COBJS-$(CONFIG_MPC8569)	+= ddr-gen3.o @@ -100,6 +101,7 @@ COBJS-$(CONFIG_SYS_FSL_QORIQ_CHASSIS1) += fsl_corenet_serdes.o  COBJS-$(CONFIG_SYS_FSL_QORIQ_CHASSIS2) += fsl_corenet2_serdes.o  # SoC specific SERDES support +COBJS-$(CONFIG_PPC_C29X)	+= c29x_serdes.o  COBJS-$(CONFIG_MPC8536) += mpc8536_serdes.o  COBJS-$(CONFIG_MPC8544) += mpc8544_serdes.o  COBJS-$(CONFIG_MPC8548) += mpc8548_serdes.o diff --git a/arch/powerpc/cpu/mpc85xx/b4860_ids.c b/arch/powerpc/cpu/mpc85xx/b4860_ids.c index 53c6a7faf..39b8e3ecc 100644 --- a/arch/powerpc/cpu/mpc85xx/b4860_ids.c +++ b/arch/powerpc/cpu/mpc85xx/b4860_ids.c @@ -41,8 +41,8 @@ struct qportal_info qp_info[CONFIG_SYS_QMAN_NUM_PORTALS] = {  #ifdef CONFIG_SYS_SRIO  struct srio_liodn_id_table srio_liodn_tbl[] = { -	SET_SRIO_LIODN_1(1, 307), -	SET_SRIO_LIODN_1(2, 387), +	SET_SRIO_LIODN_BASE(1, 307), +	SET_SRIO_LIODN_BASE(2, 387),  };  int srio_liodn_tbl_sz = ARRAY_SIZE(srio_liodn_tbl);  #endif @@ -112,10 +112,10 @@ int sec_liodn_tbl_sz = ARRAY_SIZE(sec_liodn_tbl);  #ifdef CONFIG_SYS_DPAA_RMAN  struct liodn_id_table rman_liodn_tbl[] = {  	/* Set RMan block 0-3 liodn offset */ -	SET_RMAN_LIODN(0, 678), -	SET_RMAN_LIODN(1, 679), -	SET_RMAN_LIODN(2, 680), -	SET_RMAN_LIODN(3, 681), +	SET_RMAN_LIODN(0, 6), +	SET_RMAN_LIODN(1, 7), +	SET_RMAN_LIODN(2, 8), +	SET_RMAN_LIODN(3, 9),  };  int rman_liodn_tbl_sz = ARRAY_SIZE(rman_liodn_tbl);  #endif diff --git a/arch/powerpc/cpu/mpc85xx/c29x_serdes.c b/arch/powerpc/cpu/mpc85xx/c29x_serdes.c new file mode 100644 index 000000000..51972cb7c --- /dev/null +++ b/arch/powerpc/cpu/mpc85xx/c29x_serdes.c @@ -0,0 +1,62 @@ +/* + * Copyright 2013 Freescale Semiconductor, Inc. + * + * SPDX-License-Identifier:	GPL-2.0+ + */ + +#include <config.h> +#include <common.h> +#include <asm/io.h> +#include <asm/immap_85xx.h> +#include <asm/fsl_serdes.h> + +#define SRDS1_MAX_LANES		4 + +static u32 serdes1_prtcl_map; + +struct serdes_config { +	u32 protocol; +	u8 lanes[SRDS1_MAX_LANES]; +}; + +static const struct serdes_config serdes1_cfg_tbl[] = { +	/* SerDes 1 */ +	{1, {PCIE1, PCIE1, PCIE1, PCIE1} }, +	{2, {PCIE1, PCIE1, PCIE1, PCIE1} }, +	{3, {PCIE1, PCIE1, NONE, NONE} }, +	{4, {PCIE1, PCIE1, NONE, NONE} }, +	{5, {PCIE1, NONE, NONE, NONE} }, +	{6, {PCIE1, NONE, NONE, NONE} }, +	{} +}; + +int is_serdes_configured(enum srds_prtcl device) +{ +	return (1 << device) & serdes1_prtcl_map; +} + +void fsl_serdes_init(void) +{ +	ccsr_gur_t *gur = (void *)CONFIG_SYS_MPC85xx_GUTS_ADDR; +	u32 pordevsr = in_be32(&gur->pordevsr); +	u32 srds_cfg = (pordevsr & MPC85xx_PORDEVSR_IO_SEL) >> +				MPC85xx_PORDEVSR_IO_SEL_SHIFT; +	const struct serdes_config *ptr; +	int lane; + +	debug("PORDEVSR[IO_SEL_SRDS] = %x\n", srds_cfg); + +	if (srds_cfg > ARRAY_SIZE(serdes1_cfg_tbl)) { +		printf("Invalid PORDEVSR[IO_SEL_SRDS] = %d\n", srds_cfg); +		return; +	} + +	ptr = &serdes1_cfg_tbl[srds_cfg]; +	if (!ptr->protocol) +		return; + +	for (lane = 0; lane < SRDS1_MAX_LANES; lane++) { +		enum srds_prtcl lane_prtcl = ptr->lanes[lane]; +		serdes1_prtcl_map |= (1 << lane_prtcl); +	} +} diff --git a/arch/powerpc/cpu/mpc85xx/cmd_errata.c b/arch/powerpc/cpu/mpc85xx/cmd_errata.c index 5cd02ccde..eea264b15 100644 --- a/arch/powerpc/cpu/mpc85xx/cmd_errata.c +++ b/arch/powerpc/cpu/mpc85xx/cmd_errata.c @@ -245,6 +245,18 @@ static int do_errata(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])  #ifdef CONFIG_SYS_FSL_ERRATUM_A006593  	puts("Work-around for Erratum A006593 enabled\n");  #endif +#ifdef CONFIG_SYS_FSL_ERRATUM_SEC_A003571 +	if (IS_SVR_REV(svr, 1, 0)) +		puts("Work-around for Erratum A003571 enabled\n"); +#endif +#ifdef CONFIG_SYS_FSL_ERRATUM_A005812 +	puts("Work-around for Erratum A-005812 enabled\n"); +#endif +#ifdef CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +	if ((SVR_SOC_VER(svr) == SVR_8548 && IS_SVR_REV(svr, 3, 1)) || +	    (SVR_REV(svr) <= CONFIG_SYS_FSL_A004447_SVR_REV)) +		puts("Work-around for Erratum I2C-A004447 enabled\n"); +#endif  	return 0;  } diff --git a/arch/powerpc/cpu/mpc85xx/cpu.c b/arch/powerpc/cpu/mpc85xx/cpu.c index 91ac4ee61..1a0196c7c 100644 --- a/arch/powerpc/cpu/mpc85xx/cpu.c +++ b/arch/powerpc/cpu/mpc85xx/cpu.c @@ -44,10 +44,10 @@ int checkcpu (void)  	uint major, minor;  	struct cpu_type *cpu;  	char buf1[32], buf2[32]; -#if (defined(CONFIG_DDR_CLK_FREQ) || \ -	defined(CONFIG_FSL_CORENET)) && !defined(CONFIG_SYS_FSL_QORIQ_CHASSIS2) -	volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); -#endif /* CONFIG_FSL_CORENET */ +#if defined(CONFIG_DDR_CLK_FREQ) || defined(CONFIG_FSL_CORENET) +	ccsr_gur_t __iomem *gur = +		(void __iomem *)(CONFIG_SYS_MPC85xx_GUTS_ADDR); +#endif  	/*  	 * Cornet platforms use ddr sync bit in RCW to indicate sync vs async @@ -135,81 +135,97 @@ int checkcpu (void)  		if (!(i & 3))  			printf ("\n       ");  		printf("CPU%d:%-4s MHz, ", core, -			strmhz(buf1, sysinfo.freqProcessor[core])); +			strmhz(buf1, sysinfo.freq_processor[core]));  	} -	printf("\n       CCB:%-4s MHz,\n", strmhz(buf1, sysinfo.freqSystemBus)); +	printf("\n       CCB:%-4s MHz,", strmhz(buf1, sysinfo.freq_systembus)); +	printf("\n");  #ifdef CONFIG_FSL_CORENET  	if (ddr_sync == 1) {  		printf("       DDR:%-4s MHz (%s MT/s data rate) "  			"(Synchronous), ", -			strmhz(buf1, sysinfo.freqDDRBus/2), -			strmhz(buf2, sysinfo.freqDDRBus)); +			strmhz(buf1, sysinfo.freq_ddrbus/2), +			strmhz(buf2, sysinfo.freq_ddrbus));  	} else {  		printf("       DDR:%-4s MHz (%s MT/s data rate) "  			"(Asynchronous), ", -			strmhz(buf1, sysinfo.freqDDRBus/2), -			strmhz(buf2, sysinfo.freqDDRBus)); +			strmhz(buf1, sysinfo.freq_ddrbus/2), +			strmhz(buf2, sysinfo.freq_ddrbus));  	}  #else  	switch (ddr_ratio) {  	case 0x0:  		printf("       DDR:%-4s MHz (%s MT/s data rate), ", -			strmhz(buf1, sysinfo.freqDDRBus/2), -			strmhz(buf2, sysinfo.freqDDRBus)); +			strmhz(buf1, sysinfo.freq_ddrbus/2), +			strmhz(buf2, sysinfo.freq_ddrbus));  		break;  	case 0x7:  		printf("       DDR:%-4s MHz (%s MT/s data rate) "  			"(Synchronous), ", -			strmhz(buf1, sysinfo.freqDDRBus/2), -			strmhz(buf2, sysinfo.freqDDRBus)); +			strmhz(buf1, sysinfo.freq_ddrbus/2), +			strmhz(buf2, sysinfo.freq_ddrbus));  		break;  	default:  		printf("       DDR:%-4s MHz (%s MT/s data rate) "  			"(Asynchronous), ", -			strmhz(buf1, sysinfo.freqDDRBus/2), -			strmhz(buf2, sysinfo.freqDDRBus)); +			strmhz(buf1, sysinfo.freq_ddrbus/2), +			strmhz(buf2, sysinfo.freq_ddrbus));  		break;  	}  #endif  #if defined(CONFIG_FSL_LBC) -	if (sysinfo.freqLocalBus > LCRR_CLKDIV) { -		printf("LBC:%-4s MHz\n", strmhz(buf1, sysinfo.freqLocalBus)); +	if (sysinfo.freq_localbus > LCRR_CLKDIV) { +		printf("LBC:%-4s MHz\n", strmhz(buf1, sysinfo.freq_localbus));  	} else {  		printf("LBC: unknown (LCRR[CLKDIV] = 0x%02lx)\n", -		       sysinfo.freqLocalBus); +		       sysinfo.freq_localbus);  	}  #endif  #if defined(CONFIG_FSL_IFC) -	printf("IFC:%-4s MHz\n", strmhz(buf1, sysinfo.freqLocalBus)); +	printf("IFC:%-4s MHz\n", strmhz(buf1, sysinfo.freq_localbus));  #endif  #ifdef CONFIG_CPM2 -	printf("CPM:   %s MHz\n", strmhz(buf1, sysinfo.freqSystemBus)); +	printf("CPM:   %s MHz\n", strmhz(buf1, sysinfo.freq_systembus));  #endif  #ifdef CONFIG_QE -	printf("       QE:%-4s MHz\n", strmhz(buf1, sysinfo.freqQE)); +	printf("       QE:%-4s MHz\n", strmhz(buf1, sysinfo.freq_qe));  #endif  #ifdef CONFIG_SYS_DPAA_FMAN  	for (i = 0; i < CONFIG_SYS_NUM_FMAN; i++) {  		printf("       FMAN%d: %s MHz\n", i + 1, -			strmhz(buf1, sysinfo.freqFMan[i])); +			strmhz(buf1, sysinfo.freq_fman[i]));  	}  #endif  #ifdef CONFIG_SYS_DPAA_QBMAN -	printf("       QMAN:  %s MHz\n", strmhz(buf1, sysinfo.freqQMAN)); +	printf("       QMAN:  %s MHz\n", strmhz(buf1, sysinfo.freq_qman));  #endif  #ifdef CONFIG_SYS_DPAA_PME -	printf("       PME:   %s MHz\n", strmhz(buf1, sysinfo.freqPME)); +	printf("       PME:   %s MHz\n", strmhz(buf1, sysinfo.freq_pme));  #endif -	puts("L1:    D-cache 32 kB enabled\n       I-cache 32 kB enabled\n"); +	puts("L1:    D-cache 32 KiB enabled\n       I-cache 32 KiB enabled\n"); + +#ifdef CONFIG_FSL_CORENET +	/* Display the RCW, so that no one gets confused as to what RCW +	 * we're actually using for this boot. +	 */ +	puts("Reset Configuration Word (RCW):"); +	for (i = 0; i < ARRAY_SIZE(gur->rcwsr); i++) { +		u32 rcw = in_be32(&gur->rcwsr[i]); + +		if ((i % 4) == 0) +			printf("\n       %08x:", i * 4); +		printf(" %08x", rcw); +	} +	puts("\n"); +#endif  	return 0;  } diff --git a/arch/powerpc/cpu/mpc85xx/cpu_init.c b/arch/powerpc/cpu/mpc85xx/cpu_init.c index 25beda233..6036333ea 100644 --- a/arch/powerpc/cpu/mpc85xx/cpu_init.c +++ b/arch/powerpc/cpu/mpc85xx/cpu_init.c @@ -22,6 +22,7 @@  #include <asm/fsl_law.h>  #include <asm/fsl_serdes.h>  #include <asm/fsl_srio.h> +#include <fsl_usb.h>  #include <hwconfig.h>  #include <linux/compiler.h>  #include "mp.h" @@ -166,7 +167,8 @@ static void enable_cpc(void)  	} -	printf("Corenet Platform Cache: %d KB enabled\n", size); +	puts("Corenet Platform Cache: "); +	print_size(size * 1024, " enabled\n");  }  static void invalidate_cpc(void) @@ -355,7 +357,9 @@ int cpu_init_r(void)  	extern int spin_table_compat;  	const char *spin;  #endif - +#ifdef CONFIG_SYS_FSL_ERRATUM_SEC_A003571 +	ccsr_sec_t __iomem *sec = (void *)CONFIG_SYS_FSL_SEC_ADDR; +#endif  #if defined(CONFIG_SYS_P4080_ERRATUM_CPU22) || \  	defined(CONFIG_SYS_FSL_ERRATUM_NMG_CPU_A011)  	/* @@ -399,6 +403,14 @@ int cpu_init_r(void)  		sync();  	}  #endif +#ifdef CONFIG_SYS_FSL_ERRATUM_A005812 +	/* +	 * A-005812 workaround sets bit 32 of SPR 976 for SoCs running +	 * in write shadow mode. Checking DCWS before setting SPR 976. +	 */ +	if (mfspr(L1CSR2) & L1CSR2_DCWS) +		mtspr(SPRN_HDBCR0, (mfspr(SPRN_HDBCR0) | 0x80000000)); +#endif  #if defined(CONFIG_PPC_SPINTABLE_COMPATIBLE) && defined(CONFIG_MP)  	spin = getenv("spin_table_compat"); @@ -448,28 +460,28 @@ int cpu_init_r(void)  	case 0x1:  		if (ver == SVR_8540 || ver == SVR_8560   ||  		    ver == SVR_8541 || ver == SVR_8555) { -			puts("128 KB "); -			/* set L2E=1, L2I=1, & L2BLKSZ=1 (128 Kbyte) */ +			puts("128 KiB "); +			/* set L2E=1, L2I=1, & L2BLKSZ=1 (128 KiBibyte) */  			cache_ctl = 0xc4000000;  		} else { -			puts("256 KB "); +			puts("256 KiB ");  			cache_ctl = 0xc0000000; /* set L2E=1, L2I=1, & L2SRAM=0 */  		}  		break;  	case 0x2:  		if (ver == SVR_8540 || ver == SVR_8560   ||  		    ver == SVR_8541 || ver == SVR_8555) { -			puts("256 KB "); -			/* set L2E=1, L2I=1, & L2BLKSZ=2 (256 Kbyte) */ +			puts("256 KiB "); +			/* set L2E=1, L2I=1, & L2BLKSZ=2 (256 KiBibyte) */  			cache_ctl = 0xc8000000;  		} else { -			puts ("512 KB "); +			puts("512 KiB ");  			/* set L2E=1, L2I=1, & L2SRAM=0 */  			cache_ctl = 0xc0000000;  		}  		break;  	case 0x3: -		puts("1024 KB "); +		puts("1024 KiB ");  		/* set L2E=1, L2I=1, & L2SRAM=0 */  		cache_ctl = 0xc0000000;  		break; @@ -517,13 +529,14 @@ int cpu_init_r(void)  	if (CONFIG_SYS_INIT_L2CSR0 & L2CSR0_L2E) {  		while (!(mfspr(SPRN_L2CSR0) & L2CSR0_L2E))  			; -		printf("%d KB enabled\n", (l2cfg0 & 0x3fff) * 64); +		print_size((l2cfg0 & 0x3fff) * 64 * 1024, " enabled\n");  	}  skip_l2:  #elif defined(CONFIG_SYS_FSL_QORIQ_CHASSIS2)  	if (l2cache->l2csr0 & L2CSR0_L2E) -		printf("%d KB enabled\n", (l2cache->l2cfg0 & 0x3fff) * 64); +		print_size((l2cache->l2cfg0 & 0x3fff) * 64 * 1024, +			   " enabled\n");  	enable_cluster_l2();  #else @@ -532,8 +545,16 @@ skip_l2:  	enable_cpc(); +#ifndef CONFIG_SYS_FSL_NO_SERDES  	/* needs to be in ram since code uses global static vars */  	fsl_serdes_init(); +#endif + +#ifdef CONFIG_SYS_FSL_ERRATUM_SEC_A003571 +#define MCFGR_AXIPIPE 0x000000f0 +	if (IS_SVR_REV(svr, 1, 0)) +		clrbits_be32(&sec->mcfgr, MCFGR_AXIPIPE); +#endif  #ifdef CONFIG_SYS_FSL_ERRATUM_A005871  	if (IS_SVR_REV(svr, 1, 0)) { @@ -595,7 +616,7 @@ skip_l2:  #ifdef CONFIG_SYS_FSL_USB1_PHY_ENABLE  	{ -		ccsr_usb_phy_t *usb_phy1 = +		struct ccsr_usb_phy __iomem *usb_phy1 =  			(void *)CONFIG_SYS_MPC85xx_USB1_PHY_ADDR;  		out_be32(&usb_phy1->usb_enable_override,  				CONFIG_SYS_FSL_USB_ENABLE_OVERRIDE); @@ -603,7 +624,7 @@ skip_l2:  #endif  #ifdef CONFIG_SYS_FSL_USB2_PHY_ENABLE  	{ -		ccsr_usb_phy_t *usb_phy2 = +		struct ccsr_usb_phy __iomem *usb_phy2 =  			(void *)CONFIG_SYS_MPC85xx_USB2_PHY_ADDR;  		out_be32(&usb_phy2->usb_enable_override,  				CONFIG_SYS_FSL_USB_ENABLE_OVERRIDE); @@ -625,7 +646,7 @@ skip_l2:  #endif  #if defined(CONFIG_SYS_FSL_USB_DUAL_PHY_ENABLE) -		ccsr_usb_phy_t *usb_phy = +		struct ccsr_usb_phy __iomem *usb_phy =  			(void *)CONFIG_SYS_MPC85xx_USB1_PHY_ADDR;  		setbits_be32(&usb_phy->pllprg[1],  			     CONFIG_SYS_FSL_USB_PLLPRG2_PHY2_CLK_EN | diff --git a/arch/powerpc/cpu/mpc85xx/ddr-gen1.c b/arch/powerpc/cpu/mpc85xx/ddr-gen1.c index 8a86819fb..4dd8c0b5b 100644 --- a/arch/powerpc/cpu/mpc85xx/ddr-gen1.c +++ b/arch/powerpc/cpu/mpc85xx/ddr-gen1.c @@ -15,7 +15,7 @@  #endif  void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -			     unsigned int ctrl_num) +			     unsigned int ctrl_num, int step)  {  	unsigned int i;  	volatile ccsr_ddr_t *ddr = (void *)CONFIG_SYS_MPC8xxx_DDR_ADDR; diff --git a/arch/powerpc/cpu/mpc85xx/ddr-gen2.c b/arch/powerpc/cpu/mpc85xx/ddr-gen2.c index a70586252..542bc84ac 100644 --- a/arch/powerpc/cpu/mpc85xx/ddr-gen2.c +++ b/arch/powerpc/cpu/mpc85xx/ddr-gen2.c @@ -16,7 +16,7 @@  #endif  void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -			     unsigned int ctrl_num) +			     unsigned int ctrl_num, int step)  {  	unsigned int i;  	ccsr_ddr_t *ddr = (void *)CONFIG_SYS_MPC8xxx_DDR_ADDR; diff --git a/arch/powerpc/cpu/mpc85xx/ddr-gen3.c b/arch/powerpc/cpu/mpc85xx/ddr-gen3.c index c5b47200e..1be51d330 100644 --- a/arch/powerpc/cpu/mpc85xx/ddr-gen3.c +++ b/arch/powerpc/cpu/mpc85xx/ddr-gen3.c @@ -15,8 +15,18 @@  #error Invalid setting for CONFIG_CHIP_SELECTS_PER_CTRL  #endif + +/* + * regs has the to-be-set values for DDR controller registers + * ctrl_num is the DDR controller number + * step: 0 goes through the initialization in one pass + *       1 sets registers and returns before enabling controller + *       2 resumes from step 1 and continues to initialize + * Dividing the initialization to two steps to deassert DDR reset signal + * to comply with JEDEC specs for RDIMMs. + */  void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -			     unsigned int ctrl_num) +			     unsigned int ctrl_num, int step)  {  	unsigned int i, bus_width;  	volatile ccsr_ddr_t *ddr; @@ -54,6 +64,9 @@ void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs,  		return;  	} +	if (step == 2) +		goto step2; +  	if (regs->ddr_eor)  		out_be32(&ddr->eor, regs->ddr_eor);  #ifdef CONFIG_SYS_FSL_ERRATUM_DDR111_DDR134 @@ -123,10 +136,17 @@ void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs,  	out_be32(&ddr->timing_cfg_5, regs->timing_cfg_5);  	out_be32(&ddr->ddr_zq_cntl, regs->ddr_zq_cntl);  	out_be32(&ddr->ddr_wrlvl_cntl, regs->ddr_wrlvl_cntl); +#ifndef CONFIG_SYS_FSL_DDR_EMU +	/* +	 * Skip these two registers if running on emulator +	 * because emulator doesn't have skew between bytes. +	 */ +  	if (regs->ddr_wrlvl_cntl_2)  		out_be32(&ddr->ddr_wrlvl_cntl_2, regs->ddr_wrlvl_cntl_2);  	if (regs->ddr_wrlvl_cntl_3)  		out_be32(&ddr->ddr_wrlvl_cntl_3, regs->ddr_wrlvl_cntl_3); +#endif  	out_be32(&ddr->ddr_sr_cntr, regs->ddr_sr_cntr);  	out_be32(&ddr->ddr_sdram_rcw_1, regs->ddr_sdram_rcw_1); @@ -150,6 +170,20 @@ void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs,  	out_be32(&ddr->debug[21], 0x24000000);  #endif /* CONFIG_SYS_FSL_ERRATUM_DDR_A003474 */ +	/* +	 * For RDIMMs, JEDEC spec requires clocks to be stable before reset is +	 * deasserted. Clocks start when any chip select is enabled and clock +	 * control register is set. Because all DDR components are connected to +	 * one reset signal, this needs to be done in two steps. Step 1 is to +	 * get the clocks started. Step 2 resumes after reset signal is +	 * deasserted. +	 */ +	if (step == 1) { +		udelay(200); +		return; +	} + +step2:  	/* Set, but do not enable the memory */  	temp_sdram_cfg = regs->ddr_sdram_cfg;  	temp_sdram_cfg &= ~(SDRAM_CFG_MEM_EN); diff --git a/arch/powerpc/cpu/mpc85xx/fdt.c b/arch/powerpc/cpu/mpc85xx/fdt.c index cfaa2edce..533d47ab4 100644 --- a/arch/powerpc/cpu/mpc85xx/fdt.c +++ b/arch/powerpc/cpu/mpc85xx/fdt.c @@ -403,22 +403,22 @@ static void ft_fixup_dpaa_clks(void *blob)  	get_sys_info(&sysinfo);  #ifdef CONFIG_SYS_DPAA_FMAN  	ft_fixup_clks(blob, "fsl,fman", CONFIG_SYS_FSL_FM1_OFFSET, -			sysinfo.freqFMan[0]); +			sysinfo.freq_fman[0]);  #if (CONFIG_SYS_NUM_FMAN == 2)  	ft_fixup_clks(blob, "fsl,fman", CONFIG_SYS_FSL_FM2_OFFSET, -			sysinfo.freqFMan[1]); +			sysinfo.freq_fman[1]);  #endif  #endif  #ifdef CONFIG_SYS_DPAA_QBMAN  	do_fixup_by_compat_u32(blob, "fsl,qman", -			"clock-frequency", sysinfo.freqQMAN, 1); +			"clock-frequency", sysinfo.freq_qman, 1);  #endif  #ifdef CONFIG_SYS_DPAA_PME  	do_fixup_by_compat_u32(blob, "fsl,pme", -		"clock-frequency", sysinfo.freqPME, 1); +		"clock-frequency", sysinfo.freq_pme, 1);  #endif  }  #else @@ -476,7 +476,7 @@ void fdt_fixup_fman_firmware(void *blob)  	if (!p)  		return; -	fmanfw = (struct qe_firmware *) simple_strtoul(p, NULL, 0); +	fmanfw = (struct qe_firmware *) simple_strtoul(p, NULL, 16);  	if (!fmanfw)  		return; @@ -604,15 +604,19 @@ void ft_cpu_setup(void *blob, bd_t *bd)  	fdt_add_enet_stashing(blob); +#ifndef CONFIG_FSL_TBCLK_EXTRA_DIV +#define CONFIG_FSL_TBCLK_EXTRA_DIV 1 +#endif  	do_fixup_by_prop_u32(blob, "device_type", "cpu", 4, -		"timebase-frequency", get_tbclk(), 1); +		"timebase-frequency", get_tbclk() / CONFIG_FSL_TBCLK_EXTRA_DIV, +		1);  	do_fixup_by_prop_u32(blob, "device_type", "cpu", 4,  		"bus-frequency", bd->bi_busfreq, 1);  	get_sys_info(&sysinfo);  	off = fdt_node_offset_by_prop_value(blob, -1, "device_type", "cpu", 4);  	while (off != -FDT_ERR_NOTFOUND) {  		u32 *reg = (u32 *)fdt_getprop(blob, off, "reg", 0); -		val = cpu_to_fdt32(sysinfo.freqProcessor[*reg]); +		val = cpu_to_fdt32(sysinfo.freq_processor[*reg]);  		fdt_setprop(blob, off, "clock-frequency", &val, 4);  		off = fdt_node_offset_by_prop_value(blob, off, "device_type",  							"cpu", 4); diff --git a/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.c b/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.c index de6bd11a1..39d9409d6 100644 --- a/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.c +++ b/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.c @@ -13,8 +13,12 @@  #include <asm/errno.h>  #include "fsl_corenet2_serdes.h" +#ifdef CONFIG_SYS_FSL_SRDS_1  static u64 serdes1_prtcl_map; +#endif +#ifdef CONFIG_SYS_FSL_SRDS_2  static u64 serdes2_prtcl_map; +#endif  #ifdef CONFIG_SYS_FSL_SRDS_3  static u64 serdes3_prtcl_map;  #endif @@ -78,8 +82,12 @@ int is_serdes_configured(enum srds_prtcl device)  {  	u64 ret = 0; +#ifdef CONFIG_SYS_FSL_SRDS_1  	ret |= (1ULL << device) & serdes1_prtcl_map; +#endif +#ifdef CONFIG_SYS_FSL_SRDS_2  	ret |= (1ULL << device) & serdes2_prtcl_map; +#endif  #ifdef CONFIG_SYS_FSL_SRDS_3  	ret |= (1ULL << device) & serdes3_prtcl_map;  #endif @@ -97,14 +105,18 @@ int serdes_get_first_lane(u32 sd, enum srds_prtcl device)  	int i;  	switch (sd) { +#ifdef CONFIG_SYS_FSL_SRDS_1  	case FSL_SRDS_1:  		cfg &= FSL_CORENET2_RCWSR4_SRDS1_PRTCL;  		cfg >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;  		break; +#endif +#ifdef CONFIG_SYS_FSL_SRDS_2  	case FSL_SRDS_2:  		cfg &= FSL_CORENET2_RCWSR4_SRDS2_PRTCL;  		cfg >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT;  		break; +#endif  #ifdef CONFIG_SYS_FSL_SRDS_3  	case FSL_SRDS_3:  		cfg &= FSL_CORENET2_RCWSR4_SRDS3_PRTCL; @@ -163,14 +175,18 @@ u64 serdes_init(u32 sd, u32 sd_addr, u32 sd_prctl_mask, u32 sd_prctl_shift)  void fsl_serdes_init(void)  { +#ifdef CONFIG_SYS_FSL_SRDS_1  	serdes1_prtcl_map = serdes_init(FSL_SRDS_1,  		CONFIG_SYS_FSL_CORENET_SERDES_ADDR,  		FSL_CORENET2_RCWSR4_SRDS1_PRTCL,  		FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT); +#endif +#ifdef CONFIG_SYS_FSL_SRDS_2  	serdes2_prtcl_map = serdes_init(FSL_SRDS_2,  		CONFIG_SYS_FSL_CORENET_SERDES_ADDR + FSL_SRDS_2 * 0x1000,  		FSL_CORENET2_RCWSR4_SRDS2_PRTCL,  		FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT); +#endif  #ifdef CONFIG_SYS_FSL_SRDS_3  	serdes3_prtcl_map = serdes_init(FSL_SRDS_3,  		CONFIG_SYS_FSL_CORENET_SERDES_ADDR + FSL_SRDS_3 * 0x1000, diff --git a/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.h b/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.h index 6de572d59..d515b234a 100644 --- a/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.h +++ b/arch/powerpc/cpu/mpc85xx/fsl_corenet2_serdes.h @@ -9,5 +9,4 @@  int is_serdes_prtcl_valid(int serdes, u32 prtcl);  int serdes_lane_enabled(int lane); -enum srds_prtcl serdes_get_prtcl(int serdes, int cfg, int lane);  #endif /* __FSL_CORENET2_SERDES_H */ diff --git a/arch/powerpc/cpu/mpc85xx/release.S b/arch/powerpc/cpu/mpc85xx/release.S index 15bbbc15a..c15e83b52 100644 --- a/arch/powerpc/cpu/mpc85xx/release.S +++ b/arch/powerpc/cpu/mpc85xx/release.S @@ -226,6 +226,21 @@ __secondary_start_page:  2:  #endif +#ifdef CONFIG_SYS_FSL_ERRATUM_A005812 +	/* +	 * A-005812 workaround sets bit 32 of SPR 976 for SoCs running in +	 * write shadow mode. This code should run after other code setting +	 * DCWS. +	 */ +	mfspr	r3,L1CSR2 +	andis.	r3,r3,(L1CSR2_DCWS)@h +	beq	1f +	mfspr	r3, SPRN_HDBCR0 +	oris	r3, r3, 0x8000 +	mtspr	SPRN_HDBCR0, r3 +1: +#endif +  #ifdef CONFIG_BACKSIDE_L2_CACHE  	/* skip L2 setup on P2040/P2040E as they have no L2 */  	mfspr	r3,SPRN_SVR diff --git a/arch/powerpc/cpu/mpc85xx/speed.c b/arch/powerpc/cpu/mpc85xx/speed.c index f093960fe..07690f97b 100644 --- a/arch/powerpc/cpu/mpc85xx/speed.c +++ b/arch/powerpc/cpu/mpc85xx/speed.c @@ -20,7 +20,7 @@ DECLARE_GLOBAL_DATA_PTR;  /* --------------------------------------------------------------- */ -void get_sys_info (sys_info_t * sysInfo) +void get_sys_info(sys_info_t *sys_info)  {  	volatile ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);  #ifdef CONFIG_FSL_IFC @@ -46,7 +46,7 @@ void get_sys_info (sys_info_t * sysInfo)  		[14] = 3,	/* CC4 PPL / 4 */  	}; -	const u8 core_cplx_PLL_div[16] = { +	const u8 core_cplx_pll_div[16] = {  		[ 0] = 1,	/* CC1 PPL / 1 */  		[ 1] = 2,	/* CC1 PPL / 2 */  		[ 2] = 4,	/* CC1 PPL / 4 */ @@ -60,26 +60,26 @@ void get_sys_info (sys_info_t * sysInfo)  		[13] = 2,	/* CC4 PPL / 2 */  		[14] = 4,	/* CC4 PPL / 4 */  	}; -	uint i, freqCC_PLL[6], rcw_tmp; +	uint i, freq_cc_pll[6], rcw_tmp;  	uint ratio[6];  	unsigned long sysclk = CONFIG_SYS_CLK_FREQ;  	uint mem_pll_rat; -	sysInfo->freqSystemBus = sysclk; +	sys_info->freq_systembus = sysclk;  #ifdef CONFIG_DDR_CLK_FREQ -	sysInfo->freqDDRBus = CONFIG_DDR_CLK_FREQ; +	sys_info->freq_ddrbus = CONFIG_DDR_CLK_FREQ;  #else -	sysInfo->freqDDRBus = sysclk; +	sys_info->freq_ddrbus = sysclk;  #endif -	sysInfo->freqSystemBus *= (in_be32(&gur->rcwsr[0]) >> 25) & 0x1f; +	sys_info->freq_systembus *= (in_be32(&gur->rcwsr[0]) >> 25) & 0x1f;  	mem_pll_rat = (in_be32(&gur->rcwsr[0]) >>  			FSL_CORENET_RCWSR0_MEM_PLL_RAT_SHIFT)  			& FSL_CORENET_RCWSR0_MEM_PLL_RAT_MASK;  	if (mem_pll_rat > 2) -		sysInfo->freqDDRBus *= mem_pll_rat; +		sys_info->freq_ddrbus *= mem_pll_rat;  	else -		sysInfo->freqDDRBus = sysInfo->freqSystemBus * mem_pll_rat; +		sys_info->freq_ddrbus = sys_info->freq_systembus * mem_pll_rat;  	ratio[0] = (in_be32(&clk->pllc1gsr) >> 1) & 0x3f;  	ratio[1] = (in_be32(&clk->pllc2gsr) >> 1) & 0x3f; @@ -89,9 +89,9 @@ void get_sys_info (sys_info_t * sysInfo)  	ratio[5] = (in_be32(&clk->pllc6gsr) >> 1) & 0x3f;  	for (i = 0; i < 6; i++) {  		if (ratio[i] > 4) -			freqCC_PLL[i] = sysclk * ratio[i]; +			freq_cc_pll[i] = sysclk * ratio[i];  		else -			freqCC_PLL[i] = sysInfo->freqSystemBus * ratio[i]; +			freq_cc_pll[i] = sys_info->freq_systembus * ratio[i];  	}  #ifdef CONFIG_SYS_FSL_QORIQ_CHASSIS2  	/* @@ -110,8 +110,8 @@ void get_sys_info (sys_info_t * sysInfo)  			printf("Unsupported architecture configuration"  				" in function %s\n", __func__);  		cplx_pll += (cluster / 2) * 3; -		sysInfo->freqProcessor[cpu] = -			 freqCC_PLL[cplx_pll] / core_cplx_PLL_div[c_pll_sel]; +		sys_info->freq_processor[cpu] = +			 freq_cc_pll[cplx_pll] / core_cplx_pll_div[c_pll_sel];  	}  #ifdef CONFIG_PPC_B4860  #define FM1_CLK_SEL	0xe0000000 @@ -127,63 +127,63 @@ void get_sys_info (sys_info_t * sysInfo)  #ifdef CONFIG_SYS_DPAA_PME  	switch ((rcw_tmp & PME_CLK_SEL) >> PME_CLK_SHIFT) {  	case 1: -		sysInfo->freqPME = freqCC_PLL[0]; +		sys_info->freq_pme = freq_cc_pll[0];  		break;  	case 2: -		sysInfo->freqPME = freqCC_PLL[0] / 2; +		sys_info->freq_pme = freq_cc_pll[0] / 2;  		break;  	case 3: -		sysInfo->freqPME = freqCC_PLL[0] / 3; +		sys_info->freq_pme = freq_cc_pll[0] / 3;  		break;  	case 4: -		sysInfo->freqPME = freqCC_PLL[0] / 4; +		sys_info->freq_pme = freq_cc_pll[0] / 4;  		break;  	case 6: -		sysInfo->freqPME = freqCC_PLL[1] / 2; +		sys_info->freq_pme = freq_cc_pll[1] / 2;  		break;  	case 7: -		sysInfo->freqPME = freqCC_PLL[1] / 3; +		sys_info->freq_pme = freq_cc_pll[1] / 3;  		break;  	default:  		printf("Error: Unknown PME clock select!\n");  	case 0: -		sysInfo->freqPME = sysInfo->freqSystemBus / 2; +		sys_info->freq_pme = sys_info->freq_systembus / 2;  		break;  	}  #endif  #ifdef CONFIG_SYS_DPAA_QBMAN -	sysInfo->freqQMAN = sysInfo->freqSystemBus / 2; +	sys_info->freq_qman = sys_info->freq_systembus / 2;  #endif  #ifdef CONFIG_SYS_DPAA_FMAN  	switch ((rcw_tmp & FM1_CLK_SEL) >> FM1_CLK_SHIFT) {  	case 1: -		sysInfo->freqFMan[0] = freqCC_PLL[3]; +		sys_info->freq_fman[0] = freq_cc_pll[3];  		break;  	case 2: -		sysInfo->freqFMan[0] = freqCC_PLL[3] / 2; +		sys_info->freq_fman[0] = freq_cc_pll[3] / 2;  		break;  	case 3: -		sysInfo->freqFMan[0] = freqCC_PLL[3] / 3; +		sys_info->freq_fman[0] = freq_cc_pll[3] / 3;  		break;  	case 4: -		sysInfo->freqFMan[0] = freqCC_PLL[3] / 4; +		sys_info->freq_fman[0] = freq_cc_pll[3] / 4;  		break;  	case 5: -		sysInfo->freqFMan[0] = sysInfo->freqSystemBus; +		sys_info->freq_fman[0] = sys_info->freq_systembus;  		break;  	case 6: -		sysInfo->freqFMan[0] = freqCC_PLL[4] / 2; +		sys_info->freq_fman[0] = freq_cc_pll[4] / 2;  		break;  	case 7: -		sysInfo->freqFMan[0] = freqCC_PLL[4] / 3; +		sys_info->freq_fman[0] = freq_cc_pll[4] / 3;  		break;  	default:  		printf("Error: Unknown FMan1 clock select!\n");  	case 0: -		sysInfo->freqFMan[0] = sysInfo->freqSystemBus / 2; +		sys_info->freq_fman[0] = sys_info->freq_systembus / 2;  		break;  	}  #if (CONFIG_SYS_NUM_FMAN) == 2 @@ -192,27 +192,27 @@ void get_sys_info (sys_info_t * sysInfo)  	rcw_tmp = in_be32(&gur->rcwsr[15]);  	switch ((rcw_tmp & FM2_CLK_SEL) >> FM2_CLK_SHIFT) {  	case 1: -		sysInfo->freqFMan[1] = freqCC_PLL[4]; +		sys_info->freq_fman[1] = freq_cc_pll[4];  		break;  	case 2: -		sysInfo->freqFMan[1] = freqCC_PLL[4] / 2; +		sys_info->freq_fman[1] = freq_cc_pll[4] / 2;  		break;  	case 3: -		sysInfo->freqFMan[1] = freqCC_PLL[4] / 3; +		sys_info->freq_fman[1] = freq_cc_pll[4] / 3;  		break;  	case 4: -		sysInfo->freqFMan[1] = freqCC_PLL[4] / 4; +		sys_info->freq_fman[1] = freq_cc_pll[4] / 4;  		break;  	case 6: -		sysInfo->freqFMan[1] = freqCC_PLL[3] / 2; +		sys_info->freq_fman[1] = freq_cc_pll[3] / 2;  		break;  	case 7: -		sysInfo->freqFMan[1] = freqCC_PLL[3] / 3; +		sys_info->freq_fman[1] = freq_cc_pll[3] / 3;  		break;  	default:  		printf("Error: Unknown FMan2 clock select!\n");  	case 0: -		sysInfo->freqFMan[1] = sysInfo->freqSystemBus / 2; +		sys_info->freq_fman[1] = sys_info->freq_systembus / 2;  		break;  	}  #endif	/* CONFIG_SYS_NUM_FMAN == 2 */ @@ -225,8 +225,8 @@ void get_sys_info (sys_info_t * sysInfo)  				& 0xf;  		u32 cplx_pll = core_cplx_PLL[c_pll_sel]; -		sysInfo->freqProcessor[cpu] = -			 freqCC_PLL[cplx_pll] / core_cplx_PLL_div[c_pll_sel]; +		sys_info->freq_processor[cpu] = +			 freq_cc_pll[cplx_pll] / core_cplx_pll_div[c_pll_sel];  	}  #define PME_CLK_SEL	0x80000000  #define FM1_CLK_SEL	0x40000000 @@ -246,43 +246,43 @@ void get_sys_info (sys_info_t * sysInfo)  #ifdef CONFIG_SYS_DPAA_PME  	if (rcw_tmp & PME_CLK_SEL) {  		if (rcw_tmp & HWA_ASYNC_DIV) -			sysInfo->freqPME = freqCC_PLL[HWA_CC_PLL] / 4; +			sys_info->freq_pme = freq_cc_pll[HWA_CC_PLL] / 4;  		else -			sysInfo->freqPME = freqCC_PLL[HWA_CC_PLL] / 2; +			sys_info->freq_pme = freq_cc_pll[HWA_CC_PLL] / 2;  	} else { -		sysInfo->freqPME = sysInfo->freqSystemBus / 2; +		sys_info->freq_pme = sys_info->freq_systembus / 2;  	}  #endif  #ifdef CONFIG_SYS_DPAA_FMAN  	if (rcw_tmp & FM1_CLK_SEL) {  		if (rcw_tmp & HWA_ASYNC_DIV) -			sysInfo->freqFMan[0] = freqCC_PLL[HWA_CC_PLL] / 4; +			sys_info->freq_fman[0] = freq_cc_pll[HWA_CC_PLL] / 4;  		else -			sysInfo->freqFMan[0] = freqCC_PLL[HWA_CC_PLL] / 2; +			sys_info->freq_fman[0] = freq_cc_pll[HWA_CC_PLL] / 2;  	} else { -		sysInfo->freqFMan[0] = sysInfo->freqSystemBus / 2; +		sys_info->freq_fman[0] = sys_info->freq_systembus / 2;  	}  #if (CONFIG_SYS_NUM_FMAN) == 2  	if (rcw_tmp & FM2_CLK_SEL) {  		if (rcw_tmp & HWA_ASYNC_DIV) -			sysInfo->freqFMan[1] = freqCC_PLL[HWA_CC_PLL] / 4; +			sys_info->freq_fman[1] = freq_cc_pll[HWA_CC_PLL] / 4;  		else -			sysInfo->freqFMan[1] = freqCC_PLL[HWA_CC_PLL] / 2; +			sys_info->freq_fman[1] = freq_cc_pll[HWA_CC_PLL] / 2;  	} else { -		sysInfo->freqFMan[1] = sysInfo->freqSystemBus / 2; +		sys_info->freq_fman[1] = sys_info->freq_systembus / 2;  	}  #endif  #endif  #ifdef CONFIG_SYS_DPAA_QBMAN -	sysInfo->freqQMAN = sysInfo->freqSystemBus / 2; +	sys_info->freq_qman = sys_info->freq_systembus / 2;  #endif  #endif /* CONFIG_SYS_FSL_QORIQ_CHASSIS2 */  #else /* CONFIG_FSL_CORENET */ -	uint plat_ratio, e500_ratio, half_freqSystemBus; +	uint plat_ratio, e500_ratio, half_freq_systembus;  	int i;  #ifdef CONFIG_QE  	__maybe_unused u32 qe_ratio; @@ -290,40 +290,40 @@ void get_sys_info (sys_info_t * sysInfo)  	plat_ratio = (gur->porpllsr) & 0x0000003e;  	plat_ratio >>= 1; -	sysInfo->freqSystemBus = plat_ratio * CONFIG_SYS_CLK_FREQ; +	sys_info->freq_systembus = plat_ratio * CONFIG_SYS_CLK_FREQ;  	/* Divide before multiply to avoid integer  	 * overflow for processor speeds above 2GHz */ -	half_freqSystemBus = sysInfo->freqSystemBus/2; +	half_freq_systembus = sys_info->freq_systembus/2;  	for (i = 0; i < cpu_numcores(); i++) {  		e500_ratio = ((gur->porpllsr) >> (i * 8 + 16)) & 0x3f; -		sysInfo->freqProcessor[i] = e500_ratio * half_freqSystemBus; +		sys_info->freq_processor[i] = e500_ratio * half_freq_systembus;  	} -	/* Note: freqDDRBus is the MCLK frequency, not the data rate. */ -	sysInfo->freqDDRBus = sysInfo->freqSystemBus; +	/* Note: freq_ddrbus is the MCLK frequency, not the data rate. */ +	sys_info->freq_ddrbus = sys_info->freq_systembus;  #ifdef CONFIG_DDR_CLK_FREQ  	{  		u32 ddr_ratio = ((gur->porpllsr) & MPC85xx_PORPLLSR_DDR_RATIO)  			>> MPC85xx_PORPLLSR_DDR_RATIO_SHIFT;  		if (ddr_ratio != 0x7) -			sysInfo->freqDDRBus = ddr_ratio * CONFIG_DDR_CLK_FREQ; +			sys_info->freq_ddrbus = ddr_ratio * CONFIG_DDR_CLK_FREQ;  	}  #endif  #ifdef CONFIG_QE  #if defined(CONFIG_P1012) || defined(CONFIG_P1021) || defined(CONFIG_P1025) -	sysInfo->freqQE =  sysInfo->freqSystemBus; +	sys_info->freq_qe =  sys_info->freq_systembus;  #else  	qe_ratio = ((gur->porpllsr) & MPC85xx_PORPLLSR_QE_RATIO)  			>> MPC85xx_PORPLLSR_QE_RATIO_SHIFT; -	sysInfo->freqQE = qe_ratio * CONFIG_SYS_CLK_FREQ; +	sys_info->freq_qe = qe_ratio * CONFIG_SYS_CLK_FREQ;  #endif  #endif  #ifdef CONFIG_SYS_DPAA_FMAN -		sysInfo->freqFMan[0] = sysInfo->freqSystemBus; +		sys_info->freq_fman[0] = sys_info->freq_systembus;  #endif  #endif /* CONFIG_FSL_CORENET */ @@ -350,10 +350,10 @@ void get_sys_info (sys_info_t * sysInfo)  		 */  		lcrr_div *= 2;  #endif -		sysInfo->freqLocalBus = sysInfo->freqSystemBus / lcrr_div; +		sys_info->freq_localbus = sys_info->freq_systembus / lcrr_div;  	} else {  		/* In case anyone cares what the unknown value is */ -		sysInfo->freqLocalBus = lcrr_div; +		sys_info->freq_localbus = lcrr_div;  	}  #endif @@ -361,7 +361,7 @@ void get_sys_info (sys_info_t * sysInfo)  	ccr = in_be32(&ifc_regs->ifc_ccr);  	ccr = ((ccr & IFC_CCR_CLK_DIV_MASK) >> IFC_CCR_CLK_DIV_SHIFT) + 1; -	sysInfo->freqLocalBus = sysInfo->freqSystemBus / ccr; +	sys_info->freq_localbus = sys_info->freq_systembus / ccr;  #endif  } @@ -382,13 +382,13 @@ int get_clocks (void)  	dfbrg = (sccr & SCCR_DFBRG_MSK) >> SCCR_DFBRG_SHIFT;  #endif  	get_sys_info (&sys_info); -	gd->cpu_clk = sys_info.freqProcessor[0]; -	gd->bus_clk = sys_info.freqSystemBus; -	gd->mem_clk = sys_info.freqDDRBus; -	gd->arch.lbc_clk = sys_info.freqLocalBus; +	gd->cpu_clk = sys_info.freq_processor[0]; +	gd->bus_clk = sys_info.freq_systembus; +	gd->mem_clk = sys_info.freq_ddrbus; +	gd->arch.lbc_clk = sys_info.freq_localbus;  #ifdef CONFIG_QE -	gd->arch.qe_clk = sys_info.freqQE; +	gd->arch.qe_clk = sys_info.freq_qe;  	gd->arch.brg_clk = gd->arch.qe_clk / 2;  #endif  	/* @@ -400,7 +400,7 @@ int get_clocks (void)  	 */  #if defined(CONFIG_MPC8540) || defined(CONFIG_MPC8541) || \  	defined(CONFIG_MPC8560) || defined(CONFIG_MPC8555) -	gd->arch.i2c1_clk = sys_info.freqSystemBus; +	gd->arch.i2c1_clk = sys_info.freq_systembus;  #elif defined(CONFIG_MPC8544)  	/*  	 * On the 8544, the I2C clock is the same as the SEC clock.  This can be @@ -410,12 +410,12 @@ int get_clocks (void)  	 * PORDEVSR2_SEC_CFG bit is 0 on all 85xx boards that are not an 8544.  	 */  	if (gur->pordevsr2 & MPC85xx_PORDEVSR2_SEC_CFG) -		gd->arch.i2c1_clk = sys_info.freqSystemBus / 3; +		gd->arch.i2c1_clk = sys_info.freq_systembus / 3;  	else -		gd->arch.i2c1_clk = sys_info.freqSystemBus / 2; +		gd->arch.i2c1_clk = sys_info.freq_systembus / 2;  #else  	/* Most 85xx SOCs use CCB/2, so this is the default behavior. */ -	gd->arch.i2c1_clk = sys_info.freqSystemBus / 2; +	gd->arch.i2c1_clk = sys_info.freq_systembus / 2;  #endif  	gd->arch.i2c2_clk = gd->arch.i2c1_clk; @@ -429,7 +429,7 @@ int get_clocks (void)  #endif /* defined(CONFIG_FSL_ESDHC) */  #if defined(CONFIG_CPM2) -	gd->arch.vco_out = 2*sys_info.freqSystemBus; +	gd->arch.vco_out = 2*sys_info.freq_systembus;  	gd->arch.cpm_clk = gd->arch.vco_out / 2;  	gd->arch.scc_clk = gd->arch.vco_out / 4;  	gd->arch.brg_clk = gd->arch.vco_out / (1 << (2 * (dfbrg + 1))); diff --git a/arch/powerpc/cpu/mpc85xx/start.S b/arch/powerpc/cpu/mpc85xx/start.S index cfc3a60d2..ad57a9cfa 100644 --- a/arch/powerpc/cpu/mpc85xx/start.S +++ b/arch/powerpc/cpu/mpc85xx/start.S @@ -33,7 +33,8 @@  #define MINIMAL_SPL  #endif -#if !defined(CONFIG_SPL) && !defined(CONFIG_SYS_RAMBOOT) && !defined(CONFIG_SECURE_BOOT) +#if !defined(CONFIG_SPL) && !defined(CONFIG_SYS_RAMBOOT) && \ +	!defined(CONFIG_SECURE_BOOT) && !defined(CONFIG_SRIO_PCIE_BOOT_SLAVE)  #define NOR_BOOT  #endif diff --git a/arch/powerpc/cpu/mpc85xx/t4240_ids.c b/arch/powerpc/cpu/mpc85xx/t4240_ids.c index e173cb5f9..54c1cfd2c 100644 --- a/arch/powerpc/cpu/mpc85xx/t4240_ids.c +++ b/arch/powerpc/cpu/mpc85xx/t4240_ids.c @@ -65,8 +65,8 @@ struct qportal_info qp_info[CONFIG_SYS_QMAN_NUM_PORTALS] = {  #endif  struct srio_liodn_id_table srio_liodn_tbl[] = { -	SET_SRIO_LIODN_1(1, 307), -	SET_SRIO_LIODN_1(2, 387), +	SET_SRIO_LIODN_BASE(1, 307), +	SET_SRIO_LIODN_BASE(2, 387),  };  int srio_liodn_tbl_sz = ARRAY_SIZE(srio_liodn_tbl); @@ -159,10 +159,10 @@ int sec_liodn_tbl_sz = ARRAY_SIZE(sec_liodn_tbl);  #ifdef CONFIG_SYS_DPAA_RMAN  struct liodn_id_table rman_liodn_tbl[] = {  	/* Set RMan block 0-3 liodn offset */ -	SET_RMAN_LIODN(0, 678), -	SET_RMAN_LIODN(1, 679), -	SET_RMAN_LIODN(2, 680), -	SET_RMAN_LIODN(3, 681), +	SET_RMAN_LIODN(0, 6), +	SET_RMAN_LIODN(1, 7), +	SET_RMAN_LIODN(2, 8), +	SET_RMAN_LIODN(3, 9),  };  int rman_liodn_tbl_sz = ARRAY_SIZE(rman_liodn_tbl);  #endif diff --git a/arch/powerpc/cpu/mpc85xx/t4240_serdes.c b/arch/powerpc/cpu/mpc85xx/t4240_serdes.c index ed88602c3..ff55e3c35 100644 --- a/arch/powerpc/cpu/mpc85xx/t4240_serdes.c +++ b/arch/powerpc/cpu/mpc85xx/t4240_serdes.c @@ -106,25 +106,25 @@ static const struct serdes_config serdes2_cfg_tbl[] = {  		SGMII_FM2_DTSEC1, SGMII_FM2_DTSEC2,  		SGMII_FM2_DTSEC3, SGMII_FM2_DTSEC4}},  	{38, {NONE, NONE, QSGMII_FM2_B, NONE, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{40, {SGMII_FM2_DTSEC5, SGMII_FM2_DTSEC6,  		SGMII_FM2_DTSEC10, SGMII_FM2_DTSEC9, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{46, {SGMII_FM2_DTSEC5, SGMII_FM2_DTSEC6,  		SGMII_FM2_DTSEC10, SGMII_FM2_DTSEC9, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{48, {SGMII_FM2_DTSEC5, SGMII_FM2_DTSEC6,  		SGMII_FM2_DTSEC10, SGMII_FM2_DTSEC9, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{50, {XAUI_FM2_MAC9, XAUI_FM2_MAC9,  		XAUI_FM2_MAC9, XAUI_FM2_MAC9, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{52, {HIGIG_FM2_MAC9, HIGIG_FM2_MAC9,  		HIGIG_FM2_MAC9, HIGIG_FM2_MAC9, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{54, {HIGIG_FM2_MAC9, HIGIG_FM2_MAC9,  		HIGIG_FM2_MAC9, HIGIG_FM2_MAC9, -		NONE, NONE, QSGMII_FM1_A, NONE}}, +		NONE, NONE, QSGMII_FM2_A, NONE} },  	{56, {XFI_FM1_MAC9, XFI_FM1_MAC10,  		XFI_FM2_MAC10, XFI_FM2_MAC9,  		SGMII_FM2_DTSEC1, SGMII_FM2_DTSEC2, diff --git a/arch/powerpc/cpu/mpc85xx/tlb.c b/arch/powerpc/cpu/mpc85xx/tlb.c index da3c345d6..8748ecd14 100644 --- a/arch/powerpc/cpu/mpc85xx/tlb.c +++ b/arch/powerpc/cpu/mpc85xx/tlb.c @@ -39,7 +39,8 @@ void init_tlbs(void)  	return ;  } -#if !defined(CONFIG_NAND_SPL) && !defined(CONFIG_SPL_BUILD) +#if !defined(CONFIG_NAND_SPL) && \ +	(!defined(CONFIG_SPL_BUILD) || !defined(CONFIG_SPL_INIT_MINIMAL))  void read_tlbcam_entry(int idx, u32 *valid, u32 *tsize, unsigned long *epn,  		       phys_addr_t *rpn)  { diff --git a/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds b/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds index 08188d75e..85ec74ba9 100644 --- a/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds +++ b/arch/powerpc/cpu/mpc85xx/u-boot-spl.lds @@ -44,6 +44,11 @@ SECTIONS  	}  	_edata  =  .; +	. = .; +	__start___ex_table = .; +	__ex_table : { *(__ex_table) } +	__stop___ex_table = .; +  	. = ALIGN(8);  	__init_begin = .;  	__init_end = .; diff --git a/arch/powerpc/cpu/mpc86xx/cpu.c b/arch/powerpc/cpu/mpc86xx/cpu.c index d6b28dd07..30518544d 100644 --- a/arch/powerpc/cpu/mpc86xx/cpu.c +++ b/arch/powerpc/cpu/mpc86xx/cpu.c @@ -72,21 +72,21 @@ checkcpu(void)  	get_sys_info(&sysinfo);  	puts("Clock Configuration:\n"); -	printf("       CPU:%-4s MHz, ", strmhz(buf1, sysinfo.freqProcessor)); -	printf("MPX:%-4s MHz\n", strmhz(buf1, sysinfo.freqSystemBus)); +	printf("       CPU:%-4s MHz, ", strmhz(buf1, sysinfo.freq_processor)); +	printf("MPX:%-4s MHz\n", strmhz(buf1, sysinfo.freq_systembus));  	printf("       DDR:%-4s MHz (%s MT/s data rate), ", -		strmhz(buf1, sysinfo.freqSystemBus / 2), -		strmhz(buf2, sysinfo.freqSystemBus)); +		strmhz(buf1, sysinfo.freq_systembus / 2), +		strmhz(buf2, sysinfo.freq_systembus)); -	if (sysinfo.freqLocalBus > LCRR_CLKDIV) { -		printf("LBC:%-4s MHz\n", strmhz(buf1, sysinfo.freqLocalBus)); +	if (sysinfo.freq_localbus > LCRR_CLKDIV) { +		printf("LBC:%-4s MHz\n", strmhz(buf1, sysinfo.freq_localbus));  	} else {  		printf("LBC: unknown (LCRR[CLKDIV] = 0x%02lx)\n", -		       sysinfo.freqLocalBus); +		       sysinfo.freq_localbus);  	} -	puts("L1:    D-cache 32 KB enabled\n"); -	puts("       I-cache 32 KB enabled\n"); +	puts("L1:    D-cache 32 KiB enabled\n"); +	puts("       I-cache 32 KiB enabled\n");  	puts("L2:    ");  	if (get_l2cr() & 0x80000000) { @@ -95,7 +95,7 @@ checkcpu(void)  #elif defined(CONFIG_MPC8641)  		puts("512");  #endif -		puts(" KB enabled\n"); +		puts(" KiB enabled\n");  	} else {  		puts("Disabled\n");  	} @@ -131,7 +131,7 @@ get_tbclk(void)  	sys_info_t sys_info;  	get_sys_info(&sys_info); -	return (sys_info.freqSystemBus + 3L) / 4L; +	return (sys_info.freq_systembus + 3L) / 4L;  } diff --git a/arch/powerpc/cpu/mpc86xx/ddr-8641.c b/arch/powerpc/cpu/mpc86xx/ddr-8641.c index 92ba26dc8..33a91f9f7 100644 --- a/arch/powerpc/cpu/mpc86xx/ddr-8641.c +++ b/arch/powerpc/cpu/mpc86xx/ddr-8641.c @@ -15,7 +15,7 @@  #endif  void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -			     unsigned int ctrl_num) +			     unsigned int ctrl_num, int step)  {  	unsigned int i;  	volatile ccsr_ddr_t *ddr; diff --git a/arch/powerpc/cpu/mpc86xx/speed.c b/arch/powerpc/cpu/mpc86xx/speed.c index ea366ab9e..854d02b5c 100644 --- a/arch/powerpc/cpu/mpc86xx/speed.c +++ b/arch/powerpc/cpu/mpc86xx/speed.c @@ -19,7 +19,7 @@ DECLARE_GLOBAL_DATA_PTR;  /* used in some defintiions of CONFIG_SYS_CLK_FREQ */  extern unsigned long get_board_sys_clk(unsigned long dummy); -void get_sys_info(sys_info_t *sysInfo) +void get_sys_info(sys_info_t *sys_info)  {  	volatile immap_t *immap = (immap_t *) CONFIG_SYS_IMMR;  	volatile ccsr_gur_t *gur = &immap->im_gur; @@ -31,7 +31,7 @@ void get_sys_info(sys_info_t *sysInfo)  	switch (plat_ratio) {  	case 0x0: -		sysInfo->freqSystemBus = 16 * CONFIG_SYS_CLK_FREQ; +		sys_info->freq_systembus = 16 * CONFIG_SYS_CLK_FREQ;  		break;  	case 0x02:  	case 0x03: @@ -43,10 +43,10 @@ void get_sys_info(sys_info_t *sysInfo)  	case 0x0a:  	case 0x0c:  	case 0x10: -		sysInfo->freqSystemBus = plat_ratio * CONFIG_SYS_CLK_FREQ; +		sys_info->freq_systembus = plat_ratio * CONFIG_SYS_CLK_FREQ;  		break;  	default: -		sysInfo->freqSystemBus = 0; +		sys_info->freq_systembus = 0;  		break;  	} @@ -55,25 +55,26 @@ void get_sys_info(sys_info_t *sysInfo)  	switch (e600_ratio) {  	case 0x10: -		sysInfo->freqProcessor = 2 * sysInfo->freqSystemBus; +		sys_info->freq_processor = 2 * sys_info->freq_systembus;  		break;  	case 0x19: -		sysInfo->freqProcessor = 5 * sysInfo->freqSystemBus / 2; +		sys_info->freq_processor = 5 * sys_info->freq_systembus / 2;  		break;  	case 0x20: -		sysInfo->freqProcessor = 3 * sysInfo->freqSystemBus; +		sys_info->freq_processor = 3 * sys_info->freq_systembus;  		break;  	case 0x39: -		sysInfo->freqProcessor = 7 * sysInfo->freqSystemBus / 2; +		sys_info->freq_processor = 7 * sys_info->freq_systembus / 2;  		break;  	case 0x28: -		sysInfo->freqProcessor = 4 * sysInfo->freqSystemBus; +		sys_info->freq_processor = 4 * sys_info->freq_systembus;  		break;  	case 0x1d: -		sysInfo->freqProcessor = 9 * sysInfo->freqSystemBus / 2; +		sys_info->freq_processor = 9 * sys_info->freq_systembus / 2;  		break;  	default: -		sysInfo->freqProcessor = e600_ratio + sysInfo->freqSystemBus; +		sys_info->freq_processor = e600_ratio + +						sys_info->freq_systembus;  		break;  	} @@ -84,10 +85,11 @@ void get_sys_info(sys_info_t *sysInfo)  	lcrr_div = in_be32(&immap->im_lbc.lcrr) & LCRR_CLKDIV;  #endif  	if (lcrr_div == 2 || lcrr_div == 4 || lcrr_div == 8) { -		sysInfo->freqLocalBus = sysInfo->freqSystemBus / (lcrr_div * 2); +		sys_info->freq_localbus = sys_info->freq_systembus +							/ (lcrr_div * 2);  	} else {  		/* In case anyone cares what the unknown value is */ -		sysInfo->freqLocalBus = lcrr_div; +		sys_info->freq_localbus = lcrr_div;  	}  } @@ -102,9 +104,9 @@ int get_clocks(void)  	sys_info_t sys_info;  	get_sys_info(&sys_info); -	gd->cpu_clk = sys_info.freqProcessor; -	gd->bus_clk = sys_info.freqSystemBus; -	gd->arch.lbc_clk = sys_info.freqLocalBus; +	gd->cpu_clk = sys_info.freq_processor; +	gd->bus_clk = sys_info.freq_systembus; +	gd->arch.lbc_clk = sys_info.freq_localbus;  	/*  	 * The base clock for I2C depends on the actual SOC.  Unfortunately, @@ -114,9 +116,9 @@ int get_clocks(void)  	 * AN2919.  	 */  #ifdef CONFIG_MPC8610 -	gd->arch.i2c1_clk = sys_info.freqSystemBus; +	gd->arch.i2c1_clk = sys_info.freq_systembus;  #else -	gd->arch.i2c1_clk = sys_info.freqSystemBus / 2; +	gd->arch.i2c1_clk = sys_info.freq_systembus / 2;  #endif  	gd->arch.i2c2_clk = gd->arch.i2c1_clk; @@ -138,7 +140,7 @@ ulong get_bus_freq(ulong dummy)  	sys_info_t sys_info;  	get_sys_info(&sys_info); -	val = sys_info.freqSystemBus; +	val = sys_info.freq_systembus;  	return val;  } diff --git a/arch/powerpc/cpu/mpc8xx/cpu.c b/arch/powerpc/cpu/mpc8xx/cpu.c index 1550045e6..5c96b5fe1 100644 --- a/arch/powerpc/cpu/mpc8xx/cpu.c +++ b/arch/powerpc/cpu/mpc8xx/cpu.c @@ -136,10 +136,8 @@ static int check_CPU (long clock, uint pvr, uint immr)  #else  	printf (" at %s MHz: ", strmhz (buf, clock));  #endif -	printf ("%u kB I-Cache %u kB D-Cache", -		checkicache () >> 10, -		checkdcache () >> 10 -	); +	print_size(checkicache(), " I-Cache "); +	print_size(checkdcache(), " D-Cache");  	/* do we have a FEC (860T/P or 852/859/866/885)? */ @@ -204,10 +202,10 @@ static int check_CPU (long clock, uint pvr, uint immr)  		printf ("unknown MPC857 (0x%08x)", k);  #endif -	printf (" at %s MHz:", strmhz (buf, clock)); +	printf(" at %s MHz: ", strmhz(buf, clock)); -	printf (" %u kB I-Cache", checkicache () >> 10); -	printf (" %u kB D-Cache", checkdcache () >> 10); +	print_size(checkicache(), " I-Cache "); +	print_size(checkdcache(), " D-Cache");  	/* lets check and see if we're running on a 862T (or P?) */ @@ -265,10 +263,10 @@ static int check_CPU (long clock, uint pvr, uint immr)  	if (suf)  		printf ("PPC823ZTnn%s", suf); -	printf (" at %s MHz:", strmhz (buf, clock)); +	printf(" at %s MHz: ", strmhz(buf, clock)); -	printf (" %u kB I-Cache", checkicache () >> 10); -	printf (" %u kB D-Cache", checkdcache () >> 10); +	print_size(checkicache(), " I-Cache "); +	print_size(checkdcache(), " D-Cache");  	/* lets check and see if we're running on a 860T (or P?) */ @@ -321,10 +319,10 @@ static int check_CPU (long clock, uint pvr, uint immr)  	default:  		printf ("unknown MPC850 (0x%08x)", k);  	} -	printf (" at %s MHz:", strmhz (buf, clock)); +	printf(" at %s MHz: ", strmhz(buf, clock)); -	printf (" %u kB I-Cache", checkicache () >> 10); -	printf (" %u kB D-Cache", checkdcache () >> 10); +	print_size(checkicache(), " I-Cache "); +	print_size(checkdcache(), " D-Cache");  	/* lets check and see if we're running on a 850T (or P?) */ diff --git a/arch/powerpc/cpu/mpc8xx/video.c b/arch/powerpc/cpu/mpc8xx/video.c index 02cd0debc..fc351585b 100644 --- a/arch/powerpc/cpu/mpc8xx/video.c +++ b/arch/powerpc/cpu/mpc8xx/video.c @@ -109,7 +109,6 @@ DECLARE_GLOBAL_DATA_PTR;  /************************************************************************/  #include <video_font.h>			/* Get font data, width and height */ -#include <video_font_data.h>  #ifdef CONFIG_VIDEO_LOGO  #include <video_logo.h>			/* Get logo data, width and height */ @@ -1177,7 +1176,7 @@ static void *video_logo (void)  #ifndef CONFIG_FADS		/* all normal boards */  	/* leave one blank line */ -	sprintf (info, "MPC823 CPU at %s MHz, %ld MB RAM, %ld MB Flash", +	sprintf(info, "MPC823 CPU at %s MHz, %ld MiB RAM, %ld MiB Flash",  		strmhz(temp, gd->cpu_clk),  		gd->ram_size >> 20,  		gd->bd->bi_flashsize >> 20 ); @@ -1188,7 +1187,7 @@ static void *video_logo (void)  	video_drawstring (VIDEO_INFO_X, VIDEO_INFO_Y + VIDEO_FONT_HEIGHT,  					  info); -	sprintf (info, "2MB FLASH - 8MB DRAM - 4MB SRAM"); +	sprintf(info, "2MiB FLASH - 8MiB DRAM - 4MiB SRAM");  	video_drawstring (VIDEO_INFO_X, VIDEO_INFO_Y + VIDEO_FONT_HEIGHT * 2,  					  info);  #endif diff --git a/arch/powerpc/cpu/mpc8xxx/cpu.c b/arch/powerpc/cpu/mpc8xxx/cpu.c index 7369582ef..c67be4ef2 100644 --- a/arch/powerpc/cpu/mpc8xxx/cpu.c +++ b/arch/powerpc/cpu/mpc8xxx/cpu.c @@ -79,6 +79,9 @@ static struct cpu_type cpu_type_list[] = {  	CPU_TYPE_ENTRY(BSC9131, 9131, 1),  	CPU_TYPE_ENTRY(BSC9132, 9132, 2),  	CPU_TYPE_ENTRY(BSC9232, 9232, 2), +	CPU_TYPE_ENTRY(C291, C291, 1), +	CPU_TYPE_ENTRY(C292, C292, 1), +	CPU_TYPE_ENTRY(C293, C293, 1),  #elif defined(CONFIG_MPC86xx)  	CPU_TYPE_ENTRY(8610, 8610, 1),  	CPU_TYPE_ENTRY(8641, 8641, 2), diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/ctrl_regs.c b/arch/powerpc/cpu/mpc8xxx/ddr/ctrl_regs.c index ff5812df5..242eb47ac 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/ctrl_regs.c +++ b/arch/powerpc/cpu/mpc8xxx/ddr/ctrl_regs.c @@ -364,7 +364,7 @@ static void set_timing_cfg_3(fsl_ddr_cfg_regs_t *ddr,  	ddr->timing_cfg_3 = (0  		| ((ext_pretoact & 0x1) << 28) -		| ((ext_acttopre & 0x2) << 24) +		| ((ext_acttopre & 0x3) << 24)  		| ((ext_acttorw & 0x1) << 22)  		| ((ext_refrec & 0x1F) << 16)  		| ((ext_caslat & 0x3) << 12) @@ -681,6 +681,7 @@ static void set_ddr_sdram_cfg_2(fsl_ddr_cfg_regs_t *ddr,  	unsigned int odt_cfg = 0;	/* ODT configuration */  	unsigned int num_pr;		/* Number of posted refreshes */  	unsigned int slow = 0;		/* DDR will be run less than 1250 */ +	unsigned int x4_en = 0;		/* x4 DRAM enable */  	unsigned int obc_cfg;		/* On-The-Fly Burst Chop Cfg */  	unsigned int ap_en;		/* Address Parity Enable */  	unsigned int d_init;		/* DRAM data initialization */ @@ -725,6 +726,8 @@ static void set_ddr_sdram_cfg_2(fsl_ddr_cfg_regs_t *ddr,  		ap_en = 0;  	} +	x4_en = popts->x4_en ? 1 : 0; +  #if defined(CONFIG_ECC_INIT_VIA_DDRCONTROLLER)  	/* Use the DDR controller to auto initialize memory. */  	d_init = popts->ECC_init_using_memctl; @@ -747,6 +750,7 @@ static void set_ddr_sdram_cfg_2(fsl_ddr_cfg_regs_t *ddr,  		| ((odt_cfg & 0x3) << 21)  		| ((num_pr & 0xf) << 12)  		| ((slow & 1) << 11) +		| (x4_en << 10)  		| (qd_en << 9)  		| (unq_mrs_en << 8)  		| ((obc_cfg & 0x1) << 6) @@ -1585,8 +1589,8 @@ compute_fsl_memctl_config_regs(const memctl_options_t *popts,  				| ((ea & 0xFFF) << 0)	/* ending address MSB */  				);  		} else { -			debug("FSLDDR: setting bnds to 0 for inactive CS\n"); -			ddr->cs[i].bnds = 0; +			/* setting bnds to 0xffffffff for inactive CS */ +			ddr->cs[i].bnds = 0xffffffff;  		}  		debug("FSLDDR: cs[%d]_bnds = 0x%08x\n", i, ddr->cs[i].bnds); @@ -1638,5 +1642,10 @@ compute_fsl_memctl_config_regs(const memctl_options_t *popts,  	set_ddr_sdram_rcw(ddr, popts, common_dimm); +#ifdef CONFIG_SYS_FSL_DDR_EMU +	/* disble DDR training for emulator */ +	ddr->debug[2] = 0x00000400; +	ddr->debug[4] = 0xff800000; +#endif  	return check_fsl_memctl_config_regs(ddr);  } diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/ddr.h b/arch/powerpc/cpu/mpc8xxx/ddr/ddr.h index 4dd55fc4c..c173a5a74 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/ddr.h +++ b/arch/powerpc/cpu/mpc8xxx/ddr/ddr.h @@ -96,7 +96,7 @@ unsigned int check_fsl_memctl_config_regs(const fsl_ddr_cfg_regs_t *ddr);  /* processor specific function */  void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -				   unsigned int ctrl_num); +				   unsigned int ctrl_num, int step);  /* board specific function */  int fsl_ddr_get_dimm_params(dimm_params_t *pdimm, diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/ddr3_dimm_params.c b/arch/powerpc/cpu/mpc8xxx/ddr/ddr3_dimm_params.c index 3e7c269e4..b67158c0f 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/ddr3_dimm_params.c +++ b/arch/powerpc/cpu/mpc8xxx/ddr/ddr3_dimm_params.c @@ -129,6 +129,7 @@ ddr_compute_dimm_parameters(const ddr3_spd_eeprom_t *spd,  		pdimm->ec_sdram_width = 0;  	pdimm->data_width = pdimm->primary_sdram_width  			  + pdimm->ec_sdram_width; +	pdimm->device_width = 1 << ((spd->organization & 0x7) + 2);  	/* These are the types defined by the JEDEC DDR3 SPD spec */  	pdimm->mirrored_dimm = 0; diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/interactive.c b/arch/powerpc/cpu/mpc8xxx/ddr/interactive.c index 1ed6c7715..260fce577 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/interactive.c +++ b/arch/powerpc/cpu/mpc8xxx/ddr/interactive.c @@ -205,6 +205,7 @@ static void fsl_ddr_dimm_parameters_edit(fsl_ddr_info_t *pinfo,  		DIMM_PARM(primary_sdram_width),  		DIMM_PARM(ec_sdram_width),  		DIMM_PARM(registered_dimm), +		DIMM_PARM(device_width),  		DIMM_PARM(n_row_addr),  		DIMM_PARM(n_col_addr), @@ -263,6 +264,7 @@ static void print_dimm_parameters(const dimm_params_t *pdimm)  		DIMM_PARM(primary_sdram_width),  		DIMM_PARM(ec_sdram_width),  		DIMM_PARM(registered_dimm), +		DIMM_PARM(device_width),  		DIMM_PARM(n_row_addr),  		DIMM_PARM(n_col_addr), @@ -443,6 +445,7 @@ static void fsl_ddr_options_edit(fsl_ddr_info_t *pinfo,  		CTRL_OPTIONS(twoT_en),  		CTRL_OPTIONS(threeT_en),  		CTRL_OPTIONS(ap_en), +		CTRL_OPTIONS(x4_en),  		CTRL_OPTIONS(bstopre),  		CTRL_OPTIONS(wrlvl_override),  		CTRL_OPTIONS(wrlvl_sample), @@ -687,6 +690,7 @@ static void print_memctl_options(const memctl_options_t *popts)  		CTRL_OPTIONS(threeT_en),  		CTRL_OPTIONS(registered_dimm_en),  		CTRL_OPTIONS(ap_en), +		CTRL_OPTIONS(x4_en),  		CTRL_OPTIONS(bstopre),  		CTRL_OPTIONS(wrlvl_override),  		CTRL_OPTIONS(wrlvl_sample), diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/lc_common_dimm_params.c b/arch/powerpc/cpu/mpc8xxx/ddr/lc_common_dimm_params.c index e958e138d..56128a7b9 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/lc_common_dimm_params.c +++ b/arch/powerpc/cpu/mpc8xxx/ddr/lc_common_dimm_params.c @@ -218,12 +218,16 @@ compute_lowest_common_dimm_parameters(const dimm_params_t *dimm_params,  		if (dimm_params[i].n_ranks) {  			if (dimm_params[i].registered_dimm) {  				temp1 = 1; +#ifndef CONFIG_SPL_BUILD  				printf("Detected RDIMM %s\n",  					dimm_params[i].mpart); +#endif  			} else {  				temp2 = 1; +#ifndef CONFIG_SPL_BUILD  				printf("Detected UDIMM %s\n",  					dimm_params[i].mpart); +#endif  			}  		}  	} diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/main.c b/arch/powerpc/cpu/mpc8xxx/ddr/main.c index 7a8636de1..842bf1989 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/main.c +++ b/arch/powerpc/cpu/mpc8xxx/ddr/main.c @@ -25,10 +25,6 @@ void fsl_ddr_set_lawbar(  		unsigned int ctrl_num);  void fsl_ddr_set_intl3r(const unsigned int granule_size); -/* processor specific function */ -extern void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -				   unsigned int ctrl_num); -  #if defined(SPD_EEPROM_ADDRESS) || \      defined(SPD_EEPROM_ADDRESS1) || defined(SPD_EEPROM_ADDRESS2) || \      defined(SPD_EEPROM_ADDRESS3) || defined(SPD_EEPROM_ADDRESS4) @@ -365,9 +361,11 @@ fsl_ddr_compute(fsl_ddr_info_t *pinfo, unsigned int start_step,  {  	unsigned int i, j;  	unsigned long long total_mem = 0; +	int assert_reset;  	fsl_ddr_cfg_regs_t *ddr_reg = pinfo->fsl_ddr_config_reg;  	common_timing_params_t *timing_params = pinfo->common_timing_params; +	assert_reset = board_need_mem_reset();  	/* data bus width capacity adjust shift amount */  	unsigned int dbw_capacity_adjust[CONFIG_NUM_DDR_CONTROLLERS]; @@ -462,7 +460,20 @@ fsl_ddr_compute(fsl_ddr_info_t *pinfo, unsigned int start_step,  					timing_params[i].all_DIMMs_registered,  					&pinfo->memctl_opts[i],  					pinfo->dimm_params[i], i); +			/* +			 * For RDIMMs, JEDEC spec requires clocks to be stable +			 * before reset signal is deasserted. For the boards +			 * using fixed parameters, this function should be +			 * be called from board init file. +			 */ +			if (timing_params[i].all_DIMMs_registered) +				assert_reset = 1;  		} +		if (assert_reset) { +			debug("Asserting mem reset\n"); +			board_assert_mem_reset(); +		} +  	case STEP_ASSIGN_ADDRESSES:  		/* STEP 5:  Assign addresses to chip selects */  		check_interleaving_options(pinfo); @@ -504,7 +515,13 @@ fsl_ddr_compute(fsl_ddr_info_t *pinfo, unsigned int start_step,  				fsl_ddr_cfg_regs_t *reg = &ddr_reg[i];  				if (reg->cs[j].config & 0x80000000) {  					unsigned int end; -					end = reg->cs[j].bnds & 0xFFF; +					/* +					 * 0xfffffff is a special value we put +					 * for unused bnds +					 */ +					if (reg->cs[j].bnds == 0xffffffff) +						continue; +					end = reg->cs[j].bnds & 0xffff;  					if (end > max_end) {  						max_end = end;  					} @@ -531,6 +548,7 @@ phys_size_t fsl_ddr_sdram(void)  	unsigned int law_memctl = LAW_TRGT_IF_DDR_1;  	unsigned long long total_memory;  	fsl_ddr_info_t info; +	int deassert_reset;  	/* Reset info structure. */  	memset(&info, 0, sizeof(fsl_ddr_info_t)); @@ -559,7 +577,21 @@ phys_size_t fsl_ddr_sdram(void)  		}  	} -	/* Program configuration registers. */ +	/* +	 * Program configuration registers. +	 * JEDEC specs requires clocks to be stable before deasserting reset +	 * for RDIMMs. Clocks start after chip select is enabled and clock +	 * control register is set. During step 1, all controllers have their +	 * registers set but not enabled. Step 2 proceeds after deasserting +	 * reset through board FPGA or GPIO. +	 * For non-registered DIMMs, initialization can go through but it is +	 * also OK to follow the same flow. +	 */ +	deassert_reset = board_need_mem_reset(); +	for (i = 0; i < CONFIG_NUM_DDR_CONTROLLERS; i++) { +		if (info.common_timing_params[i].all_DIMMs_registered) +			deassert_reset = 1; +	}  	for (i = 0; i < CONFIG_NUM_DDR_CONTROLLERS; i++) {  		debug("Programming controller %u\n", i);  		if (info.common_timing_params[i].ndimms_present == 0) { @@ -567,8 +599,22 @@ phys_size_t fsl_ddr_sdram(void)  					"skipping programming\n", i);  			continue;  		} - -		fsl_ddr_set_memctl_regs(&(info.fsl_ddr_config_reg[i]), i); +		/* +		 * The following call with step = 1 returns before enabling +		 * the controller. It has to finish with step = 2 later. +		 */ +		fsl_ddr_set_memctl_regs(&(info.fsl_ddr_config_reg[i]), i, +					deassert_reset ? 1 : 0); +	} +	if (deassert_reset) { +		/* Use board FPGA or GPIO to deassert reset signal */ +		debug("Deasserting mem reset\n"); +		board_deassert_mem_reset(); +		for (i = 0; i < CONFIG_NUM_DDR_CONTROLLERS; i++) { +			/* Call with step = 2 to continue initialization */ +			fsl_ddr_set_memctl_regs(&(info.fsl_ddr_config_reg[i]), +						i, 2); +		}  	}  	/* program LAWs */ @@ -637,7 +683,8 @@ phys_size_t fsl_ddr_sdram(void)  #if !defined(CONFIG_PHYS_64BIT)  	/* Check for 4G or more.  Bad. */  	if (total_memory >= (1ull << 32)) { -		printf("Detected %lld MB of memory\n", total_memory >> 20); +		puts("Detected "); +		print_size(total_memory, " of memory\n");  		printf("       This U-Boot only supports < 4G of DDR\n");  		printf("       You could rebuild it with CONFIG_PHYS_64BIT\n");  		printf("       "); /* re-align to match init_func_ram print */ diff --git a/arch/powerpc/cpu/mpc8xxx/ddr/options.c b/arch/powerpc/cpu/mpc8xxx/ddr/options.c index 26369e099..30cdca497 100644 --- a/arch/powerpc/cpu/mpc8xxx/ddr/options.c +++ b/arch/powerpc/cpu/mpc8xxx/ddr/options.c @@ -700,6 +700,8 @@ unsigned int populate_memctl_options(int all_DIMMs_registered,  	}  #endif +	popts->x4_en = (pdimm[0].device_width == 4) ? 1 : 0; +  	/* Choose burst length. */  #if defined(CONFIG_FSL_DDR3)  #if defined(CONFIG_E500MC) diff --git a/arch/powerpc/cpu/mpc8xxx/fdt.c b/arch/powerpc/cpu/mpc8xxx/fdt.c index 89966e0d2..eb7cbbce7 100644 --- a/arch/powerpc/cpu/mpc8xxx/fdt.c +++ b/arch/powerpc/cpu/mpc8xxx/fdt.c @@ -121,11 +121,8 @@ void fdt_fixup_dr_usb(void *blob, bd_t *bd)  {  	const char *modes[] = { "host", "peripheral", "otg" };  	const char *phys[] = { "ulpi", "utmi" }; -	const char *mode = NULL; -	const char *phy_type = NULL;  	const char *dr_mode_type = NULL;  	const char *dr_phy_type = NULL; -	char usb1_defined = 0;  	int usb_mode_off = -1;  	int usb_phy_off = -1;  	char str[5]; @@ -159,12 +156,6 @@ void fdt_fixup_dr_usb(void *blob, bd_t *bd)  			dr_mode_type = modes[mode_idx];  			dr_phy_type = phys[phy_idx]; -			/* use usb_dr_mode and usb_phy_type if -			   usb1_defined = 0; these variables are to -			   be deprecated */ -			if (!strcmp(str, "usb1")) -				usb1_defined = 1; -  			if (mode_idx < 0 && phy_idx < 0) {  				printf("WARNING: invalid phy or mode\n");  				return; @@ -183,19 +174,6 @@ void fdt_fixup_dr_usb(void *blob, bd_t *bd)  		if (usb_phy_off < 0)  			return;  	} - -	if (!usb1_defined) { -		int usb_off = -1; -		mode = getenv("usb_dr_mode"); -		phy_type = getenv("usb_phy_type"); -		if (mode || phy_type) { -			printf("WARNING: usb_dr_mode and usb_phy_type " -				"are to be deprecated soon. Use " -				"hwconfig to set these values instead!!\n"); -			fdt_fixup_usb_mode_phy_type(blob, mode, -				phy_type, usb_off); -		} -	}  }  #endif /* defined(CONFIG_HAS_FSL_DR_USB) || defined(CONFIG_HAS_FSL_MPH_USB) */ diff --git a/arch/powerpc/cpu/mpc8xxx/law.c b/arch/powerpc/cpu/mpc8xxx/law.c index 89a561e0a..a40108310 100644 --- a/arch/powerpc/cpu/mpc8xxx/law.c +++ b/arch/powerpc/cpu/mpc8xxx/law.c @@ -76,7 +76,8 @@ void disable_law(u8 idx)  	return;  } -#if !defined(CONFIG_NAND_SPL) && !defined(CONFIG_SPL_BUILD) +#if !defined(CONFIG_NAND_SPL) && \ +	(!defined(CONFIG_SPL_BUILD) || !defined(CONFIG_SPL_INIT_MINIMAL))  static int get_law_entry(u8 i, struct law_entry *e)  {  	u32 lawar; @@ -106,7 +107,8 @@ int set_next_law(phys_addr_t addr, enum law_size sz, enum law_trgt_if id)  	return idx;  } -#if !defined(CONFIG_NAND_SPL) && !defined(CONFIG_SPL_BUILD) +#if !defined(CONFIG_NAND_SPL) && \ +	(!defined(CONFIG_SPL_BUILD) || !defined(CONFIG_SPL_INIT_MINIMAL))  int set_last_law(phys_addr_t addr, enum law_size sz, enum law_trgt_if id)  {  	u32 idx; diff --git a/arch/powerpc/cpu/ppc4xx/4xx_pci.c b/arch/powerpc/cpu/ppc4xx/4xx_pci.c index 2ca355b13..5584e0f3e 100644 --- a/arch/powerpc/cpu/ppc4xx/4xx_pci.c +++ b/arch/powerpc/cpu/ppc4xx/4xx_pci.c @@ -1,26 +1,5 @@ -/*-----------------------------------------------------------------------------+ - *       This source code is dual-licensed.  You may use it under the terms of - *       the GNU General Public license version 2, or under the license below. - * - *       This source code has been made available to you by IBM on an AS-IS - *       basis.  Anyone receiving this source is licensed under IBM - *       copyrights to use it in any way he or she deems fit, including - *       copying it, modifying it, compiling it, and redistributing it either - *       with or without modifications.  No license under IBM patents or - *       patent applications is to be implied by the copyright license. - * - *       Any user of this software should understand that IBM cannot provide - *       technical support for this software and will not be responsible for - *       any consequences resulting from the use of this software. - * - *       Any person who transfers this source code or any derivative work - *       must include the IBM copyright notice, this paragraph, and the - *       preceding two paragraphs in the transferred software. - * - *       COPYRIGHT   I B M   CORPORATION 1995 - *       LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M - *-----------------------------------------------------------------------------*/ -/*----------------------------------------------------------------------------+ +/* + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs   *   *  File Name:   405gp_pci.c   * diff --git a/arch/powerpc/cpu/ppc4xx/4xx_uart.c b/arch/powerpc/cpu/ppc4xx/4xx_uart.c index 1ad19abff..50c28a0d3 100644 --- a/arch/powerpc/cpu/ppc4xx/4xx_uart.c +++ b/arch/powerpc/cpu/ppc4xx/4xx_uart.c @@ -5,30 +5,7 @@   * (C) Copyright 2010   * Stefan Roese, DENX Software Engineering, sr@denx.de.   * - * SPDX-License-Identifier:	GPL-2.0+ - */ - -/* - * This source code is dual-licensed.  You may use it under the terms of the - * GNU General Public License version 2, or under the license below. - * - * This source code has been made available to you by IBM on an AS-IS - * basis.  Anyone receiving this source is licensed under IBM - * copyrights to use it in any way he or she deems fit, including - * copying it, modifying it, compiling it, and redistributing it either - * with or without modifications.  No license under IBM patents or - * patent applications is to be implied by the copyright license. - * - * Any user of this software should understand that IBM cannot provide - * technical support for this software and will not be responsible for - * any consequences resulting from the use of this software. - * - * Any person who transfers this source code or any derivative work - * must include the IBM copyright notice, this paragraph, and the - * preceding two paragraphs in the transferred software. - * - * COPYRIGHT   I B M   CORPORATION 1995 - * LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs   */  #include <common.h> @@ -40,7 +17,7 @@  DECLARE_GLOBAL_DATA_PTR; -#if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \ +#if defined(CONFIG_405GP) || \      defined(CONFIG_405EP) || defined(CONFIG_405EZ) || \      defined(CONFIG_405EX) || defined(CONFIG_440) @@ -91,7 +68,7 @@ DECLARE_GLOBAL_DATA_PTR;  #define UDIV_SUBTRACT	0  #define UART0_SDR	SDR0_UART0  #define UART1_SDR	SDR0_UART1 -#else /* CONFIG_405GP || CONFIG_405CR */ +#else /* CONFIG_405GP */  #define CR0_MASK        0x00001fff  #define CR0_EXTCLK_ENA  0x000000c0  #define CR0_UDIV_POS    1 @@ -196,7 +173,7 @@ int get_serial_clock(void)  	 * Let's handle this in some #ifdef's for the SoC's.  	 */ -#if defined(CONFIG_405CR) || defined(CONFIG_405GP) +#if defined(CONFIG_405GP)  	reg = mfdcr(CPC0_CR0) & ~CR0_MASK;  #ifdef CONFIG_SYS_EXT_SERIAL_CLOCK  	clk = CONFIG_SYS_EXT_SERIAL_CLOCK; @@ -223,7 +200,7 @@ int get_serial_clock(void)  #else  	clk = CONFIG_SYS_BASE_BAUD * 16;  #endif -#endif /* CONFIG_405CR */ +#endif  #if defined(CONFIG_405EP)  	{ @@ -288,4 +265,4 @@ int get_serial_clock(void)  	return clk;  } -#endif	/* CONFIG_405GP || CONFIG_405CR */ +#endif	/* CONFIG_405GP */ diff --git a/arch/powerpc/cpu/ppc4xx/cpu.c b/arch/powerpc/cpu/ppc4xx/cpu.c index fe050985e..d1fc7f3fc 100644 --- a/arch/powerpc/cpu/ppc4xx/cpu.c +++ b/arch/powerpc/cpu/ppc4xx/cpu.c @@ -320,25 +320,9 @@ int checkcpu (void)  		puts("405GP Rev. D");  		break; -#ifdef CONFIG_405GP -	case PVR_405GP_RE: /* 405GP rev E and 405CR rev C have same PVR */ +	case PVR_405GP_RE:  		puts("405GP Rev. E");  		break; -#endif - -	case PVR_405CR_RA: -		puts("405CR Rev. A"); -		break; - -	case PVR_405CR_RB: -		puts("405CR Rev. B"); -		break; - -#ifdef CONFIG_405CR -	case PVR_405CR_RC: /* 405GP rev E and 405CR rev C have same PVR */ -		puts("405CR Rev. C"); -		break; -#endif  	case PVR_405GPR_RB:  		puts("405GPr Rev. B"); @@ -647,12 +631,12 @@ int checkcpu (void)  #endif  #if defined(CONFIG_405EP) || defined(CONFIG_405EZ) || defined(CONFIG_405EX) -	printf ("       16 kB I-Cache 16 kB D-Cache"); +	printf("       16 KiB I-Cache 16 KiB D-Cache");  #elif defined(CONFIG_440) -	printf ("       32 kB I-Cache 32 kB D-Cache"); +	printf("       32 KiB I-Cache 32 KiB D-Cache");  #else -	printf ("       16 kB I-Cache %d kB D-Cache", -		((pvr | 0x00000001) == PVR_405GPR_RB) ? 16 : 8); +	printf("       16 KiB I-Cache %d KiB D-Cache", +	       ((pvr | 0x00000001) == PVR_405GPR_RB) ? 16 : 8);  #endif  #endif /* !defined(CONFIG_405) */ diff --git a/arch/powerpc/cpu/ppc4xx/cpu_init.c b/arch/powerpc/cpu/ppc4xx/cpu_init.c index d53d88251..d465dcda8 100644 --- a/arch/powerpc/cpu/ppc4xx/cpu_init.c +++ b/arch/powerpc/cpu/ppc4xx/cpu_init.c @@ -326,7 +326,7 @@ cpu_init_f (void)  	 * External Bus Controller (EBC) Setup  	 */  #if (defined(CONFIG_SYS_EBC_PB0AP) && defined(CONFIG_SYS_EBC_PB0CR)) -#if (defined(CONFIG_405GP) || defined(CONFIG_405CR) || \ +#if (defined(CONFIG_405GP) || \       defined(CONFIG_405EP) || defined(CONFIG_405EZ) || \       defined(CONFIG_405EX) || defined(CONFIG_405))  	/* diff --git a/arch/powerpc/cpu/ppc4xx/miiphy.c b/arch/powerpc/cpu/ppc4xx/miiphy.c index 297155fda..e4a9db676 100644 --- a/arch/powerpc/cpu/ppc4xx/miiphy.c +++ b/arch/powerpc/cpu/ppc4xx/miiphy.c @@ -1,25 +1,6 @@ -/*-----------------------------------------------------------------------------+ -  |   This source code is dual-licensed.  You may use it under the terms of the -  |   GNU General Public License version 2, or under the license below. -  | -  |	  This source code has been made available to you by IBM on an AS-IS -  |	  basis.  Anyone receiving this source is licensed under IBM -  |	  copyrights to use it in any way he or she deems fit, including -  |	  copying it, modifying it, compiling it, and redistributing it either -  |	  with or without modifications.  No license under IBM patents or -  |	  patent applications is to be implied by the copyright license. -  | -  |	  Any user of this software should understand that IBM cannot provide -  |	  technical support for this software and will not be responsible for -  |	  any consequences resulting from the use of this software. -  | -  |	  Any person who transfers this source code or any derivative work -  |	  must include the IBM copyright notice, this paragraph, and the -  |	  preceding two paragraphs in the transferred software. -  | -  |	  COPYRIGHT   I B M   CORPORATION 1995 -  |	  LICENSED MATERIAL  -	PROGRAM PROPERTY OF I B M -  +-----------------------------------------------------------------------------*/ +/* + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs + */  /*-----------------------------------------------------------------------------+    |    |  File Name:	 miiphy.c diff --git a/arch/powerpc/cpu/ppc4xx/speed.c b/arch/powerpc/cpu/ppc4xx/speed.c index 3345e7334..7e077d5a9 100644 --- a/arch/powerpc/cpu/ppc4xx/speed.c +++ b/arch/powerpc/cpu/ppc4xx/speed.c @@ -21,7 +21,7 @@ DECLARE_GLOBAL_DATA_PTR;  #define ARRAY_SIZE(x) (sizeof(x) / sizeof((x)[0])) -#if defined(CONFIG_405GP) || defined(CONFIG_405CR) +#if defined(CONFIG_405GP)  void get_sys_info (PPC4xx_SYS_INFO * sysInfo)  { @@ -1184,7 +1184,7 @@ ulong get_bus_freq (ulong dummy)  {  	ulong val; -#if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \ +#if defined(CONFIG_405GP) || \      defined(CONFIG_405EP) || defined(CONFIG_405EZ) || \      defined(CONFIG_405EX) || defined(CONFIG_405) || \      defined(CONFIG_440) diff --git a/arch/powerpc/cpu/ppc4xx/start.S b/arch/powerpc/cpu/ppc4xx/start.S index 57ae1d382..d9d8cbffa 100644 --- a/arch/powerpc/cpu/ppc4xx/start.S +++ b/arch/powerpc/cpu/ppc4xx/start.S @@ -6,46 +6,7 @@   *  Copyright (c) 2008 Nuovation System Designs, LLC   *    Grant Erickson <gerickson@nuovations.com>   * - * See file CREDITS for list of people who contributed to this - * project. - * - * This program is free software; you can redistribute it and/or - * modify it under the terms of the GNU General Public License as - * published by the Free Software Foundation; either version 2 of - * the License, or (at your option) any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, - * MA 02111-1307 USA - */ -/*------------------------------------------------------------------------------+ - *   This source code is dual-licensed.  You may use it under the terms of the - *   GNU General Public License version 2, or under the license below. - * - *	 This source code has been made available to you by IBM on an AS-IS - *	 basis.	 Anyone receiving this source is licensed under IBM - *	 copyrights to use it in any way he or she deems fit, including - *	 copying it, modifying it, compiling it, and redistributing it either - *	 with or without modifications.	 No license under IBM patents or - *	 patent applications is to be implied by the copyright license. - * - *	 Any user of this software should understand that IBM cannot provide - *	 technical support for this software and will not be responsible for - *	 any consequences resulting from the use of this software. - * - *	 Any person who transfers this source code or any derivative work - *	 must include the IBM copyright notice, this paragraph, and the - *	 preceding two paragraphs in the transferred software. - * - *	 COPYRIGHT   I B M   CORPORATION 1995 - *	 LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M - *------------------------------------------------------------------------------- + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs   */  /* @@ -833,7 +794,7 @@ _start:  #endif /* CONFIG_440 */  /*****************************************************************************/ -#if defined(CONFIG_405GP) || defined(CONFIG_405CR) || \ +#if defined(CONFIG_405GP) || \      defined(CONFIG_405EP) || defined(CONFIG_405EZ) || \      defined(CONFIG_405EX) || defined(CONFIG_405)  	/*----------------------------------------------------------------------- */ @@ -1103,7 +1064,7 @@ _start:  #endif /* CONFIG_NAND_SPL */ -#endif	/* CONFIG_405GP || CONFIG_405CR || CONFIG_405 || CONFIG_405EP */ +#endif	/* CONFIG_405GP || CONFIG_405 || CONFIG_405EP */  	/*----------------------------------------------------------------------- */ diff --git a/arch/powerpc/include/asm/config_mpc85xx.h b/arch/powerpc/include/asm/config_mpc85xx.h index 7ed93acdc..15e44de41 100644 --- a/arch/powerpc/include/asm/config_mpc85xx.h +++ b/arch/powerpc/include/asm/config_mpc85xx.h @@ -67,6 +67,8 @@  #define CONFIG_SYS_FSL_SRIO_IB_WIN_NUM	5  #define CONFIG_SYS_FSL_RMU  #define CONFIG_SYS_FSL_SRIO_MSG_UNIT_NUM	2 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x00  #elif defined(CONFIG_MPC8555)  #define CONFIG_MAX_CPUS			1 @@ -131,7 +133,10 @@  #define CONFIG_SYS_FSL_USB_INTERNAL_UTMI_PHY  #define CONFIG_SYS_FSL_ERRATUM_IFC_A002769  #define CONFIG_SYS_FSL_ERRATUM_P1010_A003549 +#define CONFIG_SYS_FSL_ERRATUM_SEC_A003571  #define CONFIG_SYS_FSL_ERRATUM_IFC_A003399 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x10  /* P1011 is single core version of P1020 */  #elif defined(CONFIG_P1011) @@ -249,6 +254,8 @@  #define CONFIG_SYS_FM_MURAM_SIZE	0x10000  #define CONFIG_SYS_FSL_PCIE_COMPAT	"fsl,qoriq-pcie-v2.2"  #define CONFIG_SYS_CCSRBAR_DEFAULT	0xff600000 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x11  /* P1024 is lower end variant of P1020 */  #elif defined(CONFIG_P1024) @@ -303,6 +310,7 @@  #elif defined(CONFIG_PPC_P2041) /* also supports P2040 */  #define CONFIG_SYS_FSL_QORIQ_CHASSIS1 +#define CONFIG_FSL_CORENET		/* Freescale CoreNet platform */  #define CONFIG_MAX_CPUS			4  #define CONFIG_SYS_FSL_NUM_CC_PLLS	2  #define CONFIG_SYS_FSL_NUM_LAWS		32 @@ -333,9 +341,12 @@  #define CONFIG_SYS_FSL_CORENET_SNOOPVEC_COREONLY 0xf0000000  #define CONFIG_SYS_FSL_ERRATUM_SRIO_A004034  #define CONFIG_SYS_FSL_ERRATUM_A004849 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x11  #elif defined(CONFIG_PPC_P3041)  #define CONFIG_SYS_FSL_QORIQ_CHASSIS1 +#define CONFIG_FSL_CORENET		/* Freescale CoreNet platform */  #define CONFIG_MAX_CPUS			4  #define CONFIG_SYS_FSL_NUM_CC_PLLS	2  #define CONFIG_SYS_FSL_NUM_LAWS		32 @@ -366,9 +377,13 @@  #define CONFIG_SYS_FSL_CORENET_SNOOPVEC_COREONLY 0xf0000000  #define CONFIG_SYS_FSL_ERRATUM_SRIO_A004034  #define CONFIG_SYS_FSL_ERRATUM_A004849 +#define CONFIG_SYS_FSL_ERRATUM_A005812 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x20  #elif defined(CONFIG_PPC_P4080) /* also supports P4040 */  #define CONFIG_SYS_FSL_QORIQ_CHASSIS1 +#define CONFIG_FSL_CORENET		/* Freescale CoreNet platform */  #define CONFIG_MAX_CPUS			8  #define CONFIG_SYS_FSL_NUM_CC_PLLS	4  #define CONFIG_SYS_FSL_NUM_LAWS		32 @@ -410,10 +425,14 @@  #define CONFIG_SYS_FSL_ERRATUM_A004849  #define CONFIG_SYS_FSL_ERRATUM_A004580  #define CONFIG_SYS_P4080_ERRATUM_PCIE_A003 +#define CONFIG_SYS_FSL_ERRATUM_A005812 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x20  #elif defined(CONFIG_PPC_P5020) /* also supports P5010 */  #define CONFIG_SYS_PPC64		/* 64-bit core */  #define CONFIG_SYS_FSL_QORIQ_CHASSIS1 +#define CONFIG_FSL_CORENET		/* Freescale CoreNet platform */  #define CONFIG_MAX_CPUS			2  #define CONFIG_SYS_FSL_NUM_CC_PLLS	2  #define CONFIG_SYS_FSL_NUM_LAWS		32 @@ -440,10 +459,13 @@  #define CONFIG_SYS_FSL_ERRATUM_A004510_SVR_REV	0x10  #define CONFIG_SYS_FSL_CORENET_SNOOPVEC_COREONLY 0xc0000000  #define CONFIG_SYS_FSL_ERRATUM_SRIO_A004034 +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x20  #elif defined(CONFIG_PPC_P5040)  #define CONFIG_SYS_PPC64  #define CONFIG_SYS_FSL_QORIQ_CHASSIS1 +#define CONFIG_FSL_CORENET		/* Freescale CoreNet platform */  #define CONFIG_MAX_CPUS			4  #define CONFIG_SYS_FSL_NUM_CC_PLLS	3  #define CONFIG_SYS_FSL_NUM_LAWS		32 @@ -469,6 +491,7 @@  #define CONFIG_SYS_FSL_ERRATUM_A004510  #define CONFIG_SYS_FSL_ERRATUM_A004510_SVR_REV	0x10  #define CONFIG_SYS_FSL_CORENET_SNOOPVEC_COREONLY 0xf0000000 +#define CONFIG_SYS_FSL_ERRATUM_A005812  #elif defined(CONFIG_BSC9131)  #define CONFIG_MAX_CPUS			1 @@ -492,12 +515,18 @@  #define CONFIG_TSECV2  #define CONFIG_SYS_FSL_SEC_COMPAT	4  #define CONFIG_NUM_DDR_CONTROLLERS	2 +#define CONFIG_SYS_FSL_DSP_DDR_ADDR	0x40000000 +#define CONFIG_SYS_FSL_DSP_M2_RAM_ADDR	0xb0000000 +#define CONFIG_SYS_FSL_DSP_M3_RAM_ADDR	0xc0000000 +#define CONFIG_SYS_FSL_DSP_CCSRBAR_DEFAULT	0xff600000  #define CONFIG_SYS_FSL_IFC_BANK_COUNT	3  #define CONFIG_SYS_CCSRBAR_DEFAULT	0xff700000  #define CONFIG_NAND_FSL_IFC  #define CONFIG_SYS_FSL_ERRATUM_ESDHC111  #define CONFIG_SYS_FSL_ESDHC_P1010_BROKEN_SDCLK  #define CONFIG_SYS_FSL_PCIE_COMPAT	"fsl,qoriq-pcie-v2.2" +#define CONFIG_SYS_FSL_ERRATUM_I2C_A004447 +#define CONFIG_SYS_FSL_A004447_SVR_REV	0x11  #elif defined(CONFIG_PPC_T4240) || defined(CONFIG_PPC_T4160)  #define CONFIG_E6500 @@ -523,6 +552,8 @@  #endif  #define CONFIG_SYS_FSL_NUM_CC_PLLS	5  #define CONFIG_SYS_FSL_NUM_LAWS		32 +#define CONFIG_SYS_FSL_SRDS_1 +#define CONFIG_SYS_FSL_SRDS_2  #define CONFIG_SYS_FSL_SRDS_3  #define CONFIG_SYS_FSL_SRDS_4  #define CONFIG_SYS_FSL_SEC_COMPAT	4 @@ -536,6 +567,7 @@  #define CONFIG_SYS_FSL_SRIO_MAX_PORTS	2  #define CONFIG_SYS_FSL_SRIO_OB_WIN_NUM	9  #define CONFIG_SYS_FSL_SRIO_IB_WIN_NUM	5 +#define CONFIG_SYS_FSL_SRIO_LIODN  #define CONFIG_SYS_FSL_USB_DUAL_PHY_ENABLE  #define CONFIG_SYS_FSL_USB_INTERNAL_UTMI_PHY  #define CONFIG_SYS_FSL_ERRATUM_A004468 @@ -552,6 +584,8 @@  #define CONFIG_SYS_FSL_QORIQ_CHASSIS2	/* Freescale Chassis generation 2 */  #define CONFIG_SYS_FSL_QMAN_V3		/* QMAN version 3 */  #define CONFIG_SYS_FSL_NUM_LAWS		32 +#define CONFIG_SYS_FSL_SRDS_1 +#define CONFIG_SYS_FSL_SRDS_2  #define CONFIG_SYS_FSL_SEC_COMPAT	4  #define CONFIG_SYS_NUM_FMAN		1  #define CONFIG_SYS_FSL_DDR_VER		FSL_DDR_VER_4_7 @@ -576,6 +610,7 @@  #define CONFIG_SYS_FSL_SRIO_MAX_PORTS	2  #define CONFIG_SYS_FSL_SRIO_OB_WIN_NUM	9  #define CONFIG_SYS_FSL_SRIO_IB_WIN_NUM	5 +#define CONFIG_SYS_FSL_SRIO_LIODN  #else  #define CONFIG_MAX_CPUS			2  #define CONFIG_SYS_FSL_CORES_PER_CLUSTER 2 @@ -612,6 +647,18 @@  #define CONFIG_SYS_FSL_USB_INTERNAL_UTMI_PHY  #define CONFIG_SYS_CCSRBAR_DEFAULT	0xfe000000 +#elif defined(CONFIG_PPC_C29X) +#define CONFIG_MAX_CPUS			1 +#define CONFIG_FSL_SDHC_V2_3 +#define CONFIG_SYS_FSL_NUM_LAWS		12 +#define CONFIG_SYS_PPC_E500_DEBUG_TLB	3 +#define CONFIG_TSECV2_1 +#define CONFIG_SYS_FSL_SEC_COMPAT	6 +#define CONFIG_SYS_FSL_ERRATUM_ESDHC111 +#define CONFIG_NUM_DDR_CONTROLLERS	1 +#define CONFIG_SYS_FSL_IFC_BANK_COUNT	8 +#define CONFIG_SYS_CCSRBAR_DEFAULT	0xff700000 +  #else  #error Processor type not defined for this platform  #endif diff --git a/arch/powerpc/include/asm/fsl_ddr_dimm_params.h b/arch/powerpc/include/asm/fsl_ddr_dimm_params.h index ffe4db8b8..bd312ad5c 100644 --- a/arch/powerpc/include/asm/fsl_ddr_dimm_params.h +++ b/arch/powerpc/include/asm/fsl_ddr_dimm_params.h @@ -26,6 +26,7 @@ typedef struct dimm_params_s {  	unsigned int primary_sdram_width;  	unsigned int ec_sdram_width;  	unsigned int registered_dimm; +	unsigned int device_width;	/* x4, x8, x16 components */  	/* SDRAM device parameters */  	unsigned int n_row_addr; diff --git a/arch/powerpc/include/asm/fsl_ddr_sdram.h b/arch/powerpc/include/asm/fsl_ddr_sdram.h index 640d3297d..f4eec82d5 100644 --- a/arch/powerpc/include/asm/fsl_ddr_sdram.h +++ b/arch/powerpc/include/asm/fsl_ddr_sdram.h @@ -277,6 +277,7 @@ typedef struct memctl_options_s {  	unsigned int mirrored_dimm;  	unsigned int quad_rank_present;  	unsigned int ap_en;	/* address parity enable for RDIMM */ +	unsigned int x4_en;	/* enable x4 devices */  	/* Global Timing Parameters */  	unsigned int cas_latency_override; @@ -330,9 +331,31 @@ extern phys_size_t fsl_ddr_sdram(void);  extern phys_size_t fsl_ddr_sdram_size(void);  extern int fsl_use_spd(void);  extern void fsl_ddr_set_memctl_regs(const fsl_ddr_cfg_regs_t *regs, -					unsigned int ctrl_num); +					unsigned int ctrl_num, int step);  u32 fsl_ddr_get_intl3r(void); +static void __board_assert_mem_reset(void) +{ +} + +static void __board_deassert_mem_reset(void) +{ +} + +void board_assert_mem_reset(void) +	__attribute__((weak, alias("__board_assert_mem_reset"))); + +void board_deassert_mem_reset(void) +	__attribute__((weak, alias("__board_deassert_mem_reset"))); + +static int __board_need_mem_reset(void) +{ +	return 0; +} + +int board_need_mem_reset(void) +	__attribute__((weak, alias("__board_need_mem_reset"))); +  /*   * The 85xx boards have a common prototype for fixed_sdram so put the   * declaration here. diff --git a/arch/powerpc/include/asm/fsl_i2c.h b/arch/powerpc/include/asm/fsl_i2c.h index 4f7134132..d6537fd63 100644 --- a/arch/powerpc/include/asm/fsl_i2c.h +++ b/arch/powerpc/include/asm/fsl_i2c.h @@ -54,6 +54,7 @@ typedef struct fsl_i2c {  #define I2C_CR_MTX	0x10  #define I2C_CR_TXAK	0x08  #define I2C_CR_RSTA	0x04 +#define I2C_CR_BIT6	0x02	/* required for workaround A004447 */  #define I2C_CR_BCST	0x01  	u8 sr;		/* I2C status register */ diff --git a/arch/powerpc/include/asm/fsl_law.h b/arch/powerpc/include/asm/fsl_law.h index bea163676..37d3a2246 100644 --- a/arch/powerpc/include/asm/fsl_law.h +++ b/arch/powerpc/include/asm/fsl_law.h @@ -82,7 +82,7 @@ enum law_trgt_if {  #ifndef CONFIG_MPC8641  	LAW_TRGT_IF_PCIE_1 = 0x02,  #endif -#if defined(CONFIG_BSC9131) +#if defined(CONFIG_BSC9131) || defined(CONFIG_BSC9132)  	LAW_TRGT_IF_OCN_DSP = 0x03,  #else  #if !defined(CONFIG_MPC8572) && !defined(CONFIG_P2020) @@ -92,9 +92,14 @@ enum law_trgt_if {  	LAW_TRGT_IF_LBC = 0x04,  	LAW_TRGT_IF_CCSR = 0x08,  	LAW_TRGT_IF_DSP_CCSR = 0x09, +	LAW_TRGT_IF_PLATFORM_SRAM = 0x0a,  	LAW_TRGT_IF_DDR_INTRLV = 0x0b,  	LAW_TRGT_IF_RIO = 0x0c, +#if defined(CONFIG_BSC9132) +	LAW_TRGT_IF_CLASS_DSP = 0x0d, +#else  	LAW_TRGT_IF_RIO_2 = 0x0d, +#endif  	LAW_TRGT_IF_DPAA_SWP_SRAM = 0x0e,  	LAW_TRGT_IF_DDR = 0x0f,  	LAW_TRGT_IF_DDR_2 = 0x16,	/* 2nd controller */ diff --git a/arch/powerpc/include/asm/fsl_liodn.h b/arch/powerpc/include/asm/fsl_liodn.h index 3f543d924..44bc88dce 100644 --- a/arch/powerpc/include/asm/fsl_liodn.h +++ b/arch/powerpc/include/asm/fsl_liodn.h @@ -29,6 +29,13 @@ struct srio_liodn_id_table {  		+ CONFIG_SYS_MPC85xx_GUTS_OFFSET + CONFIG_SYS_CCSRBAR, \  	} +#define SET_SRIO_LIODN_BASE(port, id_a) \ +	{ .id = { id_a }, .num_ids = 1, .portid = port, \ +	  .reg_offset[0] = offsetof(struct ccsr_rio, liodn) \ +		+ (port - 1) * 0x200 \ +		+ CONFIG_SYS_FSL_SRIO_ADDR, \ +	} +  struct liodn_id_table {  	const char * compat;  	u32 id[2]; diff --git a/arch/powerpc/include/asm/fsl_pci.h b/arch/powerpc/include/asm/fsl_pci.h index c740da37c..749411c10 100644 --- a/arch/powerpc/include/asm/fsl_pci.h +++ b/arch/powerpc/include/asm/fsl_pci.h @@ -1,5 +1,5 @@  /* - * Copyright 2007,2009-2011 Freescale Semiconductor, Inc. + * Copyright 2007,2009-2012 Freescale Semiconductor, Inc.   *   * SPDX-License-Identifier:	GPL-2.0+   */ @@ -13,6 +13,34 @@  #define PEX_IP_BLK_REV_2_2	0x02080202  #define PEX_IP_BLK_REV_2_3	0x02080203 +#define PEX_IP_BLK_REV_3_0	0x02080300 + +/* Freescale-specific PCI config registers */ +#define FSL_PCI_PBFR		0x44 + +#ifdef CONFIG_SYS_FSL_PCI_VER_3_X +/* Currently only the PCIe capability is used, so hardcode the offset. + * if more capabilities need to be justified, the capability link method + * should be applied here + */ +#define FSL_PCIE_CAP_ID		0x70 +#define PCI_DCR		0x78    /* PCIe Device Control Register */ +#define PCI_DSR		0x7a    /* PCIe Device Status Register */ +#define PCI_LSR		0x82    /* PCIe Link Status Register */ +#define PCI_LCR		0x80    /* PCIe Link Control Register */ +#else +#define FSL_PCIE_CAP_ID		0x4c +#define PCI_DCR		0x54    /* PCIe Device Control Register */ +#define PCI_DSR		0x56    /* PCIe Device Status Register */ +#define PCI_LSR		0x5e    /* PCIe Link Status Register */ +#define PCI_LCR		0x5c    /* PCIe Link Control Register */ +#endif + +#define FSL_PCIE_CFG_RDY	0x4b0 +#define FSL_PROG_IF_AGENT	0x1 + +#define PCI_LTSSM	0x404   /* PCIe Link Training, Status State Machine */ +#define  PCI_LTSSM_L0	0x16    /* L0 state */  int fsl_setup_hose(struct pci_controller *hose, unsigned long addr);  int fsl_is_pci_agent(struct pci_controller *hose); @@ -149,7 +177,10 @@ typedef struct ccsr_pci {  	u32	perr_cap3;	/* 0xe34 - PCIE Error Capture Register 3 */  	char	res23[200];  	u32	pdb_stat;	/* 0xf00 - PCIE Debug Status */ -	char	res24[252]; +	char	res24[16]; +	u32	pex_csr0;	/* 0xf14 - PEX Control/Status register 0*/ +	u32	pex_csr1;	/* 0xf18 - PEX Control/Status register 1*/ +	char	res25[228];  } ccsr_fsl_pci_t;  #define PCIE_CONFIG_PC	0x00020000  #define PCIE_CONFIG_OB_CK	0x00002000 diff --git a/arch/powerpc/include/asm/fsl_serdes.h b/arch/powerpc/include/asm/fsl_serdes.h index 59189adb3..1106d2805 100644 --- a/arch/powerpc/include/asm/fsl_serdes.h +++ b/arch/powerpc/include/asm/fsl_serdes.h @@ -90,6 +90,7 @@ void fsl_serdes_init(void);  #ifdef CONFIG_FSL_CORENET  #ifdef CONFIG_SYS_FSL_QORIQ_CHASSIS2  int serdes_get_first_lane(u32 sd, enum srds_prtcl device); +enum srds_prtcl serdes_get_prtcl(int serdes, int cfg, int lane);  #else  int serdes_get_first_lane(enum srds_prtcl device);  #endif diff --git a/arch/powerpc/include/asm/immap_85xx.h b/arch/powerpc/include/asm/immap_85xx.h index 81b3322fe..3a10d778f 100644 --- a/arch/powerpc/include/asm/immap_85xx.h +++ b/arch/powerpc/include/asm/immap_85xx.h @@ -1544,6 +1544,18 @@ struct rio_pw {  };  #endif +#ifdef CONFIG_SYS_FSL_SRIO_LIODN +struct rio_liodn { +	u32	plbr; +	u8	res0[28]; +	u32	plaor; +	u8	res1[12]; +	u32	pludr; +	u32	plldr; +	u8	res2[456]; +}; +#endif +  /* RapidIO Registers */  struct ccsr_rio {  	struct rio_arch	arch; @@ -1566,6 +1578,10 @@ struct ccsr_rio {  	u8	res7[100];  	struct rio_pw	pw;  #endif +#ifdef CONFIG_SYS_FSL_SRIO_LIODN +	u8	res5[8192]; +	struct rio_liodn liodn[CONFIG_SYS_FSL_SRIO_MAX_PORTS]; +#endif  };  #endif @@ -2131,6 +2147,11 @@ typedef struct ccsr_gur {  #ifdef CONFIG_MPC8536  #define MPC85xx_PORPLLSR_DDR_RATIO	0x3e000000  #define MPC85xx_PORPLLSR_DDR_RATIO_SHIFT	25 +#elif defined(CONFIG_PPC_C29X) +#define MPC85xx_PORPLLSR_DDR_RATIO	0x00003f00 +#define MPC85xx_PORPLLSR_DDR_RATIO_SHIFT	(9 - ((gur->pordevsr2 \ +					& MPC85xx_PORDEVSR2_DDR_SPD_0) \ +					>> MPC85xx_PORDEVSR2_DDR_SPD_0_SHIFT))  #else  #if defined(CONFIG_BSC9131) || defined(CONFIG_BSC9132)  #define MPC85xx_PORPLLSR_DDR_RATIO	0x00003f00 @@ -2178,6 +2199,9 @@ typedef struct ccsr_gur {  #elif defined(CONFIG_BSC9132)  #define MPC85xx_PORDEVSR_IO_SEL		0x00FE0000  #define MPC85xx_PORDEVSR_IO_SEL_SHIFT	17 +#elif defined(CONFIG_PPC_C29X) +#define MPC85xx_PORDEVSR_IO_SEL		0x00e00000 +#define MPC85xx_PORDEVSR_IO_SEL_SHIFT	21  #else  #define MPC85xx_PORDEVSR_IO_SEL		0x00780000  #define MPC85xx_PORDEVSR_IO_SEL_SHIFT	19 @@ -2193,6 +2217,10 @@ typedef struct ccsr_gur {  #define MPC85xx_PORDEVSR_RIO_DEV_ID	0x00000007  	u32	pordbgmsr;	/* POR debug mode status */  	u32	pordevsr2;	/* POR I/O device status 2 */ +#if defined(CONFIG_PPC_C29X) +#define MPC85xx_PORDEVSR2_DDR_SPD_0	0x00000008 +#define MPC85xx_PORDEVSR2_DDR_SPD_0_SHIFT	3 +#endif  /* The 8544 RM says this is bit 26, but it's really bit 24 */  #define MPC85xx_PORDEVSR2_SEC_CFG	0x00000080  	u8	res1[8]; @@ -2339,6 +2367,11 @@ typedef struct ccsr_gur {  #define MPC85xx_PMUXCR0_SIM_SEL_MASK	0x0003b000  #define MPC85xx_PMUXCR0_SIM_SEL		0x00014000  #endif +#if defined(CONFIG_PPC_C29X) +#define MPC85xx_PMUXCR_SPI_MASK			0x00000300 +#define MPC85xx_PMUXCR_SPI			0x00000000 +#define MPC85xx_PMUXCR_SPI_GPIO			0x00000100 +#endif  	u32	pmuxcr2;	/* Alt. function signal multiplex control 2 */  #if defined(CONFIG_P1010) || defined(CONFIG_P1014)  #define MPC85xx_PMUXCR2_UART_GPIO		0x40000000 @@ -2526,7 +2559,9 @@ typedef struct serdes_corenet {  #define SRDS_RSTCTL_RSTDONE	0x40000000  #define SRDS_RSTCTL_RSTERR	0x20000000  #define SRDS_RSTCTL_SWRST	0x10000000 -#define SRDS_RSTCTL_SDPD	0x00000020 +#define SRDS_RSTCTL_SDEN	0x00000020 +#define SRDS_RSTCTL_SDRST_B	0x00000040 +#define SRDS_RSTCTL_PLLRST_B	0x00000080  		u32	pllcr0; /* PLL Control Register 0 */  #define SRDS_PLLCR0_POFF		0x80000000  #define SRDS_PLLCR0_RFCK_SEL_MASK	0x70000000 @@ -2811,54 +2846,6 @@ typedef struct ccsr_pme {  	u8	res4[0x400];  } ccsr_pme_t; -#ifdef CONFIG_SYS_FSL_USB_DUAL_PHY_ENABLE -struct ccsr_usb_port_ctrl { -	u32	ctrl; -	u32	drvvbuscfg; -	u32	pwrfltcfg; -	u32	sts; -	u8	res_14[0xc]; -	u32	bistcfg; -	u32	biststs; -	u32	abistcfg; -	u32	abiststs; -	u8	res_30[0x10]; -	u32	xcvrprg; -	u32	anaprg; -	u32	anadrv; -	u32	anasts; -}; - -typedef struct ccsr_usb_phy { -	u32	id; -	struct  ccsr_usb_port_ctrl port1; -	u8	res_50[0xc]; -	u32	tvr; -	u32	pllprg[4]; -	u8	res_70[0x4]; -	u32	anaccfg; -	u32	dbg; -	u8	res_7c[0x4]; -	struct  ccsr_usb_port_ctrl port2; -	u8	res_dc[0x334]; -} ccsr_usb_phy_t; - -#define CONFIG_SYS_FSL_USB_CTRL_PHY_EN (1 << 0) -#define CONFIG_SYS_FSL_USB_DRVVBUS_CR_EN (1 << 1) -#define CONFIG_SYS_FSL_USB_PWRFLT_CR_EN (1 << 1) -#define CONFIG_SYS_FSL_USB_PLLPRG2_PHY2_CLK_EN (1 << 0) -#define CONFIG_SYS_FSL_USB_PLLPRG2_PHY1_CLK_EN (1 << 1) -#define CONFIG_SYS_FSL_USB_PLLPRG2_MFI (5 << 16) -#define CONFIG_SYS_FSL_USB_PLLPRG2_PLL_EN (1 << 21) -#else -typedef struct ccsr_usb_phy { -	u8	res0[0x18]; -	u32	usb_enable_override; -	u8	res[0xe4]; -} ccsr_usb_phy_t; -#define CONFIG_SYS_FSL_USB_ENABLE_OVERRIDE 1 -#endif -  #ifdef CONFIG_SYS_FSL_RAID_ENGINE  struct ccsr_raide {  	u8	res0[0x543]; @@ -3008,12 +2995,18 @@ struct ccsr_pman {  #define CONFIG_SYS_MPC85xx_USB2_OFFSET		0x23000  #ifdef CONFIG_TSECV2  #define CONFIG_SYS_TSEC1_OFFSET			0xB0000 +#elif defined(CONFIG_TSECV2_1) +#define CONFIG_SYS_TSEC1_OFFSET			0x10000  #else  #define CONFIG_SYS_TSEC1_OFFSET			0x24000  #endif  #define CONFIG_SYS_MDIO1_OFFSET			0x24000  #define CONFIG_SYS_MPC85xx_ESDHC_OFFSET		0x2e000 +#if defined(CONFIG_PPC_C29X) +#define CONFIG_SYS_FSL_SEC_OFFSET		0x80000 +#else  #define CONFIG_SYS_FSL_SEC_OFFSET		0x30000 +#endif  #define CONFIG_SYS_MPC85xx_SERDES2_OFFSET	0xE3100  #define CONFIG_SYS_MPC85xx_SERDES1_OFFSET	0xE3000  #define CONFIG_SYS_SNVS_OFFSET			0xE6000 @@ -3031,6 +3024,12 @@ struct ccsr_pman {  #define CONFIG_SYS_MPC85xx_GUTS_OFFSET		0xE0000  #define CONFIG_SYS_FSL_SRIO_OFFSET		0xC0000 +#if defined(CONFIG_BSC9132) +#define CONFIG_SYS_FSL_DSP_CCSR_DDR_OFFSET	0x10000 +#define CONFIG_SYS_FSL_DSP_CCSR_DDR_ADDR \ +	(CONFIG_SYS_FSL_DSP_CCSRBAR + CONFIG_SYS_FSL_DSP_CCSR_DDR_OFFSET) +#endif +  #define CONFIG_SYS_FSL_CPC_ADDR	\  	(CONFIG_SYS_CCSRBAR + CONFIG_SYS_FSL_CPC_OFFSET)  #define CONFIG_SYS_FSL_QMAN_ADDR \ diff --git a/arch/powerpc/include/asm/ppc405.h b/arch/powerpc/include/asm/ppc405.h index 892848aac..8bb342b92 100644 --- a/arch/powerpc/include/asm/ppc405.h +++ b/arch/powerpc/include/asm/ppc405.h @@ -1,25 +1,6 @@ -/*----------------------------------------------------------------------------+ -|   This source code is dual-licensed.  You may use it under the terms of the -|   GNU General Public License version 2, or under the license below. -| -|	This source code has been made available to you by IBM on an AS-IS -|	basis.	Anyone receiving this source is licensed under IBM -|	copyrights to use it in any way he or she deems fit, including -|	copying it, modifying it, compiling it, and redistributing it either -|	with or without modifications.	No license under IBM patents or -|	patent applications is to be implied by the copyright license. -| -|	Any user of this software should understand that IBM cannot provide -|	technical support for this software and will not be responsible for -|	any consequences resulting from the use of this software. -| -|	Any person who transfers this source code or any derivative work -|	must include the IBM copyright notice, this paragraph, and the -|	preceding two paragraphs in the transferred software. -| -|	COPYRIGHT   I B M   CORPORATION 1999 -|	LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M -+----------------------------------------------------------------------------*/ +/* + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs + */  #ifndef	__PPC405_H__  #define __PPC405_H__ diff --git a/arch/powerpc/include/asm/ppc405cr.h b/arch/powerpc/include/asm/ppc405cr.h deleted file mode 100644 index 0ea69bd09..000000000 --- a/arch/powerpc/include/asm/ppc405cr.h +++ /dev/null @@ -1,92 +0,0 @@ -/* - * (C) Copyright 2010 - * Stefan Roese, DENX Software Engineering, sr@denx.de. - * - * SPDX-License-Identifier:	GPL-2.0+  - */ - -#ifndef _PPC405CR_H_ -#define _PPC405CR_H_ - -#define CONFIG_SDRAM_PPC4xx_IBM_SDRAM	/* IBM SDRAM controller */ - -/* Memory mapped register */ -#define CONFIG_SYS_PERIPHERAL_BASE	0xef600000 /* Internal Peripherals */ - -#define CONFIG_SYS_NS16550_COM1	(CONFIG_SYS_PERIPHERAL_BASE + 0x0300) -#define CONFIG_SYS_NS16550_COM2	(CONFIG_SYS_PERIPHERAL_BASE + 0x0400) - -#define GPIO0_BASE		(CONFIG_SYS_PERIPHERAL_BASE + 0x0700) - -/* DCR's */ -#define DCP0_CFGADDR	0x0014		/* Decompression controller addr reg */ -#define DCP0_CFGDATA	0x0015		/* Decompression controller data reg */ -#define OCM0_ISCNTL	0x0019	/* OCM I-side control reg */ -#define OCM0_DSARC	0x001a	/* OCM D-side address compare */ -#define OCM0_DSCNTL	0x001b	/* OCM D-side control */ -#define CPC0_PLLMR	0x00b0		/* PLL mode  register */ -#define CPC0_CR0	0x00b1		/* chip control register 0 */ -#define CPC0_CR1	0x00b2		/* chip control register 1 */ -#define CPC0_PSR	0x00b4		/* chip pin strapping reg */ -#define CPC0_EIRR	0x00b6		/* ext interrupt routing reg */ -#define CPC0_SR		0x00b8		/* Power management status */ -#define CPC0_ER		0x00b9		/* Power management enable */ -#define CPC0_FR		0x00ba		/* Power management force */ -#define CPC0_ECR	0x00aa		/* edge conditioner register */ - -#define PLLMR_FWD_DIV_MASK	0xE0000000	/* Forward Divisor */ -#define PLLMR_FWD_DIV_BYPASS	0xE0000000 -#define PLLMR_FWD_DIV_3		0xA0000000 -#define PLLMR_FWD_DIV_4		0x80000000 -#define PLLMR_FWD_DIV_6		0x40000000 - -#define PLLMR_FB_DIV_MASK	0x1E000000	/* Feedback Divisor */ -#define PLLMR_FB_DIV_1		0x02000000 -#define PLLMR_FB_DIV_2		0x04000000 -#define PLLMR_FB_DIV_3		0x06000000 -#define PLLMR_FB_DIV_4		0x08000000 - -#define PLLMR_TUNING_MASK	0x01F80000 - -#define PLLMR_CPU_TO_PLB_MASK	0x00060000	/* CPU:PLB Frequency Divisor */ -#define PLLMR_CPU_PLB_DIV_1	0x00000000 -#define PLLMR_CPU_PLB_DIV_2	0x00020000 -#define PLLMR_CPU_PLB_DIV_3	0x00040000 -#define PLLMR_CPU_PLB_DIV_4	0x00060000 - -#define PLLMR_OPB_TO_PLB_MASK	0x00018000	/* OPB:PLB Frequency Divisor */ -#define PLLMR_OPB_PLB_DIV_1	0x00000000 -#define PLLMR_OPB_PLB_DIV_2	0x00008000 -#define PLLMR_OPB_PLB_DIV_3	0x00010000 -#define PLLMR_OPB_PLB_DIV_4	0x00018000 - -#define PLLMR_PCI_TO_PLB_MASK	0x00006000	/* PCI:PLB Frequency Divisor */ -#define PLLMR_PCI_PLB_DIV_1	0x00000000 -#define PLLMR_PCI_PLB_DIV_2	0x00002000 -#define PLLMR_PCI_PLB_DIV_3	0x00004000 -#define PLLMR_PCI_PLB_DIV_4	0x00006000 - -#define PLLMR_EXB_TO_PLB_MASK	0x00001800	/* External Bus:PLB Divisor */ -#define PLLMR_EXB_PLB_DIV_2	0x00000000 -#define PLLMR_EXB_PLB_DIV_3	0x00000800 -#define PLLMR_EXB_PLB_DIV_4	0x00001000 -#define PLLMR_EXB_PLB_DIV_5	0x00001800 - -/* definitions for PPC405GPr (new mode strapping) */ -#define PLLMR_FWDB_DIV_MASK	0x00000007	/* Forward Divisor B */ - -#define PSR_PLL_FWD_MASK	0xC0000000 -#define PSR_PLL_FDBACK_MASK	0x30000000 -#define PSR_PLL_TUNING_MASK	0x0E000000 -#define PSR_PLB_CPU_MASK	0x01800000 -#define PSR_OPB_PLB_MASK	0x00600000 -#define PSR_PCI_PLB_MASK	0x00180000 -#define PSR_EB_PLB_MASK		0x00060000 -#define PSR_ROM_WIDTH_MASK	0x00018000 -#define PSR_ROM_LOC		0x00004000 -#define PSR_PCI_ASYNC_EN	0x00001000 -#define PSR_PERCLK_SYNC_MODE_EN 0x00000800	/* PPC405GPr only */ -#define PSR_PCI_ARBIT_EN	0x00000400 -#define PSR_NEW_MODE_EN		0x00000020	/* PPC405GPr only */ - -#endif /* _PPC405CR_H_ */ diff --git a/arch/powerpc/include/asm/ppc440.h b/arch/powerpc/include/asm/ppc440.h index 411d441a2..0f5bc8d1c 100644 --- a/arch/powerpc/include/asm/ppc440.h +++ b/arch/powerpc/include/asm/ppc440.h @@ -1,26 +1,3 @@ -/*----------------------------------------------------------------------------+ -|   This source code is dual-licensed.  You may use it under the terms of the -|   GNU General Public License version 2, or under the license below. -| -|	This source code has been made available to you by IBM on an AS-IS -|	basis.	Anyone receiving this source is licensed under IBM -|	copyrights to use it in any way he or she deems fit, including -|	copying it, modifying it, compiling it, and redistributing it either -|	with or without modifications.	No license under IBM patents or -|	patent applications is to be implied by the copyright license. -| -|	Any user of this software should understand that IBM cannot provide -|	technical support for this software and will not be responsible for -|	any consequences resulting from the use of this software. -| -|	Any person who transfers this source code or any derivative work -|	must include the IBM copyright notice, this paragraph, and the -|	preceding two paragraphs in the transferred software. -| -|	COPYRIGHT   I B M   CORPORATION 1999 -|	LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M -+----------------------------------------------------------------------------*/ -  /*   * (C) Copyright 2006   * Sylvie Gohl,             AMCC/IBM, gohl.sylvie@fr.ibm.com @@ -32,7 +9,7 @@   * (C) Copyright 2010   * Stefan Roese, DENX Software Engineering, sr@denx.de.   * - * SPDX-License-Identifier:	GPL-2.0+ + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs   */  #ifndef __PPC440_H__ diff --git a/arch/powerpc/include/asm/ppc4xx-ebc.h b/arch/powerpc/include/asm/ppc4xx-ebc.h index 9eb50ee84..32062fd41 100644 --- a/arch/powerpc/include/asm/ppc4xx-ebc.h +++ b/arch/powerpc/include/asm/ppc4xx-ebc.h @@ -14,12 +14,12 @@   * Within this group there is a slight variation concerning the bit field   * position of the EMPL and EMPH fields:   */ -#if defined(CONFIG_405CR) || defined(CONFIG_405GP) || \ +#if defined(CONFIG_405GP) || \      defined(CONFIG_405EP) || \      defined(CONFIG_440EP) || defined(CONFIG_440GR) || \      defined(CONFIG_440EPX) || defined(CONFIG_440GRX)  #define CONFIG_EBC_PPC4xx_IBM_VER1 -#if defined(CONFIG_405CR) || defined(CONFIG_405GP) || \ +#if defined(CONFIG_405GP) || \      defined(CONFIG_405EP)  #define EBC_CFG_EMPH_POS	8  #define EBC_CFG_EMPL_POS	6 @@ -32,7 +32,7 @@  /*   * Define the max number of EBC banks (chip selects)   */ -#if defined(CONFIG_405CR) || defined(CONFIG_405GP) || \ +#if defined(CONFIG_405GP) || \      defined(CONFIG_405EZ) || \      defined(CONFIG_440GP) || defined(CONFIG_440GX)  #define EBC_NUM_BANKS	8 diff --git a/arch/powerpc/include/asm/ppc4xx-emac.h b/arch/powerpc/include/asm/ppc4xx-emac.h index a219fa97f..e6eb33222 100644 --- a/arch/powerpc/include/asm/ppc4xx-emac.h +++ b/arch/powerpc/include/asm/ppc4xx-emac.h @@ -1,25 +1,6 @@ -/*----------------------------------------------------------------------------+ -|   This source code is dual-licensed.  You may use it under the terms of the -|   GNU General Public License version 2, or under the license below. -| -|	This source code has been made available to you by IBM on an AS-IS -|	basis.	Anyone receiving this source is licensed under IBM -|	copyrights to use it in any way he or she deems fit, including -|	copying it, modifying it, compiling it, and redistributing it either -|	with or without modifications.	No license under IBM patents or -|	patent applications is to be implied by the copyright license. -| -|	Any user of this software should understand that IBM cannot provide -|	technical support for this software and will not be responsible for -|	any consequences resulting from the use of this software. -| -|	Any person who transfers this source code or any derivative work -|	must include the IBM copyright notice, this paragraph, and the -|	preceding two paragraphs in the transferred software. -| -|	COPYRIGHT   I B M   CORPORATION 1999 -|	LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M -+----------------------------------------------------------------------------*/ +/* + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs + */  /*----------------------------------------------------------------------------+  |  |  File Name:	enetemac.h diff --git a/arch/powerpc/include/asm/ppc4xx-mal.h b/arch/powerpc/include/asm/ppc4xx-mal.h index 71986856b..d15290dc1 100644 --- a/arch/powerpc/include/asm/ppc4xx-mal.h +++ b/arch/powerpc/include/asm/ppc4xx-mal.h @@ -1,26 +1,7 @@  /* include/mal.h, openbios_walnut, walnut_bios 8/6/99 08:48:40 */ -/*----------------------------------------------------------------------------+ -|   This source code is dual-licensed.  You may use it under the terms of the -|   GNU General Public License version 2, or under the license below. -| -|	This source code has been made available to you by IBM on an AS-IS -|	basis.	Anyone receiving this source is licensed under IBM -|	copyrights to use it in any way he or she deems fit, including -|	copying it, modifying it, compiling it, and redistributing it either -|	with or without modifications.	No license under IBM patents or -|	patent applications is to be implied by the copyright license. -| -|	Any user of this software should understand that IBM cannot provide -|	technical support for this software and will not be responsible for -|	any consequences resulting from the use of this software. -| -|	Any person who transfers this source code or any derivative work -|	must include the IBM copyright notice, this paragraph, and the -|	preceding two paragraphs in the transferred software. -| -|	COPYRIGHT   I B M   CORPORATION 1999 -|	LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M -+----------------------------------------------------------------------------*/ +/* + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs + */  /*----------------------------------------------------------------------------+  |  |  File Name:	mal.h diff --git a/arch/powerpc/include/asm/ppc4xx.h b/arch/powerpc/include/asm/ppc4xx.h index 9f2a08b8b..8d703c663 100644 --- a/arch/powerpc/include/asm/ppc4xx.h +++ b/arch/powerpc/include/asm/ppc4xx.h @@ -1,25 +1,6 @@ -/*----------------------------------------------------------------------------+ -|       This source code is dual-licensed.  You may use it under the terms of -|       the GNU General Public License version 2, or under the license below. -| -|       This source code has been made available to you by IBM on an AS-IS -|       basis.  Anyone receiving this source is licensed under IBM -|       copyrights to use it in any way he or she deems fit, including -|       copying it, modifying it, compiling it, and redistributing it either -|       with or without modifications.  No license under IBM patents or -|       patent applications is to be implied by the copyright license. -| -|       Any user of this software should understand that IBM cannot provide -|       technical support for this software and will not be responsible for -|       any consequences resulting from the use of this software. -| -|       Any person who transfers this source code or any derivative work -|       must include the IBM copyright notice, this paragraph, and the -|       preceding two paragraphs in the transferred software. -| -|       COPYRIGHT   I B M   CORPORATION 1999 -|       LICENSED MATERIAL  -  PROGRAM PROPERTY OF I B M -+----------------------------------------------------------------------------*/ +/* + * SPDX-License-Identifier:	GPL-2.0	ibm-pibs + */  #ifndef	__PPC4XX_H__  #define __PPC4XX_H__ @@ -27,10 +8,6 @@  /*   * Include SoC specific headers   */ -#if defined(CONFIG_405CR) -#include <asm/ppc405cr.h> -#endif -  #if defined(CONFIG_405EP)  #include <asm/ppc405ep.h>  #endif diff --git a/arch/powerpc/include/asm/processor.h b/arch/powerpc/include/asm/processor.h index 56b22d840..c0fb51993 100644 --- a/arch/powerpc/include/asm/processor.h +++ b/arch/powerpc/include/asm/processor.h @@ -847,7 +847,7 @@  /* System-On-Chip Version Register (SVR) field extraction */  #define SVR_VER(svr)	(((svr) >> 16) & 0xFFFF) /* Version field */ -#define SVR_REV(svr)	(((svr) >>  0) & 0xFFFF) /* Revision field */ +#define SVR_REV(svr)	(((svr) >>  0) & 0xFF)	 /* Revision field */  #define SVR_CID(svr)	(((svr) >> 28) & 0x0F)	 /* Company or manufacturer ID */  #define SVR_SOCOP(svr)	(((svr) >> 22) & 0x3F)	 /* SOC integration options */ @@ -894,9 +894,6 @@  #define PVR_405GP_RC	0x40110082  #define PVR_405GP_RD	0x401100C4  #define PVR_405GP_RE	0x40110145  /* same as pc405cr rev c */ -#define PVR_405CR_RA	0x40110041 -#define PVR_405CR_RB	0x401100C5 -#define PVR_405CR_RC	0x40110145  /* same as pc405gp rev e */  #define PVR_405EP_RA	0x51210950  #define PVR_405GPR_RB	0x50910951  #define PVR_405EZ_RA	0x41511460 @@ -1043,9 +1040,6 @@  /* System Version Register (SVR) field extraction */ -#define SVR_VER(svr)	(((svr) >>  16) & 0xFFFF)	/* Version field */ -#define SVR_REV(svr)	(((svr) >>   0) & 0xFFFF)	/* Revison field */ -  #define SVR_SUBVER(svr)	(((svr) >>  8) & 0xFF)	/* Process/MFG sub-version */  #define SVR_FAM(svr)	(((svr) >> 20) & 0xFFF)	/* Family field */ @@ -1119,6 +1113,9 @@  #define SVR_T4240	0x824000  #define SVR_T4120	0x824001  #define SVR_T4160	0x824100 +#define SVR_C291	0x850000 +#define SVR_C292	0x850020 +#define SVR_C293	0x850030  #define SVR_B4860	0X868000  #define SVR_G4860	0x868001  #define SVR_G4060	0x868003 diff --git a/arch/powerpc/include/asm/u-boot.h b/arch/powerpc/include/asm/u-boot.h index f17b146da..5916f7ce9 100644 --- a/arch/powerpc/include/asm/u-boot.h +++ b/arch/powerpc/include/asm/u-boot.h @@ -67,7 +67,6 @@ typedef struct bd_info {  	unsigned int	bi_baudrate;	/* Console Baudrate */  #if defined(CONFIG_405)   || \      defined(CONFIG_405GP) || \ -    defined(CONFIG_405CR) || \      defined(CONFIG_405EP) || \      defined(CONFIG_405EZ) || \      defined(CONFIG_405EX) || \ diff --git a/arch/x86/cpu/coreboot/tables.c b/arch/x86/cpu/coreboot/tables.c index b116d5955..0d91adc5e 100644 --- a/arch/x86/cpu/coreboot/tables.c +++ b/arch/x86/cpu/coreboot/tables.c @@ -4,28 +4,7 @@   * Copyright (C) 2008 Advanced Micro Devices, Inc.   * Copyright (C) 2009 coresystems GmbH   * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - *    notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - *    notice, this list of conditions and the following disclaimer in the - *    documentation and/or other materials provided with the distribution. - * 3. The name of the author may not be used to endorse or promote products - *    derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. + * SPDX-License-Identifier:	BSD-3-Clause   */  #include <common.h> diff --git a/arch/x86/include/asm/arch-coreboot/sysinfo.h b/arch/x86/include/asm/arch-coreboot/sysinfo.h index 78d3a9d49..8e4a61de7 100644 --- a/arch/x86/include/asm/arch-coreboot/sysinfo.h +++ b/arch/x86/include/asm/arch-coreboot/sysinfo.h @@ -3,28 +3,7 @@   *   * Copyright (C) 2008 Advanced Micro Devices, Inc.   * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - *    notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - *    notice, this list of conditions and the following disclaimer in the - *    documentation and/or other materials provided with the distribution. - * 3. The name of the author may not be used to endorse or promote products - *    derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. + * SPDX-License-Identifier:	BSD-3-Clause   */  #ifndef _COREBOOT_SYSINFO_H diff --git a/arch/x86/include/asm/arch-coreboot/tables.h b/arch/x86/include/asm/arch-coreboot/tables.h index ad34a8b0f..0d02fe059 100644 --- a/arch/x86/include/asm/arch-coreboot/tables.h +++ b/arch/x86/include/asm/arch-coreboot/tables.h @@ -3,28 +3,7 @@   *   * Copyright (C) 2008 Advanced Micro Devices, Inc.   * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - *    notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - *    notice, this list of conditions and the following disclaimer in the - *    documentation and/or other materials provided with the distribution. - * 3. The name of the author may not be used to endorse or promote products - *    derived from this software without specific prior written permission. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. + * SPDX-License-Identifier:	BSD-3-Clause   */  #ifndef _COREBOOT_TABLES_H |