xref: /openbmc/u-boot/arch/arm/mach-omap2/omap5/hwinit.c (revision d87f82967fc90ca23672451f55eeb2a36f2f36c7)
1983e3700STom Rini /*
2983e3700STom Rini  *
3983e3700STom Rini  * Functions for omap5 based boards.
4983e3700STom Rini  *
5983e3700STom Rini  * (C) Copyright 2011
6983e3700STom Rini  * Texas Instruments, <www.ti.com>
7983e3700STom Rini  *
8983e3700STom Rini  * Author :
9983e3700STom Rini  *	Aneesh V	<aneesh@ti.com>
10983e3700STom Rini  *	Steve Sakoman	<steve@sakoman.com>
11983e3700STom Rini  *	Sricharan	<r.sricharan@ti.com>
12983e3700STom Rini  *
13983e3700STom Rini  * SPDX-License-Identifier:	GPL-2.0+
14983e3700STom Rini  */
15983e3700STom Rini #include <common.h>
16b4b06006SLokesh Vutla #include <palmas.h>
17983e3700STom Rini #include <asm/armv7.h>
18983e3700STom Rini #include <asm/arch/cpu.h>
19983e3700STom Rini #include <asm/arch/sys_proto.h>
20983e3700STom Rini #include <asm/arch/clock.h>
21983e3700STom Rini #include <linux/sizes.h>
22983e3700STom Rini #include <asm/utils.h>
23983e3700STom Rini #include <asm/arch/gpio.h>
24983e3700STom Rini #include <asm/emif.h>
25983e3700STom Rini #include <asm/omap_common.h>
26983e3700STom Rini 
27983e3700STom Rini DECLARE_GLOBAL_DATA_PTR;
28983e3700STom Rini 
29983e3700STom Rini u32 *const omap_si_rev = (u32 *)OMAP_SRAM_SCRATCH_OMAP_REV;
30983e3700STom Rini 
31983e3700STom Rini #ifndef CONFIG_DM_GPIO
32983e3700STom Rini static struct gpio_bank gpio_bank_54xx[8] = {
33983e3700STom Rini 	{ (void *)OMAP54XX_GPIO1_BASE },
34983e3700STom Rini 	{ (void *)OMAP54XX_GPIO2_BASE },
35983e3700STom Rini 	{ (void *)OMAP54XX_GPIO3_BASE },
36983e3700STom Rini 	{ (void *)OMAP54XX_GPIO4_BASE },
37983e3700STom Rini 	{ (void *)OMAP54XX_GPIO5_BASE },
38983e3700STom Rini 	{ (void *)OMAP54XX_GPIO6_BASE },
39983e3700STom Rini 	{ (void *)OMAP54XX_GPIO7_BASE },
40983e3700STom Rini 	{ (void *)OMAP54XX_GPIO8_BASE },
41983e3700STom Rini };
42983e3700STom Rini 
43983e3700STom Rini const struct gpio_bank *const omap_gpio_bank = gpio_bank_54xx;
44983e3700STom Rini #endif
45983e3700STom Rini 
46983e3700STom Rini void do_set_mux32(u32 base, struct pad_conf_entry const *array, int size)
47983e3700STom Rini {
48983e3700STom Rini 	int i;
49983e3700STom Rini 	struct pad_conf_entry *pad = (struct pad_conf_entry *)array;
50983e3700STom Rini 
51983e3700STom Rini 	for (i = 0; i < size; i++, pad++)
52983e3700STom Rini 		writel(pad->val, base + pad->offset);
53983e3700STom Rini }
54983e3700STom Rini 
55983e3700STom Rini #ifdef CONFIG_SPL_BUILD
56983e3700STom Rini /* LPDDR2 specific IO settings */
57983e3700STom Rini static void io_settings_lpddr2(void)
58983e3700STom Rini {
59983e3700STom Rini 	const struct ctrl_ioregs *ioregs;
60983e3700STom Rini 
61983e3700STom Rini 	get_ioregs(&ioregs);
62983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_0);
63983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_1);
64983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_0);
65983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_1);
66983e3700STom Rini 	writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_0);
67983e3700STom Rini 	writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_1);
68983e3700STom Rini 	writel(ioregs->ctrl_ddrio_0, (*ctrl)->control_ddrio_0);
69983e3700STom Rini 	writel(ioregs->ctrl_ddrio_1, (*ctrl)->control_ddrio_1);
70983e3700STom Rini 	writel(ioregs->ctrl_ddrio_2, (*ctrl)->control_ddrio_2);
71983e3700STom Rini }
72983e3700STom Rini 
73983e3700STom Rini /* DDR3 specific IO settings */
74983e3700STom Rini static void io_settings_ddr3(void)
75983e3700STom Rini {
76983e3700STom Rini 	u32 io_settings = 0;
77983e3700STom Rini 	const struct ctrl_ioregs *ioregs;
78983e3700STom Rini 
79983e3700STom Rini 	get_ioregs(&ioregs);
80983e3700STom Rini 	writel(ioregs->ctrl_ddr3ch, (*ctrl)->control_ddr3ch1_0);
81983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_0);
82983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_1);
83983e3700STom Rini 
84983e3700STom Rini 	writel(ioregs->ctrl_ddr3ch, (*ctrl)->control_ddr3ch2_0);
85983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_0);
86983e3700STom Rini 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_1);
87983e3700STom Rini 
88983e3700STom Rini 	writel(ioregs->ctrl_ddrio_0, (*ctrl)->control_ddrio_0);
89983e3700STom Rini 	writel(ioregs->ctrl_ddrio_1, (*ctrl)->control_ddrio_1);
90983e3700STom Rini 
91983e3700STom Rini 	if (!is_dra7xx()) {
92983e3700STom Rini 		writel(ioregs->ctrl_ddrio_2, (*ctrl)->control_ddrio_2);
93983e3700STom Rini 		writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_1);
94983e3700STom Rini 	}
95983e3700STom Rini 
96983e3700STom Rini 	/* omap5432 does not use lpddr2 */
97983e3700STom Rini 	writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_0);
98983e3700STom Rini 
99983e3700STom Rini 	writel(ioregs->ctrl_emif_sdram_config_ext,
100983e3700STom Rini 	       (*ctrl)->control_emif1_sdram_config_ext);
101983e3700STom Rini 	if (!is_dra72x())
102983e3700STom Rini 		writel(ioregs->ctrl_emif_sdram_config_ext,
103983e3700STom Rini 		       (*ctrl)->control_emif2_sdram_config_ext);
104983e3700STom Rini 
105983e3700STom Rini 	if (is_omap54xx()) {
106983e3700STom Rini 		/* Disable DLL select */
107983e3700STom Rini 		io_settings = (readl((*ctrl)->control_port_emif1_sdram_config)
108983e3700STom Rini 							& 0xFFEFFFFF);
109983e3700STom Rini 		writel(io_settings,
110983e3700STom Rini 			(*ctrl)->control_port_emif1_sdram_config);
111983e3700STom Rini 
112983e3700STom Rini 		io_settings = (readl((*ctrl)->control_port_emif2_sdram_config)
113983e3700STom Rini 							& 0xFFEFFFFF);
114983e3700STom Rini 		writel(io_settings,
115983e3700STom Rini 			(*ctrl)->control_port_emif2_sdram_config);
116983e3700STom Rini 	} else {
117983e3700STom Rini 		writel(ioregs->ctrl_ddr_ctrl_ext_0,
118983e3700STom Rini 				(*ctrl)->control_ddr_control_ext_0);
119983e3700STom Rini 	}
120983e3700STom Rini }
121983e3700STom Rini 
122983e3700STom Rini /*
123983e3700STom Rini  * Some tuning of IOs for optimal power and performance
124983e3700STom Rini  */
125983e3700STom Rini void do_io_settings(void)
126983e3700STom Rini {
127983e3700STom Rini 	u32 io_settings = 0, mask = 0;
128983e3700STom Rini 	struct emif_reg_struct *emif = (struct emif_reg_struct *)EMIF1_BASE;
129983e3700STom Rini 
130983e3700STom Rini 	/* Impedance settings EMMC, C2C 1,2, hsi2 */
131983e3700STom Rini 	mask = (ds_mask << 2) | (ds_mask << 8) |
132983e3700STom Rini 		(ds_mask << 16) | (ds_mask << 18);
133983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart1io_padconf_0) &
134983e3700STom Rini 				(~mask);
135983e3700STom Rini 	io_settings |= (ds_60_ohm << 8) | (ds_45_ohm << 16) |
136983e3700STom Rini 			(ds_45_ohm << 18) | (ds_60_ohm << 2);
137983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart1io_padconf_0);
138983e3700STom Rini 
139983e3700STom Rini 	/* Impedance settings Mcspi2 */
140983e3700STom Rini 	mask = (ds_mask << 30);
141983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart1io_padconf_1) &
142983e3700STom Rini 			(~mask);
143983e3700STom Rini 	io_settings |= (ds_60_ohm << 30);
144983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart1io_padconf_1);
145983e3700STom Rini 
146983e3700STom Rini 	/* Impedance settings C2C 3,4 */
147983e3700STom Rini 	mask = (ds_mask << 14) | (ds_mask << 16);
148983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart1io_padconf_2) &
149983e3700STom Rini 			(~mask);
150983e3700STom Rini 	io_settings |= (ds_45_ohm << 14) | (ds_45_ohm << 16);
151983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart1io_padconf_2);
152983e3700STom Rini 
153983e3700STom Rini 	/* Slew rate settings EMMC, C2C 1,2 */
154983e3700STom Rini 	mask = (sc_mask << 8) | (sc_mask << 16) | (sc_mask << 18);
155983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart2io_padconf_0) &
156983e3700STom Rini 			(~mask);
157983e3700STom Rini 	io_settings |= (sc_fast << 8) | (sc_na << 16) | (sc_na << 18);
158983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart2io_padconf_0);
159983e3700STom Rini 
160983e3700STom Rini 	/* Slew rate settings hsi2, Mcspi2 */
161983e3700STom Rini 	mask = (sc_mask << 24) | (sc_mask << 28);
162983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart2io_padconf_1) &
163983e3700STom Rini 			(~mask);
164983e3700STom Rini 	io_settings |= (sc_fast << 28) | (sc_fast << 24);
165983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart2io_padconf_1);
166983e3700STom Rini 
167983e3700STom Rini 	/* Slew rate settings C2C 3,4 */
168983e3700STom Rini 	mask = (sc_mask << 16) | (sc_mask << 18);
169983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart2io_padconf_2) &
170983e3700STom Rini 			(~mask);
171983e3700STom Rini 	io_settings |= (sc_na << 16) | (sc_na << 18);
172983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart2io_padconf_2);
173983e3700STom Rini 
174983e3700STom Rini 	/* impedance and slew rate settings for usb */
175983e3700STom Rini 	mask = (usb_i_mask << 29) | (usb_i_mask << 26) | (usb_i_mask << 23) |
176983e3700STom Rini 		(usb_i_mask << 20) | (usb_i_mask << 17) | (usb_i_mask << 14);
177983e3700STom Rini 	io_settings = readl((*ctrl)->control_smart3io_padconf_1) &
178983e3700STom Rini 			(~mask);
179983e3700STom Rini 	io_settings |= (ds_60_ohm << 29) | (ds_60_ohm << 26) |
180983e3700STom Rini 		       (ds_60_ohm << 23) | (sc_fast << 20) |
181983e3700STom Rini 		       (sc_fast << 17) | (sc_fast << 14);
182983e3700STom Rini 	writel(io_settings, (*ctrl)->control_smart3io_padconf_1);
183983e3700STom Rini 
184983e3700STom Rini 	if (emif_sdram_type(emif->emif_sdram_config) == EMIF_SDRAM_TYPE_LPDDR2)
185983e3700STom Rini 		io_settings_lpddr2();
186983e3700STom Rini 	else
187983e3700STom Rini 		io_settings_ddr3();
188983e3700STom Rini }
189983e3700STom Rini 
190983e3700STom Rini static const struct srcomp_params srcomp_parameters[NUM_SYS_CLKS] = {
191983e3700STom Rini 	{0x45, 0x1},	/* 12 MHz   */
192983e3700STom Rini 	{-1, -1},	/* 13 MHz   */
193983e3700STom Rini 	{0x63, 0x2},	/* 16.8 MHz */
194983e3700STom Rini 	{0x57, 0x2},	/* 19.2 MHz */
195983e3700STom Rini 	{0x20, 0x1},	/* 26 MHz   */
196983e3700STom Rini 	{-1, -1},	/* 27 MHz   */
197983e3700STom Rini 	{0x41, 0x3}	/* 38.4 MHz */
198983e3700STom Rini };
199983e3700STom Rini 
200983e3700STom Rini void srcomp_enable(void)
201983e3700STom Rini {
202983e3700STom Rini 	u32 srcomp_value, mul_factor, div_factor, clk_val, i;
203983e3700STom Rini 	u32 sysclk_ind	= get_sys_clk_index();
204983e3700STom Rini 	u32 omap_rev	= omap_revision();
205983e3700STom Rini 
206983e3700STom Rini 	if (!is_omap54xx())
207983e3700STom Rini 		return;
208983e3700STom Rini 
209983e3700STom Rini 	mul_factor = srcomp_parameters[sysclk_ind].multiply_factor;
210983e3700STom Rini 	div_factor = srcomp_parameters[sysclk_ind].divide_factor;
211983e3700STom Rini 
212983e3700STom Rini 	for (i = 0; i < 4; i++) {
213983e3700STom Rini 		srcomp_value = readl((*ctrl)->control_srcomp_north_side + i*4);
214983e3700STom Rini 		srcomp_value &=
215983e3700STom Rini 			~(MULTIPLY_FACTOR_XS_MASK | DIVIDE_FACTOR_XS_MASK);
216983e3700STom Rini 		srcomp_value |= (mul_factor << MULTIPLY_FACTOR_XS_SHIFT) |
217983e3700STom Rini 			(div_factor << DIVIDE_FACTOR_XS_SHIFT);
218983e3700STom Rini 		writel(srcomp_value, (*ctrl)->control_srcomp_north_side + i*4);
219983e3700STom Rini 	}
220983e3700STom Rini 
221983e3700STom Rini 	if ((omap_rev == OMAP5430_ES1_0) || (omap_rev == OMAP5432_ES1_0)) {
222983e3700STom Rini 		clk_val = readl((*prcm)->cm_coreaon_io_srcomp_clkctrl);
223983e3700STom Rini 		clk_val |= OPTFCLKEN_SRCOMP_FCLK_MASK;
224983e3700STom Rini 		writel(clk_val, (*prcm)->cm_coreaon_io_srcomp_clkctrl);
225983e3700STom Rini 
226983e3700STom Rini 		for (i = 0; i < 4; i++) {
227983e3700STom Rini 			srcomp_value =
228983e3700STom Rini 				readl((*ctrl)->control_srcomp_north_side + i*4);
229983e3700STom Rini 			srcomp_value &= ~PWRDWN_XS_MASK;
230983e3700STom Rini 			writel(srcomp_value,
231983e3700STom Rini 			       (*ctrl)->control_srcomp_north_side + i*4);
232983e3700STom Rini 
233983e3700STom Rini 			while (((readl((*ctrl)->control_srcomp_north_side + i*4)
234983e3700STom Rini 				& SRCODE_READ_XS_MASK) >>
235983e3700STom Rini 				SRCODE_READ_XS_SHIFT) == 0)
236983e3700STom Rini 				;
237983e3700STom Rini 
238983e3700STom Rini 			srcomp_value =
239983e3700STom Rini 				readl((*ctrl)->control_srcomp_north_side + i*4);
240983e3700STom Rini 			srcomp_value &= ~OVERRIDE_XS_MASK;
241983e3700STom Rini 			writel(srcomp_value,
242983e3700STom Rini 			       (*ctrl)->control_srcomp_north_side + i*4);
243983e3700STom Rini 		}
244983e3700STom Rini 	} else {
245983e3700STom Rini 		srcomp_value = readl((*ctrl)->control_srcomp_east_side_wkup);
246983e3700STom Rini 		srcomp_value &= ~(MULTIPLY_FACTOR_XS_MASK |
247983e3700STom Rini 				  DIVIDE_FACTOR_XS_MASK);
248983e3700STom Rini 		srcomp_value |= (mul_factor << MULTIPLY_FACTOR_XS_SHIFT) |
249983e3700STom Rini 				(div_factor << DIVIDE_FACTOR_XS_SHIFT);
250983e3700STom Rini 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
251983e3700STom Rini 
252983e3700STom Rini 		for (i = 0; i < 4; i++) {
253983e3700STom Rini 			srcomp_value =
254983e3700STom Rini 				readl((*ctrl)->control_srcomp_north_side + i*4);
255983e3700STom Rini 			srcomp_value |= SRCODE_OVERRIDE_SEL_XS_MASK;
256983e3700STom Rini 			writel(srcomp_value,
257983e3700STom Rini 			       (*ctrl)->control_srcomp_north_side + i*4);
258983e3700STom Rini 
259983e3700STom Rini 			srcomp_value =
260983e3700STom Rini 				readl((*ctrl)->control_srcomp_north_side + i*4);
261983e3700STom Rini 			srcomp_value &= ~OVERRIDE_XS_MASK;
262983e3700STom Rini 			writel(srcomp_value,
263983e3700STom Rini 			       (*ctrl)->control_srcomp_north_side + i*4);
264983e3700STom Rini 		}
265983e3700STom Rini 
266983e3700STom Rini 		srcomp_value =
267983e3700STom Rini 			readl((*ctrl)->control_srcomp_east_side_wkup);
268983e3700STom Rini 		srcomp_value |= SRCODE_OVERRIDE_SEL_XS_MASK;
269983e3700STom Rini 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
270983e3700STom Rini 
271983e3700STom Rini 		srcomp_value =
272983e3700STom Rini 			readl((*ctrl)->control_srcomp_east_side_wkup);
273983e3700STom Rini 		srcomp_value &= ~OVERRIDE_XS_MASK;
274983e3700STom Rini 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
275983e3700STom Rini 
276983e3700STom Rini 		clk_val = readl((*prcm)->cm_coreaon_io_srcomp_clkctrl);
277983e3700STom Rini 		clk_val |= OPTFCLKEN_SRCOMP_FCLK_MASK;
278983e3700STom Rini 		writel(clk_val, (*prcm)->cm_coreaon_io_srcomp_clkctrl);
279983e3700STom Rini 
280983e3700STom Rini 		clk_val = readl((*prcm)->cm_wkupaon_io_srcomp_clkctrl);
281983e3700STom Rini 		clk_val |= OPTFCLKEN_SRCOMP_FCLK_MASK;
282983e3700STom Rini 		writel(clk_val, (*prcm)->cm_wkupaon_io_srcomp_clkctrl);
283983e3700STom Rini 
284983e3700STom Rini 		for (i = 0; i < 4; i++) {
285983e3700STom Rini 			while (((readl((*ctrl)->control_srcomp_north_side + i*4)
286983e3700STom Rini 				& SRCODE_READ_XS_MASK) >>
287983e3700STom Rini 				SRCODE_READ_XS_SHIFT) == 0)
288983e3700STom Rini 				;
289983e3700STom Rini 
290983e3700STom Rini 			srcomp_value =
291983e3700STom Rini 				readl((*ctrl)->control_srcomp_north_side + i*4);
292983e3700STom Rini 			srcomp_value &= ~SRCODE_OVERRIDE_SEL_XS_MASK;
293983e3700STom Rini 			writel(srcomp_value,
294983e3700STom Rini 			       (*ctrl)->control_srcomp_north_side + i*4);
295983e3700STom Rini 		}
296983e3700STom Rini 
297983e3700STom Rini 		while (((readl((*ctrl)->control_srcomp_east_side_wkup) &
298983e3700STom Rini 			SRCODE_READ_XS_MASK) >> SRCODE_READ_XS_SHIFT) == 0)
299983e3700STom Rini 			;
300983e3700STom Rini 
301983e3700STom Rini 		srcomp_value =
302983e3700STom Rini 			readl((*ctrl)->control_srcomp_east_side_wkup);
303983e3700STom Rini 		srcomp_value &= ~SRCODE_OVERRIDE_SEL_XS_MASK;
304983e3700STom Rini 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
305983e3700STom Rini 	}
306983e3700STom Rini }
307983e3700STom Rini #endif
308983e3700STom Rini 
309983e3700STom Rini void config_data_eye_leveling_samples(u32 emif_base)
310983e3700STom Rini {
311983e3700STom Rini 	const struct ctrl_ioregs *ioregs;
312983e3700STom Rini 
313983e3700STom Rini 	get_ioregs(&ioregs);
314983e3700STom Rini 
315983e3700STom Rini 	/*EMIF_SDRAM_CONFIG_EXT-Read data eye leveling no of samples =4*/
316983e3700STom Rini 	if (emif_base == EMIF1_BASE)
317983e3700STom Rini 		writel(ioregs->ctrl_emif_sdram_config_ext_final,
318983e3700STom Rini 		       (*ctrl)->control_emif1_sdram_config_ext);
319983e3700STom Rini 	else if (emif_base == EMIF2_BASE)
320983e3700STom Rini 		writel(ioregs->ctrl_emif_sdram_config_ext_final,
321983e3700STom Rini 		       (*ctrl)->control_emif2_sdram_config_ext);
322983e3700STom Rini }
323983e3700STom Rini 
324983e3700STom Rini void init_cpu_configuration(void)
325983e3700STom Rini {
326983e3700STom Rini 	u32 l2actlr;
327983e3700STom Rini 
328983e3700STom Rini 	asm volatile("mrc p15, 1, %0, c15, c0, 0" : "=r"(l2actlr));
329983e3700STom Rini 	/*
330983e3700STom Rini 	 * L2ACTLR: Ensure to enable the following:
331983e3700STom Rini 	 * 3: Disable clean/evict push to external
332983e3700STom Rini 	 * 4: Disable WriteUnique and WriteLineUnique transactions from master
333983e3700STom Rini 	 * 8: Disable DVM/CMO message broadcast
334983e3700STom Rini 	 */
335983e3700STom Rini 	l2actlr |= 0x118;
336983e3700STom Rini 	omap_smc1(OMAP5_SERVICE_L2ACTLR_SET, l2actlr);
337983e3700STom Rini }
338983e3700STom Rini 
339983e3700STom Rini void init_omap_revision(void)
340983e3700STom Rini {
341983e3700STom Rini 	/*
342983e3700STom Rini 	 * For some of the ES2/ES1 boards ID_CODE is not reliable:
343983e3700STom Rini 	 * Also, ES1 and ES2 have different ARM revisions
344983e3700STom Rini 	 * So use ARM revision for identification
345983e3700STom Rini 	 */
346983e3700STom Rini 	unsigned int rev = cortex_rev();
347983e3700STom Rini 
348983e3700STom Rini 	switch (readl(CONTROL_ID_CODE)) {
349983e3700STom Rini 	case OMAP5430_CONTROL_ID_CODE_ES1_0:
350983e3700STom Rini 		*omap_si_rev = OMAP5430_ES1_0;
351983e3700STom Rini 		if (rev == MIDR_CORTEX_A15_R2P2)
352983e3700STom Rini 			*omap_si_rev = OMAP5430_ES2_0;
353983e3700STom Rini 		break;
354983e3700STom Rini 	case OMAP5432_CONTROL_ID_CODE_ES1_0:
355983e3700STom Rini 		*omap_si_rev = OMAP5432_ES1_0;
356983e3700STom Rini 		if (rev == MIDR_CORTEX_A15_R2P2)
357983e3700STom Rini 			*omap_si_rev = OMAP5432_ES2_0;
358983e3700STom Rini 		break;
359983e3700STom Rini 	case OMAP5430_CONTROL_ID_CODE_ES2_0:
360983e3700STom Rini 		*omap_si_rev = OMAP5430_ES2_0;
361983e3700STom Rini 		break;
362983e3700STom Rini 	case OMAP5432_CONTROL_ID_CODE_ES2_0:
363983e3700STom Rini 		*omap_si_rev = OMAP5432_ES2_0;
364983e3700STom Rini 		break;
365983e3700STom Rini 	case DRA752_CONTROL_ID_CODE_ES1_0:
366983e3700STom Rini 		*omap_si_rev = DRA752_ES1_0;
367983e3700STom Rini 		break;
368983e3700STom Rini 	case DRA752_CONTROL_ID_CODE_ES1_1:
369983e3700STom Rini 		*omap_si_rev = DRA752_ES1_1;
370983e3700STom Rini 		break;
371983e3700STom Rini 	case DRA752_CONTROL_ID_CODE_ES2_0:
372983e3700STom Rini 		*omap_si_rev = DRA752_ES2_0;
373983e3700STom Rini 		break;
374983e3700STom Rini 	case DRA722_CONTROL_ID_CODE_ES1_0:
375983e3700STom Rini 		*omap_si_rev = DRA722_ES1_0;
376983e3700STom Rini 		break;
377983e3700STom Rini 	case DRA722_CONTROL_ID_CODE_ES2_0:
378983e3700STom Rini 		*omap_si_rev = DRA722_ES2_0;
379983e3700STom Rini 		break;
380983e3700STom Rini 	default:
381983e3700STom Rini 		*omap_si_rev = OMAP5430_SILICON_ID_INVALID;
382983e3700STom Rini 	}
383983e3700STom Rini 	init_cpu_configuration();
384983e3700STom Rini }
385983e3700STom Rini 
386983e3700STom Rini void omap_die_id(unsigned int *die_id)
387983e3700STom Rini {
388983e3700STom Rini 	die_id[0] = readl((*ctrl)->control_std_fuse_die_id_0);
389983e3700STom Rini 	die_id[1] = readl((*ctrl)->control_std_fuse_die_id_1);
390983e3700STom Rini 	die_id[2] = readl((*ctrl)->control_std_fuse_die_id_2);
391983e3700STom Rini 	die_id[3] = readl((*ctrl)->control_std_fuse_die_id_3);
392983e3700STom Rini }
393983e3700STom Rini 
394983e3700STom Rini void reset_cpu(ulong ignored)
395983e3700STom Rini {
396983e3700STom Rini 	u32 omap_rev = omap_revision();
397983e3700STom Rini 
398983e3700STom Rini 	/*
399983e3700STom Rini 	 * WARM reset is not functional in case of OMAP5430 ES1.0 soc.
400983e3700STom Rini 	 * So use cold reset in case instead.
401983e3700STom Rini 	 */
402983e3700STom Rini 	if (omap_rev == OMAP5430_ES1_0)
403983e3700STom Rini 		writel(PRM_RSTCTRL_RESET << 0x1, (*prcm)->prm_rstctrl);
404983e3700STom Rini 	else
405983e3700STom Rini 		writel(PRM_RSTCTRL_RESET, (*prcm)->prm_rstctrl);
406983e3700STom Rini }
407983e3700STom Rini 
408983e3700STom Rini u32 warm_reset(void)
409983e3700STom Rini {
410983e3700STom Rini 	return readl((*prcm)->prm_rstst) & PRM_RSTST_WARM_RESET_MASK;
411983e3700STom Rini }
412983e3700STom Rini 
413983e3700STom Rini void setup_warmreset_time(void)
414983e3700STom Rini {
415983e3700STom Rini 	u32 rst_time, rst_val;
416983e3700STom Rini 
417*d87f8296STom Rini 	/*
418*d87f8296STom Rini 	 * MAX value for PRM_RSTTIME[9:0]RSTTIME1 stored is 0x3ff.
419*d87f8296STom Rini 	 * 0x3ff is in the no of FUNC_32K_CLK cycles. Converting cycles
420*d87f8296STom Rini 	 * into microsec and passing the value.
421*d87f8296STom Rini 	 */
422*d87f8296STom Rini 	rst_time = usec_to_32k(CONFIG_OMAP_PLATFORM_RESET_TIME_MAX_USEC)
423*d87f8296STom Rini 		<< RSTTIME1_SHIFT;
424983e3700STom Rini 
425983e3700STom Rini 	if (rst_time > RSTTIME1_MASK)
426983e3700STom Rini 		rst_time = RSTTIME1_MASK;
427983e3700STom Rini 
428983e3700STom Rini 	rst_val = readl((*prcm)->prm_rsttime) & ~RSTTIME1_MASK;
429983e3700STom Rini 	rst_val |= rst_time;
430983e3700STom Rini 	writel(rst_val, (*prcm)->prm_rsttime);
431983e3700STom Rini }
432983e3700STom Rini 
433983e3700STom Rini void v7_arch_cp15_set_l2aux_ctrl(u32 l2auxctrl, u32 cpu_midr,
434983e3700STom Rini 				 u32 cpu_rev_comb, u32 cpu_variant,
435983e3700STom Rini 				 u32 cpu_rev)
436983e3700STom Rini {
437983e3700STom Rini 	omap_smc1(OMAP5_SERVICE_L2ACTLR_SET, l2auxctrl);
438983e3700STom Rini }
439983e3700STom Rini 
440983e3700STom Rini void v7_arch_cp15_set_acr(u32 acr, u32 cpu_midr, u32 cpu_rev_comb,
441983e3700STom Rini 			  u32 cpu_variant, u32 cpu_rev)
442983e3700STom Rini {
443983e3700STom Rini 
444983e3700STom Rini #ifdef CONFIG_ARM_ERRATA_801819
445983e3700STom Rini 	/*
446983e3700STom Rini 	 * DRA72x processors are uniprocessors and DONOT have
447983e3700STom Rini 	 * ACP (Accelerator Coherency Port) hooked to ACE (AXI Coherency
448983e3700STom Rini 	 * Extensions) Hence the erratum workaround is not applicable for
449983e3700STom Rini 	 * DRA72x processors.
450983e3700STom Rini 	 */
451983e3700STom Rini 	if (is_dra72x())
452983e3700STom Rini 		acr &= ~((0x3 << 23) | (0x3 << 25));
453983e3700STom Rini #endif
454983e3700STom Rini 	omap_smc1(OMAP5_SERVICE_ACR_SET, acr);
455983e3700STom Rini }
456b4b06006SLokesh Vutla 
457b4b06006SLokesh Vutla #if defined(CONFIG_PALMAS_POWER)
458b4b06006SLokesh Vutla void vmmc_pbias_config(uint voltage)
459b4b06006SLokesh Vutla {
460b4b06006SLokesh Vutla 	u32 value = 0;
461b4b06006SLokesh Vutla 	struct vcores_data const *vcores = *omap_vcores;
462b4b06006SLokesh Vutla 
463b4b06006SLokesh Vutla 	value = readl((*ctrl)->control_pbias);
464b4b06006SLokesh Vutla 	value &= ~SDCARD_PWRDNZ;
465b4b06006SLokesh Vutla 	writel(value, (*ctrl)->control_pbias);
466b4b06006SLokesh Vutla 	udelay(10); /* wait 10 us */
467b4b06006SLokesh Vutla 	value &= ~SDCARD_BIAS_PWRDNZ;
468b4b06006SLokesh Vutla 	writel(value, (*ctrl)->control_pbias);
469b4b06006SLokesh Vutla 
470b4b06006SLokesh Vutla 	if (vcores->core.pmic->i2c_slave_addr == 0x60) {
471b4b06006SLokesh Vutla 		if (voltage == LDO_VOLT_3V0)
472b4b06006SLokesh Vutla 			voltage = 0x19;
473b4b06006SLokesh Vutla 		else if (voltage == LDO_VOLT_1V8)
474b4b06006SLokesh Vutla 			voltage = 0xa;
475b4b06006SLokesh Vutla 		lp873x_mmc1_poweron_ldo(voltage);
476b4b06006SLokesh Vutla 	} else {
477b4b06006SLokesh Vutla 		palmas_mmc1_poweron_ldo(voltage);
478b4b06006SLokesh Vutla 	}
479b4b06006SLokesh Vutla 
480b4b06006SLokesh Vutla 	value = readl((*ctrl)->control_pbias);
481b4b06006SLokesh Vutla 	value |= SDCARD_BIAS_PWRDNZ;
482b4b06006SLokesh Vutla 	writel(value, (*ctrl)->control_pbias);
483b4b06006SLokesh Vutla 	udelay(150); /* wait 150 us */
484b4b06006SLokesh Vutla 	value |= SDCARD_PWRDNZ;
485b4b06006SLokesh Vutla 	writel(value, (*ctrl)->control_pbias);
486b4b06006SLokesh Vutla 	udelay(150); /* wait 150 us */
487b4b06006SLokesh Vutla }
488b4b06006SLokesh Vutla #endif
489