xref: /OK3568_Linux_fs/u-boot/arch/arm/mach-omap2/omap5/hwinit.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  *
3*4882a593Smuzhiyun  * Functions for omap5 based boards.
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  * (C) Copyright 2011
6*4882a593Smuzhiyun  * Texas Instruments, <www.ti.com>
7*4882a593Smuzhiyun  *
8*4882a593Smuzhiyun  * Author :
9*4882a593Smuzhiyun  *	Aneesh V	<aneesh@ti.com>
10*4882a593Smuzhiyun  *	Steve Sakoman	<steve@sakoman.com>
11*4882a593Smuzhiyun  *	Sricharan	<r.sricharan@ti.com>
12*4882a593Smuzhiyun  *
13*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0+
14*4882a593Smuzhiyun  */
15*4882a593Smuzhiyun #include <common.h>
16*4882a593Smuzhiyun #include <palmas.h>
17*4882a593Smuzhiyun #include <asm/armv7.h>
18*4882a593Smuzhiyun #include <asm/arch/cpu.h>
19*4882a593Smuzhiyun #include <asm/arch/sys_proto.h>
20*4882a593Smuzhiyun #include <asm/arch/clock.h>
21*4882a593Smuzhiyun #include <linux/sizes.h>
22*4882a593Smuzhiyun #include <asm/utils.h>
23*4882a593Smuzhiyun #include <asm/arch/gpio.h>
24*4882a593Smuzhiyun #include <asm/emif.h>
25*4882a593Smuzhiyun #include <asm/omap_common.h>
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun DECLARE_GLOBAL_DATA_PTR;
28*4882a593Smuzhiyun 
29*4882a593Smuzhiyun u32 *const omap_si_rev = (u32 *)OMAP_SRAM_SCRATCH_OMAP_REV;
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun #ifndef CONFIG_DM_GPIO
32*4882a593Smuzhiyun static struct gpio_bank gpio_bank_54xx[8] = {
33*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO1_BASE },
34*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO2_BASE },
35*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO3_BASE },
36*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO4_BASE },
37*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO5_BASE },
38*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO6_BASE },
39*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO7_BASE },
40*4882a593Smuzhiyun 	{ (void *)OMAP54XX_GPIO8_BASE },
41*4882a593Smuzhiyun };
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun const struct gpio_bank *const omap_gpio_bank = gpio_bank_54xx;
44*4882a593Smuzhiyun #endif
45*4882a593Smuzhiyun 
do_set_mux32(u32 base,struct pad_conf_entry const * array,int size)46*4882a593Smuzhiyun void do_set_mux32(u32 base, struct pad_conf_entry const *array, int size)
47*4882a593Smuzhiyun {
48*4882a593Smuzhiyun 	int i;
49*4882a593Smuzhiyun 	struct pad_conf_entry *pad = (struct pad_conf_entry *)array;
50*4882a593Smuzhiyun 
51*4882a593Smuzhiyun 	for (i = 0; i < size; i++, pad++)
52*4882a593Smuzhiyun 		writel(pad->val, base + pad->offset);
53*4882a593Smuzhiyun }
54*4882a593Smuzhiyun 
55*4882a593Smuzhiyun #ifdef CONFIG_SPL_BUILD
56*4882a593Smuzhiyun /* LPDDR2 specific IO settings */
io_settings_lpddr2(void)57*4882a593Smuzhiyun static void io_settings_lpddr2(void)
58*4882a593Smuzhiyun {
59*4882a593Smuzhiyun 	const struct ctrl_ioregs *ioregs;
60*4882a593Smuzhiyun 
61*4882a593Smuzhiyun 	get_ioregs(&ioregs);
62*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_0);
63*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_1);
64*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_0);
65*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_1);
66*4882a593Smuzhiyun 	writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_0);
67*4882a593Smuzhiyun 	writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_1);
68*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrio_0, (*ctrl)->control_ddrio_0);
69*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrio_1, (*ctrl)->control_ddrio_1);
70*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrio_2, (*ctrl)->control_ddrio_2);
71*4882a593Smuzhiyun }
72*4882a593Smuzhiyun 
73*4882a593Smuzhiyun /* DDR3 specific IO settings */
io_settings_ddr3(void)74*4882a593Smuzhiyun static void io_settings_ddr3(void)
75*4882a593Smuzhiyun {
76*4882a593Smuzhiyun 	u32 io_settings = 0;
77*4882a593Smuzhiyun 	const struct ctrl_ioregs *ioregs;
78*4882a593Smuzhiyun 
79*4882a593Smuzhiyun 	get_ioregs(&ioregs);
80*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddr3ch, (*ctrl)->control_ddr3ch1_0);
81*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_0);
82*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch1_1);
83*4882a593Smuzhiyun 
84*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddr3ch, (*ctrl)->control_ddr3ch2_0);
85*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_0);
86*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrch, (*ctrl)->control_ddrch2_1);
87*4882a593Smuzhiyun 
88*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrio_0, (*ctrl)->control_ddrio_0);
89*4882a593Smuzhiyun 	writel(ioregs->ctrl_ddrio_1, (*ctrl)->control_ddrio_1);
90*4882a593Smuzhiyun 
91*4882a593Smuzhiyun 	if (!is_dra7xx()) {
92*4882a593Smuzhiyun 		writel(ioregs->ctrl_ddrio_2, (*ctrl)->control_ddrio_2);
93*4882a593Smuzhiyun 		writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_1);
94*4882a593Smuzhiyun 	}
95*4882a593Smuzhiyun 
96*4882a593Smuzhiyun 	/* omap5432 does not use lpddr2 */
97*4882a593Smuzhiyun 	writel(ioregs->ctrl_lpddr2ch, (*ctrl)->control_lpddr2ch1_0);
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun 	writel(ioregs->ctrl_emif_sdram_config_ext,
100*4882a593Smuzhiyun 	       (*ctrl)->control_emif1_sdram_config_ext);
101*4882a593Smuzhiyun 	if (!is_dra72x())
102*4882a593Smuzhiyun 		writel(ioregs->ctrl_emif_sdram_config_ext,
103*4882a593Smuzhiyun 		       (*ctrl)->control_emif2_sdram_config_ext);
104*4882a593Smuzhiyun 
105*4882a593Smuzhiyun 	if (is_omap54xx()) {
106*4882a593Smuzhiyun 		/* Disable DLL select */
107*4882a593Smuzhiyun 		io_settings = (readl((*ctrl)->control_port_emif1_sdram_config)
108*4882a593Smuzhiyun 							& 0xFFEFFFFF);
109*4882a593Smuzhiyun 		writel(io_settings,
110*4882a593Smuzhiyun 			(*ctrl)->control_port_emif1_sdram_config);
111*4882a593Smuzhiyun 
112*4882a593Smuzhiyun 		io_settings = (readl((*ctrl)->control_port_emif2_sdram_config)
113*4882a593Smuzhiyun 							& 0xFFEFFFFF);
114*4882a593Smuzhiyun 		writel(io_settings,
115*4882a593Smuzhiyun 			(*ctrl)->control_port_emif2_sdram_config);
116*4882a593Smuzhiyun 	} else {
117*4882a593Smuzhiyun 		writel(ioregs->ctrl_ddr_ctrl_ext_0,
118*4882a593Smuzhiyun 				(*ctrl)->control_ddr_control_ext_0);
119*4882a593Smuzhiyun 	}
120*4882a593Smuzhiyun }
121*4882a593Smuzhiyun 
122*4882a593Smuzhiyun /*
123*4882a593Smuzhiyun  * Some tuning of IOs for optimal power and performance
124*4882a593Smuzhiyun  */
do_io_settings(void)125*4882a593Smuzhiyun void do_io_settings(void)
126*4882a593Smuzhiyun {
127*4882a593Smuzhiyun 	u32 io_settings = 0, mask = 0;
128*4882a593Smuzhiyun 	struct emif_reg_struct *emif = (struct emif_reg_struct *)EMIF1_BASE;
129*4882a593Smuzhiyun 
130*4882a593Smuzhiyun 	/* Impedance settings EMMC, C2C 1,2, hsi2 */
131*4882a593Smuzhiyun 	mask = (ds_mask << 2) | (ds_mask << 8) |
132*4882a593Smuzhiyun 		(ds_mask << 16) | (ds_mask << 18);
133*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart1io_padconf_0) &
134*4882a593Smuzhiyun 				(~mask);
135*4882a593Smuzhiyun 	io_settings |= (ds_60_ohm << 8) | (ds_45_ohm << 16) |
136*4882a593Smuzhiyun 			(ds_45_ohm << 18) | (ds_60_ohm << 2);
137*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart1io_padconf_0);
138*4882a593Smuzhiyun 
139*4882a593Smuzhiyun 	/* Impedance settings Mcspi2 */
140*4882a593Smuzhiyun 	mask = (ds_mask << 30);
141*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart1io_padconf_1) &
142*4882a593Smuzhiyun 			(~mask);
143*4882a593Smuzhiyun 	io_settings |= (ds_60_ohm << 30);
144*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart1io_padconf_1);
145*4882a593Smuzhiyun 
146*4882a593Smuzhiyun 	/* Impedance settings C2C 3,4 */
147*4882a593Smuzhiyun 	mask = (ds_mask << 14) | (ds_mask << 16);
148*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart1io_padconf_2) &
149*4882a593Smuzhiyun 			(~mask);
150*4882a593Smuzhiyun 	io_settings |= (ds_45_ohm << 14) | (ds_45_ohm << 16);
151*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart1io_padconf_2);
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun 	/* Slew rate settings EMMC, C2C 1,2 */
154*4882a593Smuzhiyun 	mask = (sc_mask << 8) | (sc_mask << 16) | (sc_mask << 18);
155*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart2io_padconf_0) &
156*4882a593Smuzhiyun 			(~mask);
157*4882a593Smuzhiyun 	io_settings |= (sc_fast << 8) | (sc_na << 16) | (sc_na << 18);
158*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart2io_padconf_0);
159*4882a593Smuzhiyun 
160*4882a593Smuzhiyun 	/* Slew rate settings hsi2, Mcspi2 */
161*4882a593Smuzhiyun 	mask = (sc_mask << 24) | (sc_mask << 28);
162*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart2io_padconf_1) &
163*4882a593Smuzhiyun 			(~mask);
164*4882a593Smuzhiyun 	io_settings |= (sc_fast << 28) | (sc_fast << 24);
165*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart2io_padconf_1);
166*4882a593Smuzhiyun 
167*4882a593Smuzhiyun 	/* Slew rate settings C2C 3,4 */
168*4882a593Smuzhiyun 	mask = (sc_mask << 16) | (sc_mask << 18);
169*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart2io_padconf_2) &
170*4882a593Smuzhiyun 			(~mask);
171*4882a593Smuzhiyun 	io_settings |= (sc_na << 16) | (sc_na << 18);
172*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart2io_padconf_2);
173*4882a593Smuzhiyun 
174*4882a593Smuzhiyun 	/* impedance and slew rate settings for usb */
175*4882a593Smuzhiyun 	mask = (usb_i_mask << 29) | (usb_i_mask << 26) | (usb_i_mask << 23) |
176*4882a593Smuzhiyun 		(usb_i_mask << 20) | (usb_i_mask << 17) | (usb_i_mask << 14);
177*4882a593Smuzhiyun 	io_settings = readl((*ctrl)->control_smart3io_padconf_1) &
178*4882a593Smuzhiyun 			(~mask);
179*4882a593Smuzhiyun 	io_settings |= (ds_60_ohm << 29) | (ds_60_ohm << 26) |
180*4882a593Smuzhiyun 		       (ds_60_ohm << 23) | (sc_fast << 20) |
181*4882a593Smuzhiyun 		       (sc_fast << 17) | (sc_fast << 14);
182*4882a593Smuzhiyun 	writel(io_settings, (*ctrl)->control_smart3io_padconf_1);
183*4882a593Smuzhiyun 
184*4882a593Smuzhiyun 	if (emif_sdram_type(emif->emif_sdram_config) == EMIF_SDRAM_TYPE_LPDDR2)
185*4882a593Smuzhiyun 		io_settings_lpddr2();
186*4882a593Smuzhiyun 	else
187*4882a593Smuzhiyun 		io_settings_ddr3();
188*4882a593Smuzhiyun }
189*4882a593Smuzhiyun 
190*4882a593Smuzhiyun static const struct srcomp_params srcomp_parameters[NUM_SYS_CLKS] = {
191*4882a593Smuzhiyun 	{0x45, 0x1},	/* 12 MHz   */
192*4882a593Smuzhiyun 	{-1, -1},	/* 13 MHz   */
193*4882a593Smuzhiyun 	{0x63, 0x2},	/* 16.8 MHz */
194*4882a593Smuzhiyun 	{0x57, 0x2},	/* 19.2 MHz */
195*4882a593Smuzhiyun 	{0x20, 0x1},	/* 26 MHz   */
196*4882a593Smuzhiyun 	{-1, -1},	/* 27 MHz   */
197*4882a593Smuzhiyun 	{0x41, 0x3}	/* 38.4 MHz */
198*4882a593Smuzhiyun };
199*4882a593Smuzhiyun 
srcomp_enable(void)200*4882a593Smuzhiyun void srcomp_enable(void)
201*4882a593Smuzhiyun {
202*4882a593Smuzhiyun 	u32 srcomp_value, mul_factor, div_factor, clk_val, i;
203*4882a593Smuzhiyun 	u32 sysclk_ind	= get_sys_clk_index();
204*4882a593Smuzhiyun 	u32 omap_rev	= omap_revision();
205*4882a593Smuzhiyun 
206*4882a593Smuzhiyun 	if (!is_omap54xx())
207*4882a593Smuzhiyun 		return;
208*4882a593Smuzhiyun 
209*4882a593Smuzhiyun 	mul_factor = srcomp_parameters[sysclk_ind].multiply_factor;
210*4882a593Smuzhiyun 	div_factor = srcomp_parameters[sysclk_ind].divide_factor;
211*4882a593Smuzhiyun 
212*4882a593Smuzhiyun 	for (i = 0; i < 4; i++) {
213*4882a593Smuzhiyun 		srcomp_value = readl((*ctrl)->control_srcomp_north_side + i*4);
214*4882a593Smuzhiyun 		srcomp_value &=
215*4882a593Smuzhiyun 			~(MULTIPLY_FACTOR_XS_MASK | DIVIDE_FACTOR_XS_MASK);
216*4882a593Smuzhiyun 		srcomp_value |= (mul_factor << MULTIPLY_FACTOR_XS_SHIFT) |
217*4882a593Smuzhiyun 			(div_factor << DIVIDE_FACTOR_XS_SHIFT);
218*4882a593Smuzhiyun 		writel(srcomp_value, (*ctrl)->control_srcomp_north_side + i*4);
219*4882a593Smuzhiyun 	}
220*4882a593Smuzhiyun 
221*4882a593Smuzhiyun 	if ((omap_rev == OMAP5430_ES1_0) || (omap_rev == OMAP5432_ES1_0)) {
222*4882a593Smuzhiyun 		clk_val = readl((*prcm)->cm_coreaon_io_srcomp_clkctrl);
223*4882a593Smuzhiyun 		clk_val |= OPTFCLKEN_SRCOMP_FCLK_MASK;
224*4882a593Smuzhiyun 		writel(clk_val, (*prcm)->cm_coreaon_io_srcomp_clkctrl);
225*4882a593Smuzhiyun 
226*4882a593Smuzhiyun 		for (i = 0; i < 4; i++) {
227*4882a593Smuzhiyun 			srcomp_value =
228*4882a593Smuzhiyun 				readl((*ctrl)->control_srcomp_north_side + i*4);
229*4882a593Smuzhiyun 			srcomp_value &= ~PWRDWN_XS_MASK;
230*4882a593Smuzhiyun 			writel(srcomp_value,
231*4882a593Smuzhiyun 			       (*ctrl)->control_srcomp_north_side + i*4);
232*4882a593Smuzhiyun 
233*4882a593Smuzhiyun 			while (((readl((*ctrl)->control_srcomp_north_side + i*4)
234*4882a593Smuzhiyun 				& SRCODE_READ_XS_MASK) >>
235*4882a593Smuzhiyun 				SRCODE_READ_XS_SHIFT) == 0)
236*4882a593Smuzhiyun 				;
237*4882a593Smuzhiyun 
238*4882a593Smuzhiyun 			srcomp_value =
239*4882a593Smuzhiyun 				readl((*ctrl)->control_srcomp_north_side + i*4);
240*4882a593Smuzhiyun 			srcomp_value &= ~OVERRIDE_XS_MASK;
241*4882a593Smuzhiyun 			writel(srcomp_value,
242*4882a593Smuzhiyun 			       (*ctrl)->control_srcomp_north_side + i*4);
243*4882a593Smuzhiyun 		}
244*4882a593Smuzhiyun 	} else {
245*4882a593Smuzhiyun 		srcomp_value = readl((*ctrl)->control_srcomp_east_side_wkup);
246*4882a593Smuzhiyun 		srcomp_value &= ~(MULTIPLY_FACTOR_XS_MASK |
247*4882a593Smuzhiyun 				  DIVIDE_FACTOR_XS_MASK);
248*4882a593Smuzhiyun 		srcomp_value |= (mul_factor << MULTIPLY_FACTOR_XS_SHIFT) |
249*4882a593Smuzhiyun 				(div_factor << DIVIDE_FACTOR_XS_SHIFT);
250*4882a593Smuzhiyun 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
251*4882a593Smuzhiyun 
252*4882a593Smuzhiyun 		for (i = 0; i < 4; i++) {
253*4882a593Smuzhiyun 			srcomp_value =
254*4882a593Smuzhiyun 				readl((*ctrl)->control_srcomp_north_side + i*4);
255*4882a593Smuzhiyun 			srcomp_value |= SRCODE_OVERRIDE_SEL_XS_MASK;
256*4882a593Smuzhiyun 			writel(srcomp_value,
257*4882a593Smuzhiyun 			       (*ctrl)->control_srcomp_north_side + i*4);
258*4882a593Smuzhiyun 
259*4882a593Smuzhiyun 			srcomp_value =
260*4882a593Smuzhiyun 				readl((*ctrl)->control_srcomp_north_side + i*4);
261*4882a593Smuzhiyun 			srcomp_value &= ~OVERRIDE_XS_MASK;
262*4882a593Smuzhiyun 			writel(srcomp_value,
263*4882a593Smuzhiyun 			       (*ctrl)->control_srcomp_north_side + i*4);
264*4882a593Smuzhiyun 		}
265*4882a593Smuzhiyun 
266*4882a593Smuzhiyun 		srcomp_value =
267*4882a593Smuzhiyun 			readl((*ctrl)->control_srcomp_east_side_wkup);
268*4882a593Smuzhiyun 		srcomp_value |= SRCODE_OVERRIDE_SEL_XS_MASK;
269*4882a593Smuzhiyun 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
270*4882a593Smuzhiyun 
271*4882a593Smuzhiyun 		srcomp_value =
272*4882a593Smuzhiyun 			readl((*ctrl)->control_srcomp_east_side_wkup);
273*4882a593Smuzhiyun 		srcomp_value &= ~OVERRIDE_XS_MASK;
274*4882a593Smuzhiyun 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
275*4882a593Smuzhiyun 
276*4882a593Smuzhiyun 		clk_val = readl((*prcm)->cm_coreaon_io_srcomp_clkctrl);
277*4882a593Smuzhiyun 		clk_val |= OPTFCLKEN_SRCOMP_FCLK_MASK;
278*4882a593Smuzhiyun 		writel(clk_val, (*prcm)->cm_coreaon_io_srcomp_clkctrl);
279*4882a593Smuzhiyun 
280*4882a593Smuzhiyun 		clk_val = readl((*prcm)->cm_wkupaon_io_srcomp_clkctrl);
281*4882a593Smuzhiyun 		clk_val |= OPTFCLKEN_SRCOMP_FCLK_MASK;
282*4882a593Smuzhiyun 		writel(clk_val, (*prcm)->cm_wkupaon_io_srcomp_clkctrl);
283*4882a593Smuzhiyun 
284*4882a593Smuzhiyun 		for (i = 0; i < 4; i++) {
285*4882a593Smuzhiyun 			while (((readl((*ctrl)->control_srcomp_north_side + i*4)
286*4882a593Smuzhiyun 				& SRCODE_READ_XS_MASK) >>
287*4882a593Smuzhiyun 				SRCODE_READ_XS_SHIFT) == 0)
288*4882a593Smuzhiyun 				;
289*4882a593Smuzhiyun 
290*4882a593Smuzhiyun 			srcomp_value =
291*4882a593Smuzhiyun 				readl((*ctrl)->control_srcomp_north_side + i*4);
292*4882a593Smuzhiyun 			srcomp_value &= ~SRCODE_OVERRIDE_SEL_XS_MASK;
293*4882a593Smuzhiyun 			writel(srcomp_value,
294*4882a593Smuzhiyun 			       (*ctrl)->control_srcomp_north_side + i*4);
295*4882a593Smuzhiyun 		}
296*4882a593Smuzhiyun 
297*4882a593Smuzhiyun 		while (((readl((*ctrl)->control_srcomp_east_side_wkup) &
298*4882a593Smuzhiyun 			SRCODE_READ_XS_MASK) >> SRCODE_READ_XS_SHIFT) == 0)
299*4882a593Smuzhiyun 			;
300*4882a593Smuzhiyun 
301*4882a593Smuzhiyun 		srcomp_value =
302*4882a593Smuzhiyun 			readl((*ctrl)->control_srcomp_east_side_wkup);
303*4882a593Smuzhiyun 		srcomp_value &= ~SRCODE_OVERRIDE_SEL_XS_MASK;
304*4882a593Smuzhiyun 		writel(srcomp_value, (*ctrl)->control_srcomp_east_side_wkup);
305*4882a593Smuzhiyun 	}
306*4882a593Smuzhiyun }
307*4882a593Smuzhiyun #endif
308*4882a593Smuzhiyun 
config_data_eye_leveling_samples(u32 emif_base)309*4882a593Smuzhiyun void config_data_eye_leveling_samples(u32 emif_base)
310*4882a593Smuzhiyun {
311*4882a593Smuzhiyun 	const struct ctrl_ioregs *ioregs;
312*4882a593Smuzhiyun 
313*4882a593Smuzhiyun 	get_ioregs(&ioregs);
314*4882a593Smuzhiyun 
315*4882a593Smuzhiyun 	/*EMIF_SDRAM_CONFIG_EXT-Read data eye leveling no of samples =4*/
316*4882a593Smuzhiyun 	if (emif_base == EMIF1_BASE)
317*4882a593Smuzhiyun 		writel(ioregs->ctrl_emif_sdram_config_ext_final,
318*4882a593Smuzhiyun 		       (*ctrl)->control_emif1_sdram_config_ext);
319*4882a593Smuzhiyun 	else if (emif_base == EMIF2_BASE)
320*4882a593Smuzhiyun 		writel(ioregs->ctrl_emif_sdram_config_ext_final,
321*4882a593Smuzhiyun 		       (*ctrl)->control_emif2_sdram_config_ext);
322*4882a593Smuzhiyun }
323*4882a593Smuzhiyun 
init_cpu_configuration(void)324*4882a593Smuzhiyun void init_cpu_configuration(void)
325*4882a593Smuzhiyun {
326*4882a593Smuzhiyun 	u32 l2actlr;
327*4882a593Smuzhiyun 
328*4882a593Smuzhiyun 	asm volatile("mrc p15, 1, %0, c15, c0, 0" : "=r"(l2actlr));
329*4882a593Smuzhiyun 	/*
330*4882a593Smuzhiyun 	 * L2ACTLR: Ensure to enable the following:
331*4882a593Smuzhiyun 	 * 3: Disable clean/evict push to external
332*4882a593Smuzhiyun 	 * 4: Disable WriteUnique and WriteLineUnique transactions from master
333*4882a593Smuzhiyun 	 * 8: Disable DVM/CMO message broadcast
334*4882a593Smuzhiyun 	 */
335*4882a593Smuzhiyun 	l2actlr |= 0x118;
336*4882a593Smuzhiyun 	omap_smc1(OMAP5_SERVICE_L2ACTLR_SET, l2actlr);
337*4882a593Smuzhiyun }
338*4882a593Smuzhiyun 
init_omap_revision(void)339*4882a593Smuzhiyun void init_omap_revision(void)
340*4882a593Smuzhiyun {
341*4882a593Smuzhiyun 	/*
342*4882a593Smuzhiyun 	 * For some of the ES2/ES1 boards ID_CODE is not reliable:
343*4882a593Smuzhiyun 	 * Also, ES1 and ES2 have different ARM revisions
344*4882a593Smuzhiyun 	 * So use ARM revision for identification
345*4882a593Smuzhiyun 	 */
346*4882a593Smuzhiyun 	unsigned int rev = cortex_rev();
347*4882a593Smuzhiyun 
348*4882a593Smuzhiyun 	switch (readl(CONTROL_ID_CODE)) {
349*4882a593Smuzhiyun 	case OMAP5430_CONTROL_ID_CODE_ES1_0:
350*4882a593Smuzhiyun 		*omap_si_rev = OMAP5430_ES1_0;
351*4882a593Smuzhiyun 		if (rev == MIDR_CORTEX_A15_R2P2)
352*4882a593Smuzhiyun 			*omap_si_rev = OMAP5430_ES2_0;
353*4882a593Smuzhiyun 		break;
354*4882a593Smuzhiyun 	case OMAP5432_CONTROL_ID_CODE_ES1_0:
355*4882a593Smuzhiyun 		*omap_si_rev = OMAP5432_ES1_0;
356*4882a593Smuzhiyun 		if (rev == MIDR_CORTEX_A15_R2P2)
357*4882a593Smuzhiyun 			*omap_si_rev = OMAP5432_ES2_0;
358*4882a593Smuzhiyun 		break;
359*4882a593Smuzhiyun 	case OMAP5430_CONTROL_ID_CODE_ES2_0:
360*4882a593Smuzhiyun 		*omap_si_rev = OMAP5430_ES2_0;
361*4882a593Smuzhiyun 		break;
362*4882a593Smuzhiyun 	case OMAP5432_CONTROL_ID_CODE_ES2_0:
363*4882a593Smuzhiyun 		*omap_si_rev = OMAP5432_ES2_0;
364*4882a593Smuzhiyun 		break;
365*4882a593Smuzhiyun 	case DRA752_CONTROL_ID_CODE_ES1_0:
366*4882a593Smuzhiyun 		*omap_si_rev = DRA752_ES1_0;
367*4882a593Smuzhiyun 		break;
368*4882a593Smuzhiyun 	case DRA752_CONTROL_ID_CODE_ES1_1:
369*4882a593Smuzhiyun 		*omap_si_rev = DRA752_ES1_1;
370*4882a593Smuzhiyun 		break;
371*4882a593Smuzhiyun 	case DRA752_CONTROL_ID_CODE_ES2_0:
372*4882a593Smuzhiyun 		*omap_si_rev = DRA752_ES2_0;
373*4882a593Smuzhiyun 		break;
374*4882a593Smuzhiyun 	case DRA722_CONTROL_ID_CODE_ES1_0:
375*4882a593Smuzhiyun 		*omap_si_rev = DRA722_ES1_0;
376*4882a593Smuzhiyun 		break;
377*4882a593Smuzhiyun 	case DRA722_CONTROL_ID_CODE_ES2_0:
378*4882a593Smuzhiyun 		*omap_si_rev = DRA722_ES2_0;
379*4882a593Smuzhiyun 		break;
380*4882a593Smuzhiyun 	default:
381*4882a593Smuzhiyun 		*omap_si_rev = OMAP5430_SILICON_ID_INVALID;
382*4882a593Smuzhiyun 	}
383*4882a593Smuzhiyun 	init_cpu_configuration();
384*4882a593Smuzhiyun }
385*4882a593Smuzhiyun 
omap_die_id(unsigned int * die_id)386*4882a593Smuzhiyun void omap_die_id(unsigned int *die_id)
387*4882a593Smuzhiyun {
388*4882a593Smuzhiyun 	die_id[0] = readl((*ctrl)->control_std_fuse_die_id_0);
389*4882a593Smuzhiyun 	die_id[1] = readl((*ctrl)->control_std_fuse_die_id_1);
390*4882a593Smuzhiyun 	die_id[2] = readl((*ctrl)->control_std_fuse_die_id_2);
391*4882a593Smuzhiyun 	die_id[3] = readl((*ctrl)->control_std_fuse_die_id_3);
392*4882a593Smuzhiyun }
393*4882a593Smuzhiyun 
reset_cpu(ulong ignored)394*4882a593Smuzhiyun void reset_cpu(ulong ignored)
395*4882a593Smuzhiyun {
396*4882a593Smuzhiyun 	u32 omap_rev = omap_revision();
397*4882a593Smuzhiyun 
398*4882a593Smuzhiyun 	/*
399*4882a593Smuzhiyun 	 * WARM reset is not functional in case of OMAP5430 ES1.0 soc.
400*4882a593Smuzhiyun 	 * So use cold reset in case instead.
401*4882a593Smuzhiyun 	 */
402*4882a593Smuzhiyun 	if (omap_rev == OMAP5430_ES1_0)
403*4882a593Smuzhiyun 		writel(PRM_RSTCTRL_RESET << 0x1, (*prcm)->prm_rstctrl);
404*4882a593Smuzhiyun 	else
405*4882a593Smuzhiyun 		writel(PRM_RSTCTRL_RESET, (*prcm)->prm_rstctrl);
406*4882a593Smuzhiyun }
407*4882a593Smuzhiyun 
warm_reset(void)408*4882a593Smuzhiyun u32 warm_reset(void)
409*4882a593Smuzhiyun {
410*4882a593Smuzhiyun 	return readl((*prcm)->prm_rstst) & PRM_RSTST_WARM_RESET_MASK;
411*4882a593Smuzhiyun }
412*4882a593Smuzhiyun 
setup_warmreset_time(void)413*4882a593Smuzhiyun void setup_warmreset_time(void)
414*4882a593Smuzhiyun {
415*4882a593Smuzhiyun 	u32 rst_time, rst_val;
416*4882a593Smuzhiyun 
417*4882a593Smuzhiyun 	/*
418*4882a593Smuzhiyun 	 * MAX value for PRM_RSTTIME[9:0]RSTTIME1 stored is 0x3ff.
419*4882a593Smuzhiyun 	 * 0x3ff is in the no of FUNC_32K_CLK cycles. Converting cycles
420*4882a593Smuzhiyun 	 * into microsec and passing the value.
421*4882a593Smuzhiyun 	 */
422*4882a593Smuzhiyun 	rst_time = usec_to_32k(CONFIG_OMAP_PLATFORM_RESET_TIME_MAX_USEC)
423*4882a593Smuzhiyun 		<< RSTTIME1_SHIFT;
424*4882a593Smuzhiyun 
425*4882a593Smuzhiyun 	if (rst_time > RSTTIME1_MASK)
426*4882a593Smuzhiyun 		rst_time = RSTTIME1_MASK;
427*4882a593Smuzhiyun 
428*4882a593Smuzhiyun 	rst_val = readl((*prcm)->prm_rsttime) & ~RSTTIME1_MASK;
429*4882a593Smuzhiyun 	rst_val |= rst_time;
430*4882a593Smuzhiyun 	writel(rst_val, (*prcm)->prm_rsttime);
431*4882a593Smuzhiyun }
432*4882a593Smuzhiyun 
v7_arch_cp15_set_l2aux_ctrl(u32 l2auxctrl,u32 cpu_midr,u32 cpu_rev_comb,u32 cpu_variant,u32 cpu_rev)433*4882a593Smuzhiyun void v7_arch_cp15_set_l2aux_ctrl(u32 l2auxctrl, u32 cpu_midr,
434*4882a593Smuzhiyun 				 u32 cpu_rev_comb, u32 cpu_variant,
435*4882a593Smuzhiyun 				 u32 cpu_rev)
436*4882a593Smuzhiyun {
437*4882a593Smuzhiyun 	omap_smc1(OMAP5_SERVICE_L2ACTLR_SET, l2auxctrl);
438*4882a593Smuzhiyun }
439*4882a593Smuzhiyun 
v7_arch_cp15_set_acr(u32 acr,u32 cpu_midr,u32 cpu_rev_comb,u32 cpu_variant,u32 cpu_rev)440*4882a593Smuzhiyun void v7_arch_cp15_set_acr(u32 acr, u32 cpu_midr, u32 cpu_rev_comb,
441*4882a593Smuzhiyun 			  u32 cpu_variant, u32 cpu_rev)
442*4882a593Smuzhiyun {
443*4882a593Smuzhiyun 
444*4882a593Smuzhiyun #ifdef CONFIG_ARM_ERRATA_801819
445*4882a593Smuzhiyun 	/*
446*4882a593Smuzhiyun 	 * DRA72x processors are uniprocessors and DONOT have
447*4882a593Smuzhiyun 	 * ACP (Accelerator Coherency Port) hooked to ACE (AXI Coherency
448*4882a593Smuzhiyun 	 * Extensions) Hence the erratum workaround is not applicable for
449*4882a593Smuzhiyun 	 * DRA72x processors.
450*4882a593Smuzhiyun 	 */
451*4882a593Smuzhiyun 	if (is_dra72x())
452*4882a593Smuzhiyun 		acr &= ~((0x3 << 23) | (0x3 << 25));
453*4882a593Smuzhiyun #endif
454*4882a593Smuzhiyun 	omap_smc1(OMAP5_SERVICE_ACR_SET, acr);
455*4882a593Smuzhiyun }
456*4882a593Smuzhiyun 
457*4882a593Smuzhiyun #if defined(CONFIG_PALMAS_POWER)
vmmc_pbias_config(uint voltage)458*4882a593Smuzhiyun void vmmc_pbias_config(uint voltage)
459*4882a593Smuzhiyun {
460*4882a593Smuzhiyun 	u32 value = 0;
461*4882a593Smuzhiyun 	struct vcores_data const *vcores = *omap_vcores;
462*4882a593Smuzhiyun 
463*4882a593Smuzhiyun 	value = readl((*ctrl)->control_pbias);
464*4882a593Smuzhiyun 	value &= ~SDCARD_PWRDNZ;
465*4882a593Smuzhiyun 	writel(value, (*ctrl)->control_pbias);
466*4882a593Smuzhiyun 	udelay(10); /* wait 10 us */
467*4882a593Smuzhiyun 	value &= ~SDCARD_BIAS_PWRDNZ;
468*4882a593Smuzhiyun 	writel(value, (*ctrl)->control_pbias);
469*4882a593Smuzhiyun 
470*4882a593Smuzhiyun 	if (vcores->core.pmic->i2c_slave_addr == 0x60) {
471*4882a593Smuzhiyun 		if (voltage == LDO_VOLT_3V0)
472*4882a593Smuzhiyun 			voltage = 0x19;
473*4882a593Smuzhiyun 		else if (voltage == LDO_VOLT_1V8)
474*4882a593Smuzhiyun 			voltage = 0xa;
475*4882a593Smuzhiyun 		lp873x_mmc1_poweron_ldo(voltage);
476*4882a593Smuzhiyun 	} else {
477*4882a593Smuzhiyun 		palmas_mmc1_poweron_ldo(voltage);
478*4882a593Smuzhiyun 	}
479*4882a593Smuzhiyun 
480*4882a593Smuzhiyun 	value = readl((*ctrl)->control_pbias);
481*4882a593Smuzhiyun 	value |= SDCARD_BIAS_PWRDNZ;
482*4882a593Smuzhiyun 	writel(value, (*ctrl)->control_pbias);
483*4882a593Smuzhiyun 	udelay(150); /* wait 150 us */
484*4882a593Smuzhiyun 	value |= SDCARD_PWRDNZ;
485*4882a593Smuzhiyun 	writel(value, (*ctrl)->control_pbias);
486*4882a593Smuzhiyun 	udelay(150); /* wait 150 us */
487*4882a593Smuzhiyun }
488*4882a593Smuzhiyun #endif
489