183d290c5STom Rini // SPDX-License-Identifier: GPL-2.0+
2601fbec7SMasahiro Yamada /*
3601fbec7SMasahiro Yamada  * SoC-specific lowlevel code for DA850
4601fbec7SMasahiro Yamada  *
5601fbec7SMasahiro Yamada  * Copyright (C) 2011
6601fbec7SMasahiro Yamada  * Heiko Schocher, DENX Software Engineering, hs@denx.de.
7601fbec7SMasahiro Yamada  */
8601fbec7SMasahiro Yamada #include <common.h>
9601fbec7SMasahiro Yamada #include <nand.h>
10601fbec7SMasahiro Yamada #include <ns16550.h>
11601fbec7SMasahiro Yamada #include <post.h>
12601fbec7SMasahiro Yamada #include <asm/arch/da850_lowlevel.h>
13601fbec7SMasahiro Yamada #include <asm/arch/hardware.h>
14601fbec7SMasahiro Yamada #include <asm/arch/davinci_misc.h>
15601fbec7SMasahiro Yamada #include <asm/arch/ddr2_defs.h>
16601fbec7SMasahiro Yamada #include <asm/ti-common/davinci_nand.h>
17601fbec7SMasahiro Yamada #include <asm/arch/pll_defs.h>
18601fbec7SMasahiro Yamada 
davinci_enable_uart0(void)19601fbec7SMasahiro Yamada void davinci_enable_uart0(void)
20601fbec7SMasahiro Yamada {
21601fbec7SMasahiro Yamada 	lpsc_on(DAVINCI_LPSC_UART0);
22601fbec7SMasahiro Yamada 
23601fbec7SMasahiro Yamada 	/* Bringup UART0 out of reset */
24601fbec7SMasahiro Yamada 	REG(UART0_PWREMU_MGMT) = 0x00006001;
25601fbec7SMasahiro Yamada }
26601fbec7SMasahiro Yamada 
27601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_PLL_INIT)
da850_waitloop(unsigned long loopcnt)28601fbec7SMasahiro Yamada static void da850_waitloop(unsigned long loopcnt)
29601fbec7SMasahiro Yamada {
30601fbec7SMasahiro Yamada 	unsigned long	i;
31601fbec7SMasahiro Yamada 
32601fbec7SMasahiro Yamada 	for (i = 0; i < loopcnt; i++)
33601fbec7SMasahiro Yamada 		asm("   NOP");
34601fbec7SMasahiro Yamada }
35601fbec7SMasahiro Yamada 
da850_pll_init(struct davinci_pllc_regs * reg,unsigned long pllmult)36601fbec7SMasahiro Yamada static int da850_pll_init(struct davinci_pllc_regs *reg, unsigned long pllmult)
37601fbec7SMasahiro Yamada {
38601fbec7SMasahiro Yamada 	if (reg == davinci_pllc0_regs)
39601fbec7SMasahiro Yamada 		/* Unlock PLL registers. */
40601fbec7SMasahiro Yamada 		clrbits_le32(&davinci_syscfg_regs->cfgchip0, PLL_MASTER_LOCK);
41601fbec7SMasahiro Yamada 
42601fbec7SMasahiro Yamada 	/*
43601fbec7SMasahiro Yamada 	 * Set PLLENSRC '0',bit 5, PLL Enable(PLLEN) selection is controlled
44601fbec7SMasahiro Yamada 	 * through MMR
45601fbec7SMasahiro Yamada 	 */
46601fbec7SMasahiro Yamada 	clrbits_le32(&reg->pllctl, PLLCTL_PLLENSRC);
47601fbec7SMasahiro Yamada 	/* PLLCTL.EXTCLKSRC bit 9 should be left at 0 for Freon */
48601fbec7SMasahiro Yamada 	clrbits_le32(&reg->pllctl, PLLCTL_EXTCLKSRC);
49601fbec7SMasahiro Yamada 
50601fbec7SMasahiro Yamada 	/* Set PLLEN=0 => PLL BYPASS MODE */
51601fbec7SMasahiro Yamada 	clrbits_le32(&reg->pllctl, PLLCTL_PLLEN);
52601fbec7SMasahiro Yamada 
53601fbec7SMasahiro Yamada 	da850_waitloop(150);
54601fbec7SMasahiro Yamada 
55601fbec7SMasahiro Yamada 	if (reg == davinci_pllc0_regs) {
56601fbec7SMasahiro Yamada 		/*
57601fbec7SMasahiro Yamada 		 * Select the Clock Mode bit 8 as External Clock or On Chip
58601fbec7SMasahiro Yamada 		 * Oscilator
59601fbec7SMasahiro Yamada 		 */
60601fbec7SMasahiro Yamada 		dv_maskbits(&reg->pllctl, ~PLLCTL_RES_9);
61601fbec7SMasahiro Yamada 		setbits_le32(&reg->pllctl,
62601fbec7SMasahiro Yamada 			(CONFIG_SYS_DV_CLKMODE << PLLCTL_CLOCK_MODE_SHIFT));
63601fbec7SMasahiro Yamada 	}
64601fbec7SMasahiro Yamada 
65601fbec7SMasahiro Yamada 	/* Clear PLLRST bit to reset the PLL */
66601fbec7SMasahiro Yamada 	clrbits_le32(&reg->pllctl, PLLCTL_PLLRST);
67601fbec7SMasahiro Yamada 
68601fbec7SMasahiro Yamada 	/* Disable the PLL output */
69601fbec7SMasahiro Yamada 	setbits_le32(&reg->pllctl, PLLCTL_PLLDIS);
70601fbec7SMasahiro Yamada 
71601fbec7SMasahiro Yamada 	/* PLL initialization sequence */
72601fbec7SMasahiro Yamada 	/*
73601fbec7SMasahiro Yamada 	 * Power up the PLL- PWRDN bit set to 0 to bring the PLL out of
74601fbec7SMasahiro Yamada 	 * power down bit
75601fbec7SMasahiro Yamada 	 */
76601fbec7SMasahiro Yamada 	clrbits_le32(&reg->pllctl, PLLCTL_PLLPWRDN);
77601fbec7SMasahiro Yamada 
78601fbec7SMasahiro Yamada 	/* Enable the PLL from Disable Mode PLLDIS bit to 0 */
79601fbec7SMasahiro Yamada 	clrbits_le32(&reg->pllctl, PLLCTL_PLLDIS);
80601fbec7SMasahiro Yamada 
81601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_PLL0_PREDIV)
82601fbec7SMasahiro Yamada 	/* program the prediv */
83601fbec7SMasahiro Yamada 	if (reg == davinci_pllc0_regs && CONFIG_SYS_DA850_PLL0_PREDIV)
84601fbec7SMasahiro Yamada 		writel((PLL_DIVEN | CONFIG_SYS_DA850_PLL0_PREDIV),
85601fbec7SMasahiro Yamada 			&reg->prediv);
86601fbec7SMasahiro Yamada #endif
87601fbec7SMasahiro Yamada 
88601fbec7SMasahiro Yamada 	/* Program the required multiplier value in PLLM */
89601fbec7SMasahiro Yamada 	writel(pllmult, &reg->pllm);
90601fbec7SMasahiro Yamada 
91601fbec7SMasahiro Yamada 	/* program the postdiv */
92601fbec7SMasahiro Yamada 	if (reg == davinci_pllc0_regs)
93601fbec7SMasahiro Yamada 		writel((PLL_POSTDEN | CONFIG_SYS_DA850_PLL0_POSTDIV),
94601fbec7SMasahiro Yamada 			&reg->postdiv);
95601fbec7SMasahiro Yamada 	else
96601fbec7SMasahiro Yamada 		writel((PLL_POSTDEN | CONFIG_SYS_DA850_PLL1_POSTDIV),
97601fbec7SMasahiro Yamada 			&reg->postdiv);
98601fbec7SMasahiro Yamada 
99601fbec7SMasahiro Yamada 	/*
100601fbec7SMasahiro Yamada 	 * Check for the GOSTAT bit in PLLSTAT to clear to 0 to indicate that
101601fbec7SMasahiro Yamada 	 * no GO operation is currently in progress
102601fbec7SMasahiro Yamada 	 */
103601fbec7SMasahiro Yamada 	while ((readl(&reg->pllstat) & PLLCMD_GOSTAT) == PLLCMD_GOSTAT)
104601fbec7SMasahiro Yamada 		;
105601fbec7SMasahiro Yamada 
106601fbec7SMasahiro Yamada 	if (reg == davinci_pllc0_regs) {
107601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV1, &reg->plldiv1);
108601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV2, &reg->plldiv2);
109601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV3, &reg->plldiv3);
110601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV4, &reg->plldiv4);
111601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV5, &reg->plldiv5);
112601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV6, &reg->plldiv6);
113601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL0_PLLDIV7, &reg->plldiv7);
114601fbec7SMasahiro Yamada 	} else {
115601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL1_PLLDIV1, &reg->plldiv1);
116601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL1_PLLDIV2, &reg->plldiv2);
117601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_PLL1_PLLDIV3, &reg->plldiv3);
118601fbec7SMasahiro Yamada 	}
119601fbec7SMasahiro Yamada 
120601fbec7SMasahiro Yamada 	/*
121601fbec7SMasahiro Yamada 	 * Set the GOSET bit in PLLCMD to 1 to initiate a new divider
122601fbec7SMasahiro Yamada 	 * transition.
123601fbec7SMasahiro Yamada 	 */
124601fbec7SMasahiro Yamada 	setbits_le32(&reg->pllcmd, PLLCMD_GOSTAT);
125601fbec7SMasahiro Yamada 
126601fbec7SMasahiro Yamada 	/*
127601fbec7SMasahiro Yamada 	 * Wait for the GOSTAT bit in PLLSTAT to clear to 0
128601fbec7SMasahiro Yamada 	 * (completion of phase alignment).
129601fbec7SMasahiro Yamada 	 */
130601fbec7SMasahiro Yamada 	while ((readl(&reg->pllstat) & PLLCMD_GOSTAT) == PLLCMD_GOSTAT)
131601fbec7SMasahiro Yamada 		;
132601fbec7SMasahiro Yamada 
133601fbec7SMasahiro Yamada 	/* Wait for PLL to reset properly. See PLL spec for PLL reset time */
134601fbec7SMasahiro Yamada 	da850_waitloop(200);
135601fbec7SMasahiro Yamada 
136601fbec7SMasahiro Yamada 	/* Set the PLLRST bit in PLLCTL to 1 to bring the PLL out of reset */
137601fbec7SMasahiro Yamada 	setbits_le32(&reg->pllctl, PLLCTL_PLLRST);
138601fbec7SMasahiro Yamada 
139601fbec7SMasahiro Yamada 	/* Wait for PLL to lock. See PLL spec for PLL lock time */
140601fbec7SMasahiro Yamada 	da850_waitloop(2400);
141601fbec7SMasahiro Yamada 
142601fbec7SMasahiro Yamada 	/*
143601fbec7SMasahiro Yamada 	 * Set the PLLEN bit in PLLCTL to 1 to remove the PLL from bypass
144601fbec7SMasahiro Yamada 	 * mode
145601fbec7SMasahiro Yamada 	 */
146601fbec7SMasahiro Yamada 	setbits_le32(&reg->pllctl, PLLCTL_PLLEN);
147601fbec7SMasahiro Yamada 
148601fbec7SMasahiro Yamada 
149601fbec7SMasahiro Yamada 	/*
150601fbec7SMasahiro Yamada 	 * clear EMIFA and EMIFB clock source settings, let them
151601fbec7SMasahiro Yamada 	 * run off SYSCLK
152601fbec7SMasahiro Yamada 	 */
153601fbec7SMasahiro Yamada 	if (reg == davinci_pllc0_regs)
154601fbec7SMasahiro Yamada 		dv_maskbits(&davinci_syscfg_regs->cfgchip3,
155601fbec7SMasahiro Yamada 			~(PLL_SCSCFG3_DIV45PENA | PLL_SCSCFG3_EMA_CLKSRC));
156601fbec7SMasahiro Yamada 
157601fbec7SMasahiro Yamada 	return 0;
158601fbec7SMasahiro Yamada }
159601fbec7SMasahiro Yamada #endif /* CONFIG_SYS_DA850_PLL_INIT */
160601fbec7SMasahiro Yamada 
161601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_DDR_INIT)
da850_ddr_setup(void)162601fbec7SMasahiro Yamada static int da850_ddr_setup(void)
163601fbec7SMasahiro Yamada {
164601fbec7SMasahiro Yamada 	unsigned long	tmp;
165601fbec7SMasahiro Yamada 
166601fbec7SMasahiro Yamada 	/* Enable the Clock to DDR2/mDDR */
167601fbec7SMasahiro Yamada 	lpsc_on(DAVINCI_LPSC_DDR_EMIF);
168601fbec7SMasahiro Yamada 
169601fbec7SMasahiro Yamada 	tmp = readl(&davinci_syscfg1_regs->vtpio_ctl);
170601fbec7SMasahiro Yamada 	if ((tmp & VTP_POWERDWN) == VTP_POWERDWN) {
171601fbec7SMasahiro Yamada 		/* Begin VTP Calibration */
172601fbec7SMasahiro Yamada 		clrbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_POWERDWN);
173601fbec7SMasahiro Yamada 		clrbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_LOCK);
174601fbec7SMasahiro Yamada 		setbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_CLKRZ);
175601fbec7SMasahiro Yamada 		clrbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_CLKRZ);
176601fbec7SMasahiro Yamada 		setbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_CLKRZ);
177601fbec7SMasahiro Yamada 
178601fbec7SMasahiro Yamada 		/* Polling READY bit to see when VTP calibration is done */
179601fbec7SMasahiro Yamada 		tmp = readl(&davinci_syscfg1_regs->vtpio_ctl);
180601fbec7SMasahiro Yamada 		while ((tmp & VTP_READY) != VTP_READY)
181601fbec7SMasahiro Yamada 			tmp = readl(&davinci_syscfg1_regs->vtpio_ctl);
182601fbec7SMasahiro Yamada 
183601fbec7SMasahiro Yamada 		setbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_LOCK);
184601fbec7SMasahiro Yamada 		setbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_POWERDWN);
185601fbec7SMasahiro Yamada 	}
186601fbec7SMasahiro Yamada 	setbits_le32(&davinci_syscfg1_regs->vtpio_ctl, VTP_IOPWRDWN);
187601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_DDR2_DDRPHYCR, &dv_ddr2_regs_ctrl->ddrphycr);
188601fbec7SMasahiro Yamada 
189601fbec7SMasahiro Yamada 	if (CONFIG_SYS_DA850_DDR2_SDBCR & (1 << DV_DDR_SDCR_DDR2EN_SHIFT)) {
190601fbec7SMasahiro Yamada 		/* DDR2 */
191601fbec7SMasahiro Yamada 		clrbits_le32(&davinci_syscfg1_regs->ddr_slew,
192601fbec7SMasahiro Yamada 			(1 << DDR_SLEW_DDR_PDENA_BIT) |
193601fbec7SMasahiro Yamada 			(1 << DDR_SLEW_CMOSEN_BIT));
194601fbec7SMasahiro Yamada 	} else {
195601fbec7SMasahiro Yamada 		/* MOBILE DDR */
196601fbec7SMasahiro Yamada 		setbits_le32(&davinci_syscfg1_regs->ddr_slew,
197601fbec7SMasahiro Yamada 			(1 << DDR_SLEW_DDR_PDENA_BIT) |
198601fbec7SMasahiro Yamada 			(1 << DDR_SLEW_CMOSEN_BIT));
199601fbec7SMasahiro Yamada 	}
200601fbec7SMasahiro Yamada 
201601fbec7SMasahiro Yamada 	/*
202601fbec7SMasahiro Yamada 	 * SDRAM Configuration Register (SDCR):
203601fbec7SMasahiro Yamada 	 * First set the BOOTUNLOCK bit to make configuration bits
204601fbec7SMasahiro Yamada 	 * writeable.
205601fbec7SMasahiro Yamada 	 */
206601fbec7SMasahiro Yamada 	setbits_le32(&dv_ddr2_regs_ctrl->sdbcr, DV_DDR_BOOTUNLOCK);
207601fbec7SMasahiro Yamada 
208601fbec7SMasahiro Yamada 	/*
209601fbec7SMasahiro Yamada 	 * Write the new value of these bits and clear BOOTUNLOCK.
210601fbec7SMasahiro Yamada 	 * At the same time, set the TIMUNLOCK bit to allow changing
211601fbec7SMasahiro Yamada 	 * the timing registers
212601fbec7SMasahiro Yamada 	 */
213601fbec7SMasahiro Yamada 	tmp = CONFIG_SYS_DA850_DDR2_SDBCR;
214601fbec7SMasahiro Yamada 	tmp &= ~DV_DDR_BOOTUNLOCK;
215601fbec7SMasahiro Yamada 	tmp |= DV_DDR_TIMUNLOCK;
216601fbec7SMasahiro Yamada 	writel(tmp, &dv_ddr2_regs_ctrl->sdbcr);
217601fbec7SMasahiro Yamada 
218601fbec7SMasahiro Yamada 	/* write memory configuration and timing */
219601fbec7SMasahiro Yamada 	if (!(CONFIG_SYS_DA850_DDR2_SDBCR & (1 << DV_DDR_SDCR_DDR2EN_SHIFT))) {
220601fbec7SMasahiro Yamada 		/* MOBILE DDR only*/
221601fbec7SMasahiro Yamada 		writel(CONFIG_SYS_DA850_DDR2_SDBCR2,
222601fbec7SMasahiro Yamada 			&dv_ddr2_regs_ctrl->sdbcr2);
223601fbec7SMasahiro Yamada 	}
224601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_DDR2_SDTIMR, &dv_ddr2_regs_ctrl->sdtimr);
225601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_DDR2_SDTIMR2, &dv_ddr2_regs_ctrl->sdtimr2);
226601fbec7SMasahiro Yamada 
227601fbec7SMasahiro Yamada 	/* clear the TIMUNLOCK bit and write the value of the CL field */
228601fbec7SMasahiro Yamada 	tmp &= ~DV_DDR_TIMUNLOCK;
229601fbec7SMasahiro Yamada 	writel(tmp, &dv_ddr2_regs_ctrl->sdbcr);
230601fbec7SMasahiro Yamada 
231601fbec7SMasahiro Yamada 	/*
232601fbec7SMasahiro Yamada 	 * LPMODEN and MCLKSTOPEN must be set!
233601fbec7SMasahiro Yamada 	 * Without this bits set, PSC don;t switch states !!
234601fbec7SMasahiro Yamada 	 */
235601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_DDR2_SDRCR |
236601fbec7SMasahiro Yamada 		(1 << DV_DDR_SRCR_LPMODEN_SHIFT) |
237601fbec7SMasahiro Yamada 		(1 << DV_DDR_SRCR_MCLKSTOPEN_SHIFT),
238601fbec7SMasahiro Yamada 		&dv_ddr2_regs_ctrl->sdrcr);
239601fbec7SMasahiro Yamada 
240601fbec7SMasahiro Yamada 	/* SyncReset the Clock to EMIF3A SDRAM */
241601fbec7SMasahiro Yamada 	lpsc_syncreset(DAVINCI_LPSC_DDR_EMIF);
242601fbec7SMasahiro Yamada 	/* Enable the Clock to EMIF3A SDRAM */
243601fbec7SMasahiro Yamada 	lpsc_on(DAVINCI_LPSC_DDR_EMIF);
244601fbec7SMasahiro Yamada 
245601fbec7SMasahiro Yamada 	/* disable self refresh */
246601fbec7SMasahiro Yamada 	clrbits_le32(&dv_ddr2_regs_ctrl->sdrcr,
247601fbec7SMasahiro Yamada 		DV_DDR_SDRCR_LPMODEN | DV_DDR_SDRCR_MCLKSTOPEN);
248601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_DDR2_PBBPR, &dv_ddr2_regs_ctrl->pbbpr);
249601fbec7SMasahiro Yamada 
250601fbec7SMasahiro Yamada 	return 0;
251601fbec7SMasahiro Yamada }
252601fbec7SMasahiro Yamada #endif /* CONFIG_SYS_DA850_DDR_INIT */
253601fbec7SMasahiro Yamada 
254601fbec7SMasahiro Yamada __attribute__((weak))
board_gpio_init(void)255601fbec7SMasahiro Yamada void board_gpio_init(void)
256601fbec7SMasahiro Yamada {
257601fbec7SMasahiro Yamada 	return;
258601fbec7SMasahiro Yamada }
259601fbec7SMasahiro Yamada 
arch_cpu_init(void)260601fbec7SMasahiro Yamada int arch_cpu_init(void)
261601fbec7SMasahiro Yamada {
262601fbec7SMasahiro Yamada 	/* Unlock kick registers */
263601fbec7SMasahiro Yamada 	writel(DV_SYSCFG_KICK0_UNLOCK, &davinci_syscfg_regs->kick0);
264601fbec7SMasahiro Yamada 	writel(DV_SYSCFG_KICK1_UNLOCK, &davinci_syscfg_regs->kick1);
265601fbec7SMasahiro Yamada 
266601fbec7SMasahiro Yamada 	dv_maskbits(&davinci_syscfg_regs->suspsrc,
267601fbec7SMasahiro Yamada 		CONFIG_SYS_DA850_SYSCFG_SUSPSRC);
268601fbec7SMasahiro Yamada 
269601fbec7SMasahiro Yamada 	/* configure pinmux settings */
270601fbec7SMasahiro Yamada 	if (davinci_configure_pin_mux_items(pinmuxes, pinmuxes_size))
271601fbec7SMasahiro Yamada 		return 1;
272601fbec7SMasahiro Yamada 
273601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_PLL_INIT)
274601fbec7SMasahiro Yamada 	/* PLL setup */
275601fbec7SMasahiro Yamada 	da850_pll_init(davinci_pllc0_regs, CONFIG_SYS_DA850_PLL0_PLLM);
276601fbec7SMasahiro Yamada 	da850_pll_init(davinci_pllc1_regs, CONFIG_SYS_DA850_PLL1_PLLM);
277601fbec7SMasahiro Yamada #endif
278601fbec7SMasahiro Yamada 	/* setup CSn config */
279601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_CS2CFG)
280601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_CS2CFG, &davinci_emif_regs->ab1cr);
281601fbec7SMasahiro Yamada #endif
282601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_CS3CFG)
283601fbec7SMasahiro Yamada 	writel(CONFIG_SYS_DA850_CS3CFG, &davinci_emif_regs->ab2cr);
284601fbec7SMasahiro Yamada #endif
285601fbec7SMasahiro Yamada 
286601fbec7SMasahiro Yamada 	da8xx_configure_lpsc_items(lpsc, lpsc_size);
287601fbec7SMasahiro Yamada 
288601fbec7SMasahiro Yamada 	/* GPIO setup */
289601fbec7SMasahiro Yamada 	board_gpio_init();
290601fbec7SMasahiro Yamada 
291*973fcc8dSAdam Ford #if !CONFIG_IS_ENABLED(DM_SERIAL)
292601fbec7SMasahiro Yamada 	NS16550_init((NS16550_t)(CONFIG_SYS_NS16550_COM1),
293601fbec7SMasahiro Yamada 			CONFIG_SYS_NS16550_CLK / 16 / CONFIG_BAUDRATE);
294*973fcc8dSAdam Ford #endif
295601fbec7SMasahiro Yamada 	/*
296601fbec7SMasahiro Yamada 	 * Fix Power and Emulation Management Register
297601fbec7SMasahiro Yamada 	 * see sprufw3a.pdf page 37 Table 24
298601fbec7SMasahiro Yamada 	 */
299601fbec7SMasahiro Yamada 	writel((DAVINCI_UART_PWREMU_MGMT_FREE | DAVINCI_UART_PWREMU_MGMT_URRST |
300601fbec7SMasahiro Yamada 		DAVINCI_UART_PWREMU_MGMT_UTRST),
301601fbec7SMasahiro Yamada #if (CONFIG_SYS_NS16550_COM1 == DAVINCI_UART0_BASE)
302601fbec7SMasahiro Yamada 	       &davinci_uart0_ctrl_regs->pwremu_mgmt);
303601fbec7SMasahiro Yamada #else
304601fbec7SMasahiro Yamada 	       &davinci_uart2_ctrl_regs->pwremu_mgmt);
305601fbec7SMasahiro Yamada #endif
306601fbec7SMasahiro Yamada 
307601fbec7SMasahiro Yamada #if defined(CONFIG_SYS_DA850_DDR_INIT)
308601fbec7SMasahiro Yamada 	da850_ddr_setup();
309601fbec7SMasahiro Yamada #endif
310601fbec7SMasahiro Yamada 
311601fbec7SMasahiro Yamada 	return 0;
312601fbec7SMasahiro Yamada }
313