xref: /rk3399_ARM-atf/drivers/renesas/rzg/pfc/G2H/pfc_init_g2h.c (revision e9cd36f569dea31b542839d6529994b383c69815)
1*a51d7062SLad Prabhakar /*
2*a51d7062SLad Prabhakar  * Copyright (c) 2021, Renesas Electronics Corporation. All rights reserved.
3*a51d7062SLad Prabhakar  *
4*a51d7062SLad Prabhakar  * SPDX-License-Identifier: BSD-3-Clause
5*a51d7062SLad Prabhakar  */
6*a51d7062SLad Prabhakar 
7*a51d7062SLad Prabhakar #include <stdint.h>
8*a51d7062SLad Prabhakar 
9*a51d7062SLad Prabhakar #include <lib/mmio.h>
10*a51d7062SLad Prabhakar 
11*a51d7062SLad Prabhakar #include "pfc_init_g2h.h"
12*a51d7062SLad Prabhakar #include "rcar_def.h"
13*a51d7062SLad Prabhakar #include "../pfc_regs.h"
14*a51d7062SLad Prabhakar 
15*a51d7062SLad Prabhakar #define GPSR0_D15			BIT(15)
16*a51d7062SLad Prabhakar #define GPSR0_D14			BIT(14)
17*a51d7062SLad Prabhakar #define GPSR0_D13			BIT(13)
18*a51d7062SLad Prabhakar #define GPSR0_D12			BIT(12)
19*a51d7062SLad Prabhakar #define GPSR0_D11			BIT(11)
20*a51d7062SLad Prabhakar #define GPSR0_D10			BIT(10)
21*a51d7062SLad Prabhakar #define GPSR0_D9			BIT(9)
22*a51d7062SLad Prabhakar #define GPSR0_D8			BIT(8)
23*a51d7062SLad Prabhakar #define GPSR0_D7			BIT(7)
24*a51d7062SLad Prabhakar #define GPSR0_D6			BIT(6)
25*a51d7062SLad Prabhakar #define GPSR0_D5			BIT(5)
26*a51d7062SLad Prabhakar #define GPSR0_D4			BIT(4)
27*a51d7062SLad Prabhakar #define GPSR0_D3			BIT(3)
28*a51d7062SLad Prabhakar #define GPSR0_D2			BIT(2)
29*a51d7062SLad Prabhakar #define GPSR0_D1			BIT(1)
30*a51d7062SLad Prabhakar #define GPSR0_D0			BIT(0)
31*a51d7062SLad Prabhakar #define GPSR1_CLKOUT			BIT(28)
32*a51d7062SLad Prabhakar #define GPSR1_EX_WAIT0_A		BIT(27)
33*a51d7062SLad Prabhakar #define GPSR1_WE1			BIT(26)
34*a51d7062SLad Prabhakar #define GPSR1_WE0			BIT(25)
35*a51d7062SLad Prabhakar #define GPSR1_RD_WR			BIT(24)
36*a51d7062SLad Prabhakar #define GPSR1_RD			BIT(23)
37*a51d7062SLad Prabhakar #define GPSR1_BS			BIT(22)
38*a51d7062SLad Prabhakar #define GPSR1_CS1_A26			BIT(21)
39*a51d7062SLad Prabhakar #define GPSR1_CS0			BIT(20)
40*a51d7062SLad Prabhakar #define GPSR1_A19			BIT(19)
41*a51d7062SLad Prabhakar #define GPSR1_A18			BIT(18)
42*a51d7062SLad Prabhakar #define GPSR1_A17			BIT(17)
43*a51d7062SLad Prabhakar #define GPSR1_A16			BIT(16)
44*a51d7062SLad Prabhakar #define GPSR1_A15			BIT(15)
45*a51d7062SLad Prabhakar #define GPSR1_A14			BIT(14)
46*a51d7062SLad Prabhakar #define GPSR1_A13			BIT(13)
47*a51d7062SLad Prabhakar #define GPSR1_A12			BIT(12)
48*a51d7062SLad Prabhakar #define GPSR1_A11			BIT(11)
49*a51d7062SLad Prabhakar #define GPSR1_A10			BIT(10)
50*a51d7062SLad Prabhakar #define GPSR1_A9			BIT(9)
51*a51d7062SLad Prabhakar #define GPSR1_A8			BIT(8)
52*a51d7062SLad Prabhakar #define GPSR1_A7			BIT(7)
53*a51d7062SLad Prabhakar #define GPSR1_A6			BIT(6)
54*a51d7062SLad Prabhakar #define GPSR1_A5			BIT(5)
55*a51d7062SLad Prabhakar #define GPSR1_A4			BIT(4)
56*a51d7062SLad Prabhakar #define GPSR1_A3			BIT(3)
57*a51d7062SLad Prabhakar #define GPSR1_A2			BIT(2)
58*a51d7062SLad Prabhakar #define GPSR1_A1			BIT(1)
59*a51d7062SLad Prabhakar #define GPSR1_A0			BIT(0)
60*a51d7062SLad Prabhakar #define GPSR2_AVB_AVTP_CAPTURE_A	BIT(14)
61*a51d7062SLad Prabhakar #define GPSR2_AVB_AVTP_MATCH_A		BIT(13)
62*a51d7062SLad Prabhakar #define GPSR2_AVB_LINK			BIT(12)
63*a51d7062SLad Prabhakar #define GPSR2_AVB_PHY_INT		BIT(11)
64*a51d7062SLad Prabhakar #define GPSR2_AVB_MAGIC			BIT(10)
65*a51d7062SLad Prabhakar #define GPSR2_AVB_MDC			BIT(9)
66*a51d7062SLad Prabhakar #define GPSR2_PWM2_A			BIT(8)
67*a51d7062SLad Prabhakar #define GPSR2_PWM1_A			BIT(7)
68*a51d7062SLad Prabhakar #define GPSR2_PWM0			BIT(6)
69*a51d7062SLad Prabhakar #define GPSR2_IRQ5			BIT(5)
70*a51d7062SLad Prabhakar #define GPSR2_IRQ4			BIT(4)
71*a51d7062SLad Prabhakar #define GPSR2_IRQ3			BIT(3)
72*a51d7062SLad Prabhakar #define GPSR2_IRQ2			BIT(2)
73*a51d7062SLad Prabhakar #define GPSR2_IRQ1			BIT(1)
74*a51d7062SLad Prabhakar #define GPSR2_IRQ0			BIT(0)
75*a51d7062SLad Prabhakar #define GPSR3_SD1_WP			BIT(15)
76*a51d7062SLad Prabhakar #define GPSR3_SD1_CD			BIT(14)
77*a51d7062SLad Prabhakar #define GPSR3_SD0_WP			BIT(13)
78*a51d7062SLad Prabhakar #define GPSR3_SD0_CD			BIT(12)
79*a51d7062SLad Prabhakar #define GPSR3_SD1_DAT3			BIT(11)
80*a51d7062SLad Prabhakar #define GPSR3_SD1_DAT2			BIT(10)
81*a51d7062SLad Prabhakar #define GPSR3_SD1_DAT1			BIT(9)
82*a51d7062SLad Prabhakar #define GPSR3_SD1_DAT0			BIT(8)
83*a51d7062SLad Prabhakar #define GPSR3_SD1_CMD			BIT(7)
84*a51d7062SLad Prabhakar #define GPSR3_SD1_CLK			BIT(6)
85*a51d7062SLad Prabhakar #define GPSR3_SD0_DAT3			BIT(5)
86*a51d7062SLad Prabhakar #define GPSR3_SD0_DAT2			BIT(4)
87*a51d7062SLad Prabhakar #define GPSR3_SD0_DAT1			BIT(3)
88*a51d7062SLad Prabhakar #define GPSR3_SD0_DAT0			BIT(2)
89*a51d7062SLad Prabhakar #define GPSR3_SD0_CMD			BIT(1)
90*a51d7062SLad Prabhakar #define GPSR3_SD0_CLK			BIT(0)
91*a51d7062SLad Prabhakar #define GPSR4_SD3_DS			BIT(17)
92*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT7			BIT(16)
93*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT6			BIT(15)
94*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT5			BIT(14)
95*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT4			BIT(13)
96*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT3			BIT(12)
97*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT2			BIT(11)
98*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT1			BIT(10)
99*a51d7062SLad Prabhakar #define GPSR4_SD3_DAT0			BIT(9)
100*a51d7062SLad Prabhakar #define GPSR4_SD3_CMD			BIT(8)
101*a51d7062SLad Prabhakar #define GPSR4_SD3_CLK			BIT(7)
102*a51d7062SLad Prabhakar #define GPSR4_SD2_DS			BIT(6)
103*a51d7062SLad Prabhakar #define GPSR4_SD2_DAT3			BIT(5)
104*a51d7062SLad Prabhakar #define GPSR4_SD2_DAT2			BIT(4)
105*a51d7062SLad Prabhakar #define GPSR4_SD2_DAT1			BIT(3)
106*a51d7062SLad Prabhakar #define GPSR4_SD2_DAT0			BIT(2)
107*a51d7062SLad Prabhakar #define GPSR4_SD2_CMD			BIT(1)
108*a51d7062SLad Prabhakar #define GPSR4_SD2_CLK			BIT(0)
109*a51d7062SLad Prabhakar #define GPSR5_MLB_DAT			BIT(25)
110*a51d7062SLad Prabhakar #define GPSR5_MLB_SIG			BIT(24)
111*a51d7062SLad Prabhakar #define GPSR5_MLB_CLK			BIT(23)
112*a51d7062SLad Prabhakar #define GPSR5_MSIOF0_RXD		BIT(22)
113*a51d7062SLad Prabhakar #define GPSR5_MSIOF0_SS2		BIT(21)
114*a51d7062SLad Prabhakar #define GPSR5_MSIOF0_TXD		BIT(20)
115*a51d7062SLad Prabhakar #define GPSR5_MSIOF0_SS1		BIT(19)
116*a51d7062SLad Prabhakar #define GPSR5_MSIOF0_SYNC		BIT(18)
117*a51d7062SLad Prabhakar #define GPSR5_MSIOF0_SCK		BIT(17)
118*a51d7062SLad Prabhakar #define GPSR5_HRTS0			BIT(16)
119*a51d7062SLad Prabhakar #define GPSR5_HCTS0			BIT(15)
120*a51d7062SLad Prabhakar #define GPSR5_HTX0			BIT(14)
121*a51d7062SLad Prabhakar #define GPSR5_HRX0			BIT(13)
122*a51d7062SLad Prabhakar #define GPSR5_HSCK0			BIT(12)
123*a51d7062SLad Prabhakar #define GPSR5_RX2_A			BIT(11)
124*a51d7062SLad Prabhakar #define GPSR5_TX2_A			BIT(10)
125*a51d7062SLad Prabhakar #define GPSR5_SCK2			BIT(9)
126*a51d7062SLad Prabhakar #define GPSR5_RTS1			BIT(8)
127*a51d7062SLad Prabhakar #define GPSR5_CTS1			BIT(7)
128*a51d7062SLad Prabhakar #define GPSR5_TX1_A			BIT(6)
129*a51d7062SLad Prabhakar #define GPSR5_RX1_A			BIT(5)
130*a51d7062SLad Prabhakar #define GPSR5_RTS0			BIT(4)
131*a51d7062SLad Prabhakar #define GPSR5_CTS0			BIT(3)
132*a51d7062SLad Prabhakar #define GPSR5_TX0			BIT(2)
133*a51d7062SLad Prabhakar #define GPSR5_RX0			BIT(1)
134*a51d7062SLad Prabhakar #define GPSR5_SCK0			BIT(0)
135*a51d7062SLad Prabhakar #define GPSR6_USB31_OVC			BIT(31)
136*a51d7062SLad Prabhakar #define GPSR6_USB31_PWEN		BIT(30)
137*a51d7062SLad Prabhakar #define GPSR6_USB30_OVC			BIT(29)
138*a51d7062SLad Prabhakar #define GPSR6_USB30_PWEN		BIT(28)
139*a51d7062SLad Prabhakar #define GPSR6_USB1_OVC			BIT(27)
140*a51d7062SLad Prabhakar #define GPSR6_USB1_PWEN			BIT(26)
141*a51d7062SLad Prabhakar #define GPSR6_USB0_OVC			BIT(25)
142*a51d7062SLad Prabhakar #define GPSR6_USB0_PWEN			BIT(24)
143*a51d7062SLad Prabhakar #define GPSR6_AUDIO_CLKB_B		BIT(23)
144*a51d7062SLad Prabhakar #define GPSR6_AUDIO_CLKA_A		BIT(22)
145*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA9_A		BIT(21)
146*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA8		BIT(20)
147*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA7		BIT(19)
148*a51d7062SLad Prabhakar #define GPSR6_SSI_WS78			BIT(18)
149*a51d7062SLad Prabhakar #define GPSR6_SSI_SCK78			BIT(17)
150*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA6		BIT(16)
151*a51d7062SLad Prabhakar #define GPSR6_SSI_WS6			BIT(15)
152*a51d7062SLad Prabhakar #define GPSR6_SSI_SCK6			BIT(14)
153*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA5		BIT(13)
154*a51d7062SLad Prabhakar #define GPSR6_SSI_WS5			BIT(12)
155*a51d7062SLad Prabhakar #define GPSR6_SSI_SCK5			BIT(11)
156*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA4		BIT(10)
157*a51d7062SLad Prabhakar #define GPSR6_SSI_WS4			BIT(9)
158*a51d7062SLad Prabhakar #define GPSR6_SSI_SCK4			BIT(8)
159*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA3		BIT(7)
160*a51d7062SLad Prabhakar #define GPSR6_SSI_WS34			BIT(6)
161*a51d7062SLad Prabhakar #define GPSR6_SSI_SCK34			BIT(5)
162*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA2_A		BIT(4)
163*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA1_A		BIT(3)
164*a51d7062SLad Prabhakar #define GPSR6_SSI_SDATA0		BIT(2)
165*a51d7062SLad Prabhakar #define GPSR6_SSI_WS0129		BIT(1)
166*a51d7062SLad Prabhakar #define GPSR6_SSI_SCK0129		BIT(0)
167*a51d7062SLad Prabhakar #define GPSR7_AVS2			BIT(1)
168*a51d7062SLad Prabhakar #define GPSR7_AVS1			BIT(0)
169*a51d7062SLad Prabhakar 
170*a51d7062SLad Prabhakar #define IPSR_28_FUNC(x)			((uint32_t)(x) << 28U)
171*a51d7062SLad Prabhakar #define IPSR_24_FUNC(x)			((uint32_t)(x) << 24U)
172*a51d7062SLad Prabhakar #define IPSR_20_FUNC(x)			((uint32_t)(x) << 20U)
173*a51d7062SLad Prabhakar #define IPSR_16_FUNC(x)			((uint32_t)(x) << 16U)
174*a51d7062SLad Prabhakar #define IPSR_12_FUNC(x)			((uint32_t)(x) << 12U)
175*a51d7062SLad Prabhakar #define IPSR_8_FUNC(x)			((uint32_t)(x) << 8U)
176*a51d7062SLad Prabhakar #define IPSR_4_FUNC(x)			((uint32_t)(x) << 4U)
177*a51d7062SLad Prabhakar #define IPSR_0_FUNC(x)			((uint32_t)(x) << 0U)
178*a51d7062SLad Prabhakar 
179*a51d7062SLad Prabhakar #define POC_SD3_DS_33V			BIT(29)
180*a51d7062SLad Prabhakar #define POC_SD3_DAT7_33V		BIT(28)
181*a51d7062SLad Prabhakar #define POC_SD3_DAT6_33V		BIT(27)
182*a51d7062SLad Prabhakar #define POC_SD3_DAT5_33V		BIT(26)
183*a51d7062SLad Prabhakar #define POC_SD3_DAT4_33V		BIT(25)
184*a51d7062SLad Prabhakar #define POC_SD3_DAT3_33V		BIT(24)
185*a51d7062SLad Prabhakar #define POC_SD3_DAT2_33V		BIT(23)
186*a51d7062SLad Prabhakar #define POC_SD3_DAT1_33V		BIT(22)
187*a51d7062SLad Prabhakar #define POC_SD3_DAT0_33V		BIT(21)
188*a51d7062SLad Prabhakar #define POC_SD3_CMD_33V			BIT(20)
189*a51d7062SLad Prabhakar #define POC_SD3_CLK_33V			BIT(19)
190*a51d7062SLad Prabhakar #define POC_SD2_DS_33V			BIT(18)
191*a51d7062SLad Prabhakar #define POC_SD2_DAT3_33V		BIT(17)
192*a51d7062SLad Prabhakar #define POC_SD2_DAT2_33V		BIT(16)
193*a51d7062SLad Prabhakar #define POC_SD2_DAT1_33V		BIT(15)
194*a51d7062SLad Prabhakar #define POC_SD2_DAT0_33V		BIT(14)
195*a51d7062SLad Prabhakar #define POC_SD2_CMD_33V			BIT(13)
196*a51d7062SLad Prabhakar #define POC_SD2_CLK_33V			BIT(12)
197*a51d7062SLad Prabhakar #define POC_SD1_DAT3_33V		BIT(11)
198*a51d7062SLad Prabhakar #define POC_SD1_DAT2_33V		BIT(10)
199*a51d7062SLad Prabhakar #define POC_SD1_DAT1_33V		BIT(9)
200*a51d7062SLad Prabhakar #define POC_SD1_DAT0_33V		BIT(8)
201*a51d7062SLad Prabhakar #define POC_SD1_CMD_33V			BIT(7)
202*a51d7062SLad Prabhakar #define POC_SD1_CLK_33V			BIT(6)
203*a51d7062SLad Prabhakar #define POC_SD0_DAT3_33V		BIT(5)
204*a51d7062SLad Prabhakar #define POC_SD0_DAT2_33V		BIT(4)
205*a51d7062SLad Prabhakar #define POC_SD0_DAT1_33V		BIT(3)
206*a51d7062SLad Prabhakar #define POC_SD0_DAT0_33V		BIT(2)
207*a51d7062SLad Prabhakar #define POC_SD0_CMD_33V			BIT(1)
208*a51d7062SLad Prabhakar #define POC_SD0_CLK_33V			BIT(0)
209*a51d7062SLad Prabhakar 
210*a51d7062SLad Prabhakar #define DRVCTRL0_MASK			(0xCCCCCCCCU)
211*a51d7062SLad Prabhakar #define DRVCTRL1_MASK			(0xCCCCCCC8U)
212*a51d7062SLad Prabhakar #define DRVCTRL2_MASK			(0x88888888U)
213*a51d7062SLad Prabhakar #define DRVCTRL3_MASK			(0x88888888U)
214*a51d7062SLad Prabhakar #define DRVCTRL4_MASK			(0x88888888U)
215*a51d7062SLad Prabhakar #define DRVCTRL5_MASK			(0x88888888U)
216*a51d7062SLad Prabhakar #define DRVCTRL6_MASK			(0x88888888U)
217*a51d7062SLad Prabhakar #define DRVCTRL7_MASK			(0x88888888U)
218*a51d7062SLad Prabhakar #define DRVCTRL8_MASK			(0x88888888U)
219*a51d7062SLad Prabhakar #define DRVCTRL9_MASK			(0x88888888U)
220*a51d7062SLad Prabhakar #define DRVCTRL10_MASK			(0x88888888U)
221*a51d7062SLad Prabhakar #define DRVCTRL11_MASK			(0x888888CCU)
222*a51d7062SLad Prabhakar #define DRVCTRL12_MASK			(0xCCCFFFCFU)
223*a51d7062SLad Prabhakar #define DRVCTRL13_MASK			(0xCC888888U)
224*a51d7062SLad Prabhakar #define DRVCTRL14_MASK			(0x88888888U)
225*a51d7062SLad Prabhakar #define DRVCTRL15_MASK			(0x88888888U)
226*a51d7062SLad Prabhakar #define DRVCTRL16_MASK			(0x88888888U)
227*a51d7062SLad Prabhakar #define DRVCTRL17_MASK			(0x88888888U)
228*a51d7062SLad Prabhakar #define DRVCTRL18_MASK			(0x88888888U)
229*a51d7062SLad Prabhakar #define DRVCTRL19_MASK			(0x88888888U)
230*a51d7062SLad Prabhakar #define DRVCTRL20_MASK			(0x88888888U)
231*a51d7062SLad Prabhakar #define DRVCTRL21_MASK			(0x88888888U)
232*a51d7062SLad Prabhakar #define DRVCTRL22_MASK			(0x88888888U)
233*a51d7062SLad Prabhakar #define DRVCTRL23_MASK			(0x88888888U)
234*a51d7062SLad Prabhakar #define DRVCTRL24_MASK			(0x8888888FU)
235*a51d7062SLad Prabhakar 
236*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI0_SPCLK(x)		((uint32_t)(x) << 28U)
237*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI0_MOSI_IO0(x)	((uint32_t)(x) << 24U)
238*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI0_MISO_IO1(x)	((uint32_t)(x) << 20U)
239*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI0_IO2(x)		((uint32_t)(x) << 16U)
240*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI0_IO3(x)		((uint32_t)(x) << 12U)
241*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI0_SSL(x)		((uint32_t)(x) << 8U)
242*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI1_SPCLK(x)		((uint32_t)(x) << 4U)
243*a51d7062SLad Prabhakar #define DRVCTRL0_QSPI1_MOSI_IO0(x)	((uint32_t)(x) << 0U)
244*a51d7062SLad Prabhakar #define DRVCTRL1_QSPI1_MISO_IO1(x)	((uint32_t)(x) << 28U)
245*a51d7062SLad Prabhakar #define DRVCTRL1_QSPI1_IO2(x)		((uint32_t)(x) << 24U)
246*a51d7062SLad Prabhakar #define DRVCTRL1_QSPI1_IO3(x)		((uint32_t)(x) << 20U)
247*a51d7062SLad Prabhakar #define DRVCTRL1_QSPI1_SS(x)		((uint32_t)(x) << 16U)
248*a51d7062SLad Prabhakar #define DRVCTRL1_RPC_INT(x)		((uint32_t)(x) << 12U)
249*a51d7062SLad Prabhakar #define DRVCTRL1_RPC_WP(x)		((uint32_t)(x) << 8U)
250*a51d7062SLad Prabhakar #define DRVCTRL1_RPC_RESET(x)		((uint32_t)(x) << 4U)
251*a51d7062SLad Prabhakar #define DRVCTRL1_AVB_RX_CTL(x)		((uint32_t)(x) << 0U)
252*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_RXC(x)		((uint32_t)(x) << 28U)
253*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_RD0(x)		((uint32_t)(x) << 24U)
254*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_RD1(x)		((uint32_t)(x) << 20U)
255*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_RD2(x)		((uint32_t)(x) << 16U)
256*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_RD3(x)		((uint32_t)(x) << 12U)
257*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_TX_CTL(x)		((uint32_t)(x) << 8U)
258*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_TXC(x)		((uint32_t)(x) << 4U)
259*a51d7062SLad Prabhakar #define DRVCTRL2_AVB_TD0(x)		((uint32_t)(x) << 0U)
260*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_TD1(x)		((uint32_t)(x) << 28U)
261*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_TD2(x)		((uint32_t)(x) << 24U)
262*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_TD3(x)		((uint32_t)(x) << 20U)
263*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_TXCREFCLK(x)	((uint32_t)(x) << 16U)
264*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_MDIO(x)		((uint32_t)(x) << 12U)
265*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_MDC(x)		((uint32_t)(x) << 8U)
266*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_MAGIC(x)		((uint32_t)(x) << 4U)
267*a51d7062SLad Prabhakar #define DRVCTRL3_AVB_PHY_INT(x)		((uint32_t)(x) << 0U)
268*a51d7062SLad Prabhakar #define DRVCTRL4_AVB_LINK(x)		((uint32_t)(x) << 28U)
269*a51d7062SLad Prabhakar #define DRVCTRL4_AVB_AVTP_MATCH(x)	((uint32_t)(x) << 24U)
270*a51d7062SLad Prabhakar #define DRVCTRL4_AVB_AVTP_CAPTURE(x)	((uint32_t)(x) << 20U)
271*a51d7062SLad Prabhakar #define DRVCTRL4_IRQ0(x)		((uint32_t)(x) << 16U)
272*a51d7062SLad Prabhakar #define DRVCTRL4_IRQ1(x)		((uint32_t)(x) << 12U)
273*a51d7062SLad Prabhakar #define DRVCTRL4_IRQ2(x)		((uint32_t)(x) << 8U)
274*a51d7062SLad Prabhakar #define DRVCTRL4_IRQ3(x)		((uint32_t)(x) << 4U)
275*a51d7062SLad Prabhakar #define DRVCTRL4_IRQ4(x)		((uint32_t)(x) << 0U)
276*a51d7062SLad Prabhakar #define DRVCTRL5_IRQ5(x)		((uint32_t)(x) << 28U)
277*a51d7062SLad Prabhakar #define DRVCTRL5_PWM0(x)		((uint32_t)(x) << 24U)
278*a51d7062SLad Prabhakar #define DRVCTRL5_PWM1(x)		((uint32_t)(x) << 20U)
279*a51d7062SLad Prabhakar #define DRVCTRL5_PWM2(x)		((uint32_t)(x) << 16U)
280*a51d7062SLad Prabhakar #define DRVCTRL5_A0(x)			((uint32_t)(x) << 12U)
281*a51d7062SLad Prabhakar #define DRVCTRL5_A1(x)			((uint32_t)(x) << 8U)
282*a51d7062SLad Prabhakar #define DRVCTRL5_A2(x)			((uint32_t)(x) << 4U)
283*a51d7062SLad Prabhakar #define DRVCTRL5_A3(x)			((uint32_t)(x) << 0U)
284*a51d7062SLad Prabhakar #define DRVCTRL6_A4(x)			((uint32_t)(x) << 28U)
285*a51d7062SLad Prabhakar #define DRVCTRL6_A5(x)			((uint32_t)(x) << 24U)
286*a51d7062SLad Prabhakar #define DRVCTRL6_A6(x)			((uint32_t)(x) << 20U)
287*a51d7062SLad Prabhakar #define DRVCTRL6_A7(x)			((uint32_t)(x) << 16U)
288*a51d7062SLad Prabhakar #define DRVCTRL6_A8(x)			((uint32_t)(x) << 12U)
289*a51d7062SLad Prabhakar #define DRVCTRL6_A9(x)			((uint32_t)(x) << 8U)
290*a51d7062SLad Prabhakar #define DRVCTRL6_A10(x)			((uint32_t)(x) << 4U)
291*a51d7062SLad Prabhakar #define DRVCTRL6_A11(x)			((uint32_t)(x) << 0U)
292*a51d7062SLad Prabhakar #define DRVCTRL7_A12(x)			((uint32_t)(x) << 28U)
293*a51d7062SLad Prabhakar #define DRVCTRL7_A13(x)			((uint32_t)(x) << 24U)
294*a51d7062SLad Prabhakar #define DRVCTRL7_A14(x)			((uint32_t)(x) << 20U)
295*a51d7062SLad Prabhakar #define DRVCTRL7_A15(x)			((uint32_t)(x) << 16U)
296*a51d7062SLad Prabhakar #define DRVCTRL7_A16(x)			((uint32_t)(x) << 12U)
297*a51d7062SLad Prabhakar #define DRVCTRL7_A17(x)			((uint32_t)(x) << 8U)
298*a51d7062SLad Prabhakar #define DRVCTRL7_A18(x)			((uint32_t)(x) << 4U)
299*a51d7062SLad Prabhakar #define DRVCTRL7_A19(x)			((uint32_t)(x) << 0U)
300*a51d7062SLad Prabhakar #define DRVCTRL8_CLKOUT(x)		((uint32_t)(x) << 28U)
301*a51d7062SLad Prabhakar #define DRVCTRL8_CS0(x)			((uint32_t)(x) << 24U)
302*a51d7062SLad Prabhakar #define DRVCTRL8_CS1_A2(x)		((uint32_t)(x) << 20U)
303*a51d7062SLad Prabhakar #define DRVCTRL8_BS(x)			((uint32_t)(x) << 16U)
304*a51d7062SLad Prabhakar #define DRVCTRL8_RD(x)			((uint32_t)(x) << 12U)
305*a51d7062SLad Prabhakar #define DRVCTRL8_RD_W(x)		((uint32_t)(x) << 8U)
306*a51d7062SLad Prabhakar #define DRVCTRL8_WE0(x)			((uint32_t)(x) << 4U)
307*a51d7062SLad Prabhakar #define DRVCTRL8_WE1(x)			((uint32_t)(x) << 0U)
308*a51d7062SLad Prabhakar #define DRVCTRL9_EX_WAIT0(x)		((uint32_t)(x) << 28U)
309*a51d7062SLad Prabhakar #define DRVCTRL9_PRESETOU(x)		((uint32_t)(x) << 24U)
310*a51d7062SLad Prabhakar #define DRVCTRL9_D0(x)			((uint32_t)(x) << 20U)
311*a51d7062SLad Prabhakar #define DRVCTRL9_D1(x)			((uint32_t)(x) << 16U)
312*a51d7062SLad Prabhakar #define DRVCTRL9_D2(x)			((uint32_t)(x) << 12U)
313*a51d7062SLad Prabhakar #define DRVCTRL9_D3(x)			((uint32_t)(x) << 8U)
314*a51d7062SLad Prabhakar #define DRVCTRL9_D4(x)			((uint32_t)(x) << 4U)
315*a51d7062SLad Prabhakar #define DRVCTRL9_D5(x)			((uint32_t)(x) << 0U)
316*a51d7062SLad Prabhakar #define DRVCTRL10_D6(x)			((uint32_t)(x) << 28U)
317*a51d7062SLad Prabhakar #define DRVCTRL10_D7(x)			((uint32_t)(x) << 24U)
318*a51d7062SLad Prabhakar #define DRVCTRL10_D8(x)			((uint32_t)(x) << 20U)
319*a51d7062SLad Prabhakar #define DRVCTRL10_D9(x)			((uint32_t)(x) << 16U)
320*a51d7062SLad Prabhakar #define DRVCTRL10_D10(x)		((uint32_t)(x) << 12U)
321*a51d7062SLad Prabhakar #define DRVCTRL10_D11(x)		((uint32_t)(x) << 8U)
322*a51d7062SLad Prabhakar #define DRVCTRL10_D12(x)		((uint32_t)(x) << 4U)
323*a51d7062SLad Prabhakar #define DRVCTRL10_D13(x)		((uint32_t)(x) << 0U)
324*a51d7062SLad Prabhakar #define DRVCTRL11_D14(x)		((uint32_t)(x) << 28U)
325*a51d7062SLad Prabhakar #define DRVCTRL11_D15(x)		((uint32_t)(x) << 24U)
326*a51d7062SLad Prabhakar #define DRVCTRL11_AVS1(x)		((uint32_t)(x) << 20U)
327*a51d7062SLad Prabhakar #define DRVCTRL11_AVS2(x)		((uint32_t)(x) << 16U)
328*a51d7062SLad Prabhakar #define DRVCTRL11_GP7_02(x)		((uint32_t)(x) << 12U)
329*a51d7062SLad Prabhakar #define DRVCTRL11_GP7_03(x)		((uint32_t)(x) << 8U)
330*a51d7062SLad Prabhakar #define DRVCTRL11_DU_DOTCLKIN0(x)	((uint32_t)(x) << 4U)
331*a51d7062SLad Prabhakar #define DRVCTRL11_DU_DOTCLKIN1(x)	((uint32_t)(x) << 0U)
332*a51d7062SLad Prabhakar #define DRVCTRL12_DU_DOTCLKIN2(x)	((uint32_t)(x) << 28U)
333*a51d7062SLad Prabhakar #define DRVCTRL12_DU_DOTCLKIN3(x)	((uint32_t)(x) << 24U)
334*a51d7062SLad Prabhakar #define DRVCTRL12_DU_FSCLKST(x)		((uint32_t)(x) << 20U)
335*a51d7062SLad Prabhakar #define DRVCTRL12_DU_TMS(x)		((uint32_t)(x) << 4U)
336*a51d7062SLad Prabhakar #define DRVCTRL13_TDO(x)		((uint32_t)(x) << 28U)
337*a51d7062SLad Prabhakar #define DRVCTRL13_ASEBRK(x)		((uint32_t)(x) << 24U)
338*a51d7062SLad Prabhakar #define DRVCTRL13_SD0_CLK(x)		((uint32_t)(x) << 20U)
339*a51d7062SLad Prabhakar #define DRVCTRL13_SD0_CMD(x)		((uint32_t)(x) << 16U)
340*a51d7062SLad Prabhakar #define DRVCTRL13_SD0_DAT0(x)		((uint32_t)(x) << 12U)
341*a51d7062SLad Prabhakar #define DRVCTRL13_SD0_DAT1(x)		((uint32_t)(x) << 8U)
342*a51d7062SLad Prabhakar #define DRVCTRL13_SD0_DAT2(x)		((uint32_t)(x) << 4U)
343*a51d7062SLad Prabhakar #define DRVCTRL13_SD0_DAT3(x)		((uint32_t)(x) << 0U)
344*a51d7062SLad Prabhakar #define DRVCTRL14_SD1_CLK(x)		((uint32_t)(x) << 28U)
345*a51d7062SLad Prabhakar #define DRVCTRL14_SD1_CMD(x)		((uint32_t)(x) << 24U)
346*a51d7062SLad Prabhakar #define DRVCTRL14_SD1_DAT0(x)		((uint32_t)(x) << 20U)
347*a51d7062SLad Prabhakar #define DRVCTRL14_SD1_DAT1(x)		((uint32_t)(x) << 16U)
348*a51d7062SLad Prabhakar #define DRVCTRL14_SD1_DAT2(x)		((uint32_t)(x) << 12U)
349*a51d7062SLad Prabhakar #define DRVCTRL14_SD1_DAT3(x)		((uint32_t)(x) << 8U)
350*a51d7062SLad Prabhakar #define DRVCTRL14_SD2_CLK(x)		((uint32_t)(x) << 4U)
351*a51d7062SLad Prabhakar #define DRVCTRL14_SD2_CMD(x)		((uint32_t)(x) << 0U)
352*a51d7062SLad Prabhakar #define DRVCTRL15_SD2_DAT0(x)		((uint32_t)(x) << 28U)
353*a51d7062SLad Prabhakar #define DRVCTRL15_SD2_DAT1(x)		((uint32_t)(x) << 24U)
354*a51d7062SLad Prabhakar #define DRVCTRL15_SD2_DAT2(x)		((uint32_t)(x) << 20U)
355*a51d7062SLad Prabhakar #define DRVCTRL15_SD2_DAT3(x)		((uint32_t)(x) << 16U)
356*a51d7062SLad Prabhakar #define DRVCTRL15_SD2_DS(x)		((uint32_t)(x) << 12U)
357*a51d7062SLad Prabhakar #define DRVCTRL15_SD3_CLK(x)		((uint32_t)(x) << 8U)
358*a51d7062SLad Prabhakar #define DRVCTRL15_SD3_CMD(x)		((uint32_t)(x) << 4U)
359*a51d7062SLad Prabhakar #define DRVCTRL15_SD3_DAT0(x)		((uint32_t)(x) << 0U)
360*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT1(x)		((uint32_t)(x) << 28U)
361*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT2(x)		((uint32_t)(x) << 24U)
362*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT3(x)		((uint32_t)(x) << 20U)
363*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT4(x)		((uint32_t)(x) << 16U)
364*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT5(x)		((uint32_t)(x) << 12U)
365*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT6(x)		((uint32_t)(x) << 8U)
366*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DAT7(x)		((uint32_t)(x) << 4U)
367*a51d7062SLad Prabhakar #define DRVCTRL16_SD3_DS(x)		((uint32_t)(x) << 0U)
368*a51d7062SLad Prabhakar #define DRVCTRL17_SD0_CD(x)		((uint32_t)(x) << 28U)
369*a51d7062SLad Prabhakar #define DRVCTRL17_SD0_WP(x)		((uint32_t)(x) << 24U)
370*a51d7062SLad Prabhakar #define DRVCTRL17_SD1_CD(x)		((uint32_t)(x) << 20U)
371*a51d7062SLad Prabhakar #define DRVCTRL17_SD1_WP(x)		((uint32_t)(x) << 16U)
372*a51d7062SLad Prabhakar #define DRVCTRL17_SCK0(x)		((uint32_t)(x) << 12U)
373*a51d7062SLad Prabhakar #define DRVCTRL17_RX0(x)		((uint32_t)(x) << 8U)
374*a51d7062SLad Prabhakar #define DRVCTRL17_TX0(x)		((uint32_t)(x) << 4U)
375*a51d7062SLad Prabhakar #define DRVCTRL17_CTS0(x)		((uint32_t)(x) << 0U)
376*a51d7062SLad Prabhakar #define DRVCTRL18_RTS0_TANS(x)		((uint32_t)(x) << 28U)
377*a51d7062SLad Prabhakar #define DRVCTRL18_RX1(x)		((uint32_t)(x) << 24U)
378*a51d7062SLad Prabhakar #define DRVCTRL18_TX1(x)		((uint32_t)(x) << 20U)
379*a51d7062SLad Prabhakar #define DRVCTRL18_CTS1(x)		((uint32_t)(x) << 16U)
380*a51d7062SLad Prabhakar #define DRVCTRL18_RTS1_TANS(x)		((uint32_t)(x) << 12U)
381*a51d7062SLad Prabhakar #define DRVCTRL18_SCK2(x)		((uint32_t)(x) << 8U)
382*a51d7062SLad Prabhakar #define DRVCTRL18_TX2(x)		((uint32_t)(x) << 4U)
383*a51d7062SLad Prabhakar #define DRVCTRL18_RX2(x)		((uint32_t)(x) << 0U)
384*a51d7062SLad Prabhakar #define DRVCTRL19_HSCK0(x)		((uint32_t)(x) << 28U)
385*a51d7062SLad Prabhakar #define DRVCTRL19_HRX0(x)		((uint32_t)(x) << 24U)
386*a51d7062SLad Prabhakar #define DRVCTRL19_HTX0(x)		((uint32_t)(x) << 20U)
387*a51d7062SLad Prabhakar #define DRVCTRL19_HCTS0(x)		((uint32_t)(x) << 16U)
388*a51d7062SLad Prabhakar #define DRVCTRL19_HRTS0(x)		((uint32_t)(x) << 12U)
389*a51d7062SLad Prabhakar #define DRVCTRL19_MSIOF0_SCK(x)		((uint32_t)(x) << 8U)
390*a51d7062SLad Prabhakar #define DRVCTRL19_MSIOF0_SYNC(x)	((uint32_t)(x) << 4U)
391*a51d7062SLad Prabhakar #define DRVCTRL19_MSIOF0_SS1(x)		((uint32_t)(x) << 0U)
392*a51d7062SLad Prabhakar #define DRVCTRL20_MSIOF0_TXD(x)		((uint32_t)(x) << 28U)
393*a51d7062SLad Prabhakar #define DRVCTRL20_MSIOF0_SS2(x)		((uint32_t)(x) << 24U)
394*a51d7062SLad Prabhakar #define DRVCTRL20_MSIOF0_RXD(x)		((uint32_t)(x) << 20U)
395*a51d7062SLad Prabhakar #define DRVCTRL20_MLB_CLK(x)		((uint32_t)(x) << 16U)
396*a51d7062SLad Prabhakar #define DRVCTRL20_MLB_SIG(x)		((uint32_t)(x) << 12U)
397*a51d7062SLad Prabhakar #define DRVCTRL20_MLB_DAT(x)		((uint32_t)(x) << 8U)
398*a51d7062SLad Prabhakar #define DRVCTRL20_MLB_REF(x)		((uint32_t)(x) << 4U)
399*a51d7062SLad Prabhakar #define DRVCTRL20_SSI_SCK0129(x)	((uint32_t)(x) << 0U)
400*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_WS0129(x)		((uint32_t)(x) << 28U)
401*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_SDATA0(x)		((uint32_t)(x) << 24U)
402*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_SDATA1(x)		((uint32_t)(x) << 20U)
403*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_SDATA2(x)		((uint32_t)(x) << 16U)
404*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_SCK34(x)		((uint32_t)(x) << 12U)
405*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_WS34(x)		((uint32_t)(x) << 8U)
406*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_SDATA3(x)		((uint32_t)(x) << 4U)
407*a51d7062SLad Prabhakar #define DRVCTRL21_SSI_SCK4(x)		((uint32_t)(x) << 0U)
408*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_WS4(x)		((uint32_t)(x) << 28U)
409*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_SDATA4(x)		((uint32_t)(x) << 24U)
410*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_SCK5(x)		((uint32_t)(x) << 20U)
411*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_WS5(x)		((uint32_t)(x) << 16U)
412*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_SDATA5(x)		((uint32_t)(x) << 12U)
413*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_SCK6(x)		((uint32_t)(x) << 8U)
414*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_WS6(x)		((uint32_t)(x) << 4U)
415*a51d7062SLad Prabhakar #define DRVCTRL22_SSI_SDATA6(x)		((uint32_t)(x) << 0U)
416*a51d7062SLad Prabhakar #define DRVCTRL23_SSI_SCK78(x)		((uint32_t)(x) << 28U)
417*a51d7062SLad Prabhakar #define DRVCTRL23_SSI_WS78(x)		((uint32_t)(x) << 24U)
418*a51d7062SLad Prabhakar #define DRVCTRL23_SSI_SDATA7(x)		((uint32_t)(x) << 20U)
419*a51d7062SLad Prabhakar #define DRVCTRL23_SSI_SDATA8(x)		((uint32_t)(x) << 16U)
420*a51d7062SLad Prabhakar #define DRVCTRL23_SSI_SDATA9(x)		((uint32_t)(x) << 12U)
421*a51d7062SLad Prabhakar #define DRVCTRL23_AUDIO_CLKA(x)		((uint32_t)(x) << 8U)
422*a51d7062SLad Prabhakar #define DRVCTRL23_AUDIO_CLKB(x)		((uint32_t)(x) << 4U)
423*a51d7062SLad Prabhakar #define DRVCTRL23_USB0_PWEN(x)		((uint32_t)(x) << 0U)
424*a51d7062SLad Prabhakar #define DRVCTRL24_USB0_OVC(x)		((uint32_t)(x) << 28U)
425*a51d7062SLad Prabhakar #define DRVCTRL24_USB1_PWEN(x)		((uint32_t)(x) << 24U)
426*a51d7062SLad Prabhakar #define DRVCTRL24_USB1_OVC(x)		((uint32_t)(x) << 20U)
427*a51d7062SLad Prabhakar #define DRVCTRL24_USB30_PWEN(x)		((uint32_t)(x) << 16U)
428*a51d7062SLad Prabhakar #define DRVCTRL24_USB30_OVC(x)		((uint32_t)(x) << 12U)
429*a51d7062SLad Prabhakar #define DRVCTRL24_USB31_PWEN(x)		((uint32_t)(x) << 8U)
430*a51d7062SLad Prabhakar #define DRVCTRL24_USB31_OVC(x)		((uint32_t)(x) << 4U)
431*a51d7062SLad Prabhakar 
432*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF3_A		((uint32_t)0U << 29U)
433*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF3_B		((uint32_t)1U << 29U)
434*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF3_C		((uint32_t)2U << 29U)
435*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF3_D		((uint32_t)3U << 29U)
436*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF3_E		((uint32_t)4U << 29U)
437*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF2_A		((uint32_t)0U << 27U)
438*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF2_B		((uint32_t)1U << 27U)
439*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF2_C		((uint32_t)2U << 27U)
440*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF2_D		((uint32_t)3U << 27U)
441*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_A		((uint32_t)0U << 24U)
442*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_B		((uint32_t)1U << 24U)
443*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_C		((uint32_t)2U << 24U)
444*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_D		((uint32_t)3U << 24U)
445*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_E		((uint32_t)4U << 24U)
446*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_F		((uint32_t)5U << 24U)
447*a51d7062SLad Prabhakar #define MOD_SEL0_MSIOF1_G		((uint32_t)6U << 24U)
448*a51d7062SLad Prabhakar #define MOD_SEL0_LBSC_A			((uint32_t)0U << 23U)
449*a51d7062SLad Prabhakar #define MOD_SEL0_LBSC_B			((uint32_t)1U << 23U)
450*a51d7062SLad Prabhakar #define MOD_SEL0_IEBUS_A		((uint32_t)0U << 22U)
451*a51d7062SLad Prabhakar #define MOD_SEL0_IEBUS_B		((uint32_t)1U << 22U)
452*a51d7062SLad Prabhakar #define MOD_SEL0_I2C2_A			((uint32_t)0U << 21U)
453*a51d7062SLad Prabhakar #define MOD_SEL0_I2C2_B			((uint32_t)1U << 21U)
454*a51d7062SLad Prabhakar #define MOD_SEL0_I2C1_A			((uint32_t)0U << 20U)
455*a51d7062SLad Prabhakar #define MOD_SEL0_I2C1_B			((uint32_t)1U << 20U)
456*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF4_A		((uint32_t)0U << 19U)
457*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF4_B		((uint32_t)1U << 19U)
458*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF3_A		((uint32_t)0U << 17U)
459*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF3_B		((uint32_t)1U << 17U)
460*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF3_C		((uint32_t)2U << 17U)
461*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF3_D		((uint32_t)3U << 17U)
462*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF1_A		((uint32_t)0U << 16U)
463*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF1_B		((uint32_t)1U << 16U)
464*a51d7062SLad Prabhakar #define MOD_SEL0_FSO_A			((uint32_t)0U << 15U)
465*a51d7062SLad Prabhakar #define MOD_SEL0_FSO_B			((uint32_t)1U << 15U)
466*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF2_A		((uint32_t)0U << 13U)
467*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF2_B		((uint32_t)1U << 13U)
468*a51d7062SLad Prabhakar #define MOD_SEL0_HSCIF2_C		((uint32_t)2U << 13U)
469*a51d7062SLad Prabhakar #define MOD_SEL0_ETHERAVB_A		((uint32_t)0U << 12U)
470*a51d7062SLad Prabhakar #define MOD_SEL0_ETHERAVB_B		((uint32_t)1U << 12U)
471*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF3_A		((uint32_t)0U << 11U)
472*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF3_B		((uint32_t)1U << 11U)
473*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF2_A		((uint32_t)0U << 10U)
474*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF2_B		((uint32_t)1U << 10U)
475*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF1_A		((uint32_t)0U << 8U)
476*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF1_B		((uint32_t)1U << 8U)
477*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF1_C		((uint32_t)2U << 8U)
478*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF0_A		((uint32_t)0U << 6U)
479*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF0_B		((uint32_t)1U << 6U)
480*a51d7062SLad Prabhakar #define MOD_SEL0_DRIF0_C		((uint32_t)2U << 6U)
481*a51d7062SLad Prabhakar #define MOD_SEL0_CANFD0_A		((uint32_t)0U << 5U)
482*a51d7062SLad Prabhakar #define MOD_SEL0_CANFD0_B		((uint32_t)1U << 5U)
483*a51d7062SLad Prabhakar #define MOD_SEL0_ADG_A_A		((uint32_t)0U << 3U)
484*a51d7062SLad Prabhakar #define MOD_SEL0_ADG_A_B		((uint32_t)1U << 3U)
485*a51d7062SLad Prabhakar #define MOD_SEL0_ADG_A_C		((uint32_t)2U << 3U)
486*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF1_A		((uint32_t)0U << 30U)
487*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF1_B		((uint32_t)1U << 30U)
488*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF1_C		((uint32_t)2U << 30U)
489*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF1_D		((uint32_t)3U << 30U)
490*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF0_A		((uint32_t)0U << 27U)
491*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF0_B		((uint32_t)1U << 27U)
492*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF0_C		((uint32_t)2U << 27U)
493*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF0_D		((uint32_t)3U << 27U)
494*a51d7062SLad Prabhakar #define MOD_SEL1_TSIF0_E		((uint32_t)4U << 27U)
495*a51d7062SLad Prabhakar #define MOD_SEL1_TIMER_TMU_A		((uint32_t)0U << 26U)
496*a51d7062SLad Prabhakar #define MOD_SEL1_TIMER_TMU_B		((uint32_t)1U << 26U)
497*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_1_A		((uint32_t)0U << 24U)
498*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_1_B		((uint32_t)1U << 24U)
499*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_1_C		((uint32_t)2U << 24U)
500*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_1_D		((uint32_t)3U << 24U)
501*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_0_A		((uint32_t)0U << 21U)
502*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_0_B		((uint32_t)1U << 21U)
503*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_0_C		((uint32_t)2U << 21U)
504*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_0_D		((uint32_t)3U << 21U)
505*a51d7062SLad Prabhakar #define MOD_SEL1_SSP1_0_E		((uint32_t)4U << 21U)
506*a51d7062SLad Prabhakar #define MOD_SEL1_SSI_A			((uint32_t)0U << 20U)
507*a51d7062SLad Prabhakar #define MOD_SEL1_SSI_B			((uint32_t)1U << 20U)
508*a51d7062SLad Prabhakar #define MOD_SEL1_SPEED_PULSE_IF_A	((uint32_t)0U << 19U)
509*a51d7062SLad Prabhakar #define MOD_SEL1_SPEED_PULSE_IF_B	((uint32_t)1U << 19U)
510*a51d7062SLad Prabhakar #define MOD_SEL1_SIMCARD_A		((uint32_t)0U << 17U)
511*a51d7062SLad Prabhakar #define MOD_SEL1_SIMCARD_B		((uint32_t)1U << 17U)
512*a51d7062SLad Prabhakar #define MOD_SEL1_SIMCARD_C		((uint32_t)2U << 17U)
513*a51d7062SLad Prabhakar #define MOD_SEL1_SIMCARD_D		((uint32_t)3U << 17U)
514*a51d7062SLad Prabhakar #define MOD_SEL1_SDHI2_A		((uint32_t)0U << 16U)
515*a51d7062SLad Prabhakar #define MOD_SEL1_SDHI2_B		((uint32_t)1U << 16U)
516*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF4_A		((uint32_t)0U << 14U)
517*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF4_B		((uint32_t)1U << 14U)
518*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF4_C		((uint32_t)2U << 14U)
519*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF3_A		((uint32_t)0U << 13U)
520*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF3_B		((uint32_t)1U << 13U)
521*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF2_A		((uint32_t)0U << 12U)
522*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF2_B		((uint32_t)1U << 12U)
523*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF1_A		((uint32_t)0U << 11U)
524*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF1_B		((uint32_t)1U << 11U)
525*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF_A			((uint32_t)0U << 10U)
526*a51d7062SLad Prabhakar #define MOD_SEL1_SCIF_B			((uint32_t)1U << 10U)
527*a51d7062SLad Prabhakar #define MOD_SEL1_REMOCON_A		((uint32_t)0U << 9U)
528*a51d7062SLad Prabhakar #define MOD_SEL1_REMOCON_B		((uint32_t)1U << 9U)
529*a51d7062SLad Prabhakar #define MOD_SEL1_RCAN0_A		((uint32_t)0U << 6U)
530*a51d7062SLad Prabhakar #define MOD_SEL1_RCAN0_B		((uint32_t)1U << 6U)
531*a51d7062SLad Prabhakar #define MOD_SEL1_PWM6_A			((uint32_t)0U << 5U)
532*a51d7062SLad Prabhakar #define MOD_SEL1_PWM6_B			((uint32_t)1U << 5U)
533*a51d7062SLad Prabhakar #define MOD_SEL1_PWM5_A			((uint32_t)0U << 4U)
534*a51d7062SLad Prabhakar #define MOD_SEL1_PWM5_B			((uint32_t)1U << 4U)
535*a51d7062SLad Prabhakar #define MOD_SEL1_PWM4_A			((uint32_t)0U << 3U)
536*a51d7062SLad Prabhakar #define MOD_SEL1_PWM4_B			((uint32_t)1U << 3U)
537*a51d7062SLad Prabhakar #define MOD_SEL1_PWM3_A			((uint32_t)0U << 2U)
538*a51d7062SLad Prabhakar #define MOD_SEL1_PWM3_B			((uint32_t)1U << 2U)
539*a51d7062SLad Prabhakar #define MOD_SEL1_PWM2_A			((uint32_t)0U << 1U)
540*a51d7062SLad Prabhakar #define MOD_SEL1_PWM2_B			((uint32_t)1U << 1U)
541*a51d7062SLad Prabhakar #define MOD_SEL1_PWM1_A			((uint32_t)0U << 0U)
542*a51d7062SLad Prabhakar #define MOD_SEL1_PWM1_B			((uint32_t)1U << 0U)
543*a51d7062SLad Prabhakar #define MOD_SEL2_I2C_5_A		((uint32_t)0U << 31U)
544*a51d7062SLad Prabhakar #define MOD_SEL2_I2C_5_B		((uint32_t)1U << 31U)
545*a51d7062SLad Prabhakar #define MOD_SEL2_I2C_3_A		((uint32_t)0U << 30U)
546*a51d7062SLad Prabhakar #define MOD_SEL2_I2C_3_B		((uint32_t)1U << 30U)
547*a51d7062SLad Prabhakar #define MOD_SEL2_I2C_0_A		((uint32_t)0U << 29U)
548*a51d7062SLad Prabhakar #define MOD_SEL2_I2C_0_B		((uint32_t)1U << 29U)
549*a51d7062SLad Prabhakar #define MOD_SEL2_FM_A			((uint32_t)0U << 27U)
550*a51d7062SLad Prabhakar #define MOD_SEL2_FM_B			((uint32_t)1U << 27U)
551*a51d7062SLad Prabhakar #define MOD_SEL2_FM_C			((uint32_t)2U << 27U)
552*a51d7062SLad Prabhakar #define MOD_SEL2_FM_D			((uint32_t)3U << 27U)
553*a51d7062SLad Prabhakar #define MOD_SEL2_SCIF5_A		((uint32_t)0U << 26U)
554*a51d7062SLad Prabhakar #define MOD_SEL2_SCIF5_B		((uint32_t)1U << 26U)
555*a51d7062SLad Prabhakar #define MOD_SEL2_I2C6_A			((uint32_t)0U << 23U)
556*a51d7062SLad Prabhakar #define MOD_SEL2_I2C6_B			((uint32_t)1U << 23U)
557*a51d7062SLad Prabhakar #define MOD_SEL2_I2C6_C			((uint32_t)2U << 23U)
558*a51d7062SLad Prabhakar #define MOD_SEL2_NDF_A			((uint32_t)0U << 22U)
559*a51d7062SLad Prabhakar #define MOD_SEL2_NDF_B			((uint32_t)1U << 22U)
560*a51d7062SLad Prabhakar #define MOD_SEL2_SSI2_A			((uint32_t)0U << 21U)
561*a51d7062SLad Prabhakar #define MOD_SEL2_SSI2_B			((uint32_t)1U << 21U)
562*a51d7062SLad Prabhakar #define MOD_SEL2_SSI9_A			((uint32_t)0U << 20U)
563*a51d7062SLad Prabhakar #define MOD_SEL2_SSI9_B			((uint32_t)1U << 20U)
564*a51d7062SLad Prabhakar #define MOD_SEL2_TIMER_TMU2_A		((uint32_t)0U << 19U)
565*a51d7062SLad Prabhakar #define MOD_SEL2_TIMER_TMU2_B		((uint32_t)1U << 19U)
566*a51d7062SLad Prabhakar #define MOD_SEL2_ADG_B_A		((uint32_t)0U << 18U)
567*a51d7062SLad Prabhakar #define MOD_SEL2_ADG_B_B		((uint32_t)1U << 18U)
568*a51d7062SLad Prabhakar #define MOD_SEL2_ADG_C_A		((uint32_t)0U << 17U)
569*a51d7062SLad Prabhakar #define MOD_SEL2_ADG_C_B		((uint32_t)1U << 17U)
570*a51d7062SLad Prabhakar #define MOD_SEL2_VIN4_A			((uint32_t)0U << 0U)
571*a51d7062SLad Prabhakar #define MOD_SEL2_VIN4_B			((uint32_t)1U << 0U)
572*a51d7062SLad Prabhakar 
pfc_reg_write(uint32_t addr,uint32_t data)573*a51d7062SLad Prabhakar static void pfc_reg_write(uint32_t addr, uint32_t data)
574*a51d7062SLad Prabhakar {
575*a51d7062SLad Prabhakar 	mmio_write_32(PFC_PMMR, ~data);
576*a51d7062SLad Prabhakar 	mmio_write_32((uintptr_t)addr, data);
577*a51d7062SLad Prabhakar }
578*a51d7062SLad Prabhakar 
pfc_init_g2h(void)579*a51d7062SLad Prabhakar void pfc_init_g2h(void)
580*a51d7062SLad Prabhakar {
581*a51d7062SLad Prabhakar 	uint32_t reg;
582*a51d7062SLad Prabhakar 
583*a51d7062SLad Prabhakar 	/* initialize module select */
584*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_MOD_SEL0,
585*a51d7062SLad Prabhakar 		      MOD_SEL0_MSIOF3_A |
586*a51d7062SLad Prabhakar 		      MOD_SEL0_MSIOF2_A |
587*a51d7062SLad Prabhakar 		      MOD_SEL0_MSIOF1_A |
588*a51d7062SLad Prabhakar 		      MOD_SEL0_LBSC_A |
589*a51d7062SLad Prabhakar 		      MOD_SEL0_IEBUS_A |
590*a51d7062SLad Prabhakar 		      MOD_SEL0_I2C2_A |
591*a51d7062SLad Prabhakar 		      MOD_SEL0_I2C1_A |
592*a51d7062SLad Prabhakar 		      MOD_SEL0_HSCIF4_A |
593*a51d7062SLad Prabhakar 		      MOD_SEL0_HSCIF3_A |
594*a51d7062SLad Prabhakar 		      MOD_SEL0_HSCIF1_A |
595*a51d7062SLad Prabhakar 		      MOD_SEL0_FSO_A |
596*a51d7062SLad Prabhakar 		      MOD_SEL0_HSCIF2_A |
597*a51d7062SLad Prabhakar 		      MOD_SEL0_ETHERAVB_A |
598*a51d7062SLad Prabhakar 		      MOD_SEL0_DRIF3_A |
599*a51d7062SLad Prabhakar 		      MOD_SEL0_DRIF2_A |
600*a51d7062SLad Prabhakar 		      MOD_SEL0_DRIF1_A |
601*a51d7062SLad Prabhakar 		      MOD_SEL0_DRIF0_A |
602*a51d7062SLad Prabhakar 		      MOD_SEL0_CANFD0_A |
603*a51d7062SLad Prabhakar 		      MOD_SEL0_ADG_A_A);
604*a51d7062SLad Prabhakar 
605*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_MOD_SEL1,
606*a51d7062SLad Prabhakar 		      MOD_SEL1_TSIF1_A |
607*a51d7062SLad Prabhakar 		      MOD_SEL1_TSIF0_A |
608*a51d7062SLad Prabhakar 		      MOD_SEL1_TIMER_TMU_A |
609*a51d7062SLad Prabhakar 		      MOD_SEL1_SSP1_1_A |
610*a51d7062SLad Prabhakar 		      MOD_SEL1_SSP1_0_A |
611*a51d7062SLad Prabhakar 		      MOD_SEL1_SSI_A |
612*a51d7062SLad Prabhakar 		      MOD_SEL1_SPEED_PULSE_IF_A |
613*a51d7062SLad Prabhakar 		      MOD_SEL1_SIMCARD_A |
614*a51d7062SLad Prabhakar 		      MOD_SEL1_SDHI2_A |
615*a51d7062SLad Prabhakar 		      MOD_SEL1_SCIF4_A |
616*a51d7062SLad Prabhakar 		      MOD_SEL1_SCIF3_A |
617*a51d7062SLad Prabhakar 		      MOD_SEL1_SCIF2_A |
618*a51d7062SLad Prabhakar 		      MOD_SEL1_SCIF1_A |
619*a51d7062SLad Prabhakar 		      MOD_SEL1_SCIF_A |
620*a51d7062SLad Prabhakar 		      MOD_SEL1_REMOCON_A |
621*a51d7062SLad Prabhakar 		      MOD_SEL1_RCAN0_A |
622*a51d7062SLad Prabhakar 		      MOD_SEL1_PWM6_A |
623*a51d7062SLad Prabhakar 		      MOD_SEL1_PWM5_A |
624*a51d7062SLad Prabhakar 		      MOD_SEL1_PWM4_A |
625*a51d7062SLad Prabhakar 		      MOD_SEL1_PWM3_A |
626*a51d7062SLad Prabhakar 		      MOD_SEL1_PWM2_A |
627*a51d7062SLad Prabhakar 		      MOD_SEL1_PWM1_A);
628*a51d7062SLad Prabhakar 
629*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_MOD_SEL2,
630*a51d7062SLad Prabhakar 		      MOD_SEL2_I2C_5_B |
631*a51d7062SLad Prabhakar 		      MOD_SEL2_I2C_3_B |
632*a51d7062SLad Prabhakar 		      MOD_SEL2_I2C_0_B |
633*a51d7062SLad Prabhakar 		      MOD_SEL2_FM_A |
634*a51d7062SLad Prabhakar 		      MOD_SEL2_SCIF5_A |
635*a51d7062SLad Prabhakar 		      MOD_SEL2_I2C6_A |
636*a51d7062SLad Prabhakar 		      MOD_SEL2_NDF_A |
637*a51d7062SLad Prabhakar 		      MOD_SEL2_SSI2_A |
638*a51d7062SLad Prabhakar 		      MOD_SEL2_SSI9_A |
639*a51d7062SLad Prabhakar 		      MOD_SEL2_TIMER_TMU2_A |
640*a51d7062SLad Prabhakar 		      MOD_SEL2_ADG_B_A |
641*a51d7062SLad Prabhakar 		      MOD_SEL2_ADG_C_A |
642*a51d7062SLad Prabhakar 		      MOD_SEL2_VIN4_A);
643*a51d7062SLad Prabhakar 
644*a51d7062SLad Prabhakar 	/* initialize peripheral function select */
645*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR0,
646*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
647*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
648*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
649*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
650*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
651*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
652*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
653*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
654*a51d7062SLad Prabhakar 
655*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR1,
656*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(6) |
657*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
658*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
659*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
660*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(3) |
661*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(3) |
662*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(3) |
663*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(3));
664*a51d7062SLad Prabhakar 
665*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR2,
666*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
667*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(6) |
668*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(6) |
669*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(6) |
670*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(6) |
671*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(6) |
672*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(6) |
673*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(6));
674*a51d7062SLad Prabhakar 
675*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR3,
676*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(6) |
677*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(6) |
678*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(6) |
679*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(6) |
680*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(6) |
681*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
682*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
683*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
684*a51d7062SLad Prabhakar 
685*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR4,
686*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
687*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
688*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
689*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
690*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
691*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(6) |
692*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(6) |
693*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(6));
694*a51d7062SLad Prabhakar 
695*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR5,
696*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
697*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
698*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
699*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
700*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
701*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(6) |
702*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
703*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
704*a51d7062SLad Prabhakar 
705*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR6,
706*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(6) |
707*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(6) |
708*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(6) |
709*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(6) |
710*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(6) |
711*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
712*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
713*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
714*a51d7062SLad Prabhakar 
715*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR7,
716*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
717*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
718*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
719*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
720*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
721*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(6) |
722*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(6) |
723*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(6));
724*a51d7062SLad Prabhakar 
725*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR8,
726*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(1) |
727*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(1) |
728*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(1) |
729*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(1) |
730*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
731*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
732*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
733*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
734*a51d7062SLad Prabhakar 
735*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR9,
736*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
737*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
738*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
739*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
740*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
741*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
742*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
743*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
744*a51d7062SLad Prabhakar 
745*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR10,
746*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
747*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
748*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
749*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
750*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
751*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
752*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
753*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
754*a51d7062SLad Prabhakar 
755*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR11,
756*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
757*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(4) |
758*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
759*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
760*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
761*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
762*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
763*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
764*a51d7062SLad Prabhakar 
765*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR12,
766*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
767*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
768*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
769*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
770*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
771*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(4) |
772*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
773*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
774*a51d7062SLad Prabhakar 
775*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR13,
776*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(8) |
777*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
778*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
779*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
780*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
781*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(3) |
782*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
783*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
784*a51d7062SLad Prabhakar 
785*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR14,
786*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
787*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
788*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
789*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
790*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
791*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
792*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(3) |
793*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(8));
794*a51d7062SLad Prabhakar 
795*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR15,
796*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
797*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
798*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
799*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
800*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
801*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
802*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
803*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
804*a51d7062SLad Prabhakar 
805*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR16,
806*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
807*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
808*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
809*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
810*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
811*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
812*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
813*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
814*a51d7062SLad Prabhakar 
815*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR17,
816*a51d7062SLad Prabhakar 		      IPSR_28_FUNC(0) |
817*a51d7062SLad Prabhakar 		      IPSR_24_FUNC(0) |
818*a51d7062SLad Prabhakar 		      IPSR_20_FUNC(0) |
819*a51d7062SLad Prabhakar 		      IPSR_16_FUNC(0) |
820*a51d7062SLad Prabhakar 		      IPSR_12_FUNC(0) |
821*a51d7062SLad Prabhakar 		      IPSR_8_FUNC(0) |
822*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(1) |
823*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
824*a51d7062SLad Prabhakar 
825*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_IPSR18,
826*a51d7062SLad Prabhakar 		      IPSR_4_FUNC(0) |
827*a51d7062SLad Prabhakar 		      IPSR_0_FUNC(0));
828*a51d7062SLad Prabhakar 
829*a51d7062SLad Prabhakar 	/* initialize GPIO/peripheral function select */
830*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR0,
831*a51d7062SLad Prabhakar 		      GPSR0_D15 |
832*a51d7062SLad Prabhakar 		      GPSR0_D14 |
833*a51d7062SLad Prabhakar 		      GPSR0_D13 |
834*a51d7062SLad Prabhakar 		      GPSR0_D12 |
835*a51d7062SLad Prabhakar 		      GPSR0_D11 |
836*a51d7062SLad Prabhakar 		      GPSR0_D10 |
837*a51d7062SLad Prabhakar 		      GPSR0_D9 |
838*a51d7062SLad Prabhakar 		      GPSR0_D8 |
839*a51d7062SLad Prabhakar 		      GPSR0_D7 |
840*a51d7062SLad Prabhakar 		      GPSR0_D6 |
841*a51d7062SLad Prabhakar 		      GPSR0_D5 |
842*a51d7062SLad Prabhakar 		      GPSR0_D4 |
843*a51d7062SLad Prabhakar 		      GPSR0_D3 |
844*a51d7062SLad Prabhakar 		      GPSR0_D2 |
845*a51d7062SLad Prabhakar 		      GPSR0_D0);
846*a51d7062SLad Prabhakar 
847*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR1,
848*a51d7062SLad Prabhakar 		      GPSR1_CLKOUT |
849*a51d7062SLad Prabhakar 		      GPSR1_EX_WAIT0_A |
850*a51d7062SLad Prabhakar 		      GPSR1_WE1 |
851*a51d7062SLad Prabhakar 		      GPSR1_RD |
852*a51d7062SLad Prabhakar 		      GPSR1_RD_WR |
853*a51d7062SLad Prabhakar 		      GPSR1_CS0 |
854*a51d7062SLad Prabhakar 		      GPSR1_A19 |
855*a51d7062SLad Prabhakar 		      GPSR1_A18 |
856*a51d7062SLad Prabhakar 		      GPSR1_A17 |
857*a51d7062SLad Prabhakar 		      GPSR1_A16 |
858*a51d7062SLad Prabhakar 		      GPSR1_A15 |
859*a51d7062SLad Prabhakar 		      GPSR1_A14 |
860*a51d7062SLad Prabhakar 		      GPSR1_A13 |
861*a51d7062SLad Prabhakar 		      GPSR1_A12 |
862*a51d7062SLad Prabhakar 		      GPSR1_A7 |
863*a51d7062SLad Prabhakar 		      GPSR1_A6 |
864*a51d7062SLad Prabhakar 		      GPSR1_A5 |
865*a51d7062SLad Prabhakar 		      GPSR1_A4 |
866*a51d7062SLad Prabhakar 		      GPSR1_A3 |
867*a51d7062SLad Prabhakar 		      GPSR1_A2 |
868*a51d7062SLad Prabhakar 		      GPSR1_A1 |
869*a51d7062SLad Prabhakar 		      GPSR1_A0);
870*a51d7062SLad Prabhakar 
871*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR2,
872*a51d7062SLad Prabhakar 		      GPSR2_AVB_AVTP_CAPTURE_A |
873*a51d7062SLad Prabhakar 		      GPSR2_AVB_AVTP_MATCH_A |
874*a51d7062SLad Prabhakar 		      GPSR2_AVB_LINK |
875*a51d7062SLad Prabhakar 		      GPSR2_AVB_PHY_INT |
876*a51d7062SLad Prabhakar 		      GPSR2_AVB_MDC |
877*a51d7062SLad Prabhakar 		      GPSR2_PWM2_A |
878*a51d7062SLad Prabhakar 		      GPSR2_PWM1_A |
879*a51d7062SLad Prabhakar 		      GPSR2_IRQ4 |
880*a51d7062SLad Prabhakar 		      GPSR2_IRQ3 |
881*a51d7062SLad Prabhakar 		      GPSR2_IRQ2 |
882*a51d7062SLad Prabhakar 		      GPSR2_IRQ1 |
883*a51d7062SLad Prabhakar 		      GPSR2_IRQ0);
884*a51d7062SLad Prabhakar 
885*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR3,
886*a51d7062SLad Prabhakar 		      GPSR3_SD0_CD |
887*a51d7062SLad Prabhakar 		      GPSR3_SD1_DAT3 |
888*a51d7062SLad Prabhakar 		      GPSR3_SD1_DAT2 |
889*a51d7062SLad Prabhakar 		      GPSR3_SD1_DAT1 |
890*a51d7062SLad Prabhakar 		      GPSR3_SD1_DAT0 |
891*a51d7062SLad Prabhakar 		      GPSR3_SD0_DAT3 |
892*a51d7062SLad Prabhakar 		      GPSR3_SD0_DAT2 |
893*a51d7062SLad Prabhakar 		      GPSR3_SD0_DAT1 |
894*a51d7062SLad Prabhakar 		      GPSR3_SD0_DAT0 |
895*a51d7062SLad Prabhakar 		      GPSR3_SD0_CMD |
896*a51d7062SLad Prabhakar 		      GPSR3_SD0_CLK);
897*a51d7062SLad Prabhakar 
898*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR4,
899*a51d7062SLad Prabhakar 		      GPSR4_SD3_DS |
900*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT7 |
901*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT6 |
902*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT5 |
903*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT4 |
904*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT3 |
905*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT2 |
906*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT1 |
907*a51d7062SLad Prabhakar 		      GPSR4_SD3_DAT0 |
908*a51d7062SLad Prabhakar 		      GPSR4_SD3_CMD |
909*a51d7062SLad Prabhakar 		      GPSR4_SD3_CLK |
910*a51d7062SLad Prabhakar 		      GPSR4_SD2_DAT3 |
911*a51d7062SLad Prabhakar 		      GPSR4_SD2_DAT2 |
912*a51d7062SLad Prabhakar 		      GPSR4_SD2_DAT1 |
913*a51d7062SLad Prabhakar 		      GPSR4_SD2_DAT0 |
914*a51d7062SLad Prabhakar 		      GPSR4_SD2_CMD |
915*a51d7062SLad Prabhakar 		      GPSR4_SD2_CLK);
916*a51d7062SLad Prabhakar 
917*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR5,
918*a51d7062SLad Prabhakar 		      GPSR5_MSIOF0_RXD |
919*a51d7062SLad Prabhakar 		      GPSR5_MSIOF0_TXD |
920*a51d7062SLad Prabhakar 		      GPSR5_MSIOF0_SYNC |
921*a51d7062SLad Prabhakar 		      GPSR5_MSIOF0_SCK |
922*a51d7062SLad Prabhakar 		      GPSR5_RX2_A |
923*a51d7062SLad Prabhakar 		      GPSR5_TX2_A |
924*a51d7062SLad Prabhakar 		      GPSR5_RTS1 |
925*a51d7062SLad Prabhakar 		      GPSR5_CTS1 |
926*a51d7062SLad Prabhakar 		      GPSR5_TX1_A |
927*a51d7062SLad Prabhakar 		      GPSR5_RX1_A |
928*a51d7062SLad Prabhakar 		      GPSR5_RTS0 |
929*a51d7062SLad Prabhakar 		      GPSR5_SCK0);
930*a51d7062SLad Prabhakar 
931*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR6,
932*a51d7062SLad Prabhakar 		      GPSR6_AUDIO_CLKB_B |
933*a51d7062SLad Prabhakar 		      GPSR6_AUDIO_CLKA_A |
934*a51d7062SLad Prabhakar 		      GPSR6_SSI_WS6 |
935*a51d7062SLad Prabhakar 		      GPSR6_SSI_SCK6 |
936*a51d7062SLad Prabhakar 		      GPSR6_SSI_SDATA4 |
937*a51d7062SLad Prabhakar 		      GPSR6_SSI_WS4 |
938*a51d7062SLad Prabhakar 		      GPSR6_SSI_SCK4 |
939*a51d7062SLad Prabhakar 		      GPSR6_SSI_SDATA1_A |
940*a51d7062SLad Prabhakar 		      GPSR6_SSI_SDATA0 |
941*a51d7062SLad Prabhakar 		      GPSR6_SSI_WS0129 |
942*a51d7062SLad Prabhakar 		      GPSR6_SSI_SCK0129);
943*a51d7062SLad Prabhakar 
944*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_GPSR7,
945*a51d7062SLad Prabhakar 		      GPSR7_AVS2 |
946*a51d7062SLad Prabhakar 		      GPSR7_AVS1);
947*a51d7062SLad Prabhakar 
948*a51d7062SLad Prabhakar 	/* initialize POC control register */
949*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_POCCTRL0,
950*a51d7062SLad Prabhakar 		      POC_SD0_DAT3_33V |
951*a51d7062SLad Prabhakar 		      POC_SD0_DAT2_33V |
952*a51d7062SLad Prabhakar 		      POC_SD0_DAT1_33V |
953*a51d7062SLad Prabhakar 		      POC_SD0_DAT0_33V |
954*a51d7062SLad Prabhakar 		      POC_SD0_CMD_33V |
955*a51d7062SLad Prabhakar 		      POC_SD0_CLK_33V);
956*a51d7062SLad Prabhakar 
957*a51d7062SLad Prabhakar 	/* initialize DRV control register */
958*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL0);
959*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL0_MASK) |
960*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI0_SPCLK(3) |
961*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI0_MOSI_IO0(3) |
962*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI0_MISO_IO1(3) |
963*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI0_IO2(3) |
964*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI0_IO3(3) |
965*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI0_SSL(3) |
966*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI1_SPCLK(3) |
967*a51d7062SLad Prabhakar 	      DRVCTRL0_QSPI1_MOSI_IO0(3);
968*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL0, reg);
969*a51d7062SLad Prabhakar 
970*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL1);
971*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL1_MASK) |
972*a51d7062SLad Prabhakar 	      DRVCTRL1_QSPI1_MISO_IO1(3) |
973*a51d7062SLad Prabhakar 	      DRVCTRL1_QSPI1_IO2(3) |
974*a51d7062SLad Prabhakar 	      DRVCTRL1_QSPI1_IO3(3) |
975*a51d7062SLad Prabhakar 	      DRVCTRL1_QSPI1_SS(3) |
976*a51d7062SLad Prabhakar 	      DRVCTRL1_RPC_INT(3) |
977*a51d7062SLad Prabhakar 	      DRVCTRL1_RPC_WP(3) |
978*a51d7062SLad Prabhakar 	      DRVCTRL1_RPC_RESET(3) |
979*a51d7062SLad Prabhakar 	      DRVCTRL1_AVB_RX_CTL(7);
980*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL1, reg);
981*a51d7062SLad Prabhakar 
982*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL2);
983*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL2_MASK) |
984*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_RXC(7) |
985*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_RD0(7) |
986*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_RD1(7) |
987*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_RD2(7) |
988*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_RD3(7) |
989*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_TX_CTL(3) |
990*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_TXC(3) |
991*a51d7062SLad Prabhakar 	      DRVCTRL2_AVB_TD0(3);
992*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL2, reg);
993*a51d7062SLad Prabhakar 
994*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL3);
995*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL3_MASK) |
996*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_TD1(3) |
997*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_TD2(3) |
998*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_TD3(3) |
999*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_TXCREFCLK(7) |
1000*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_MDIO(7) |
1001*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_MDC(7) |
1002*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_MAGIC(7) |
1003*a51d7062SLad Prabhakar 	      DRVCTRL3_AVB_PHY_INT(7);
1004*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL3, reg);
1005*a51d7062SLad Prabhakar 
1006*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL4);
1007*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL4_MASK) |
1008*a51d7062SLad Prabhakar 	      DRVCTRL4_AVB_LINK(7) |
1009*a51d7062SLad Prabhakar 	      DRVCTRL4_AVB_AVTP_MATCH(7) |
1010*a51d7062SLad Prabhakar 	      DRVCTRL4_AVB_AVTP_CAPTURE(7) |
1011*a51d7062SLad Prabhakar 	      DRVCTRL4_IRQ0(7) |
1012*a51d7062SLad Prabhakar 	      DRVCTRL4_IRQ1(7) |
1013*a51d7062SLad Prabhakar 	      DRVCTRL4_IRQ2(7) |
1014*a51d7062SLad Prabhakar 	      DRVCTRL4_IRQ3(7) |
1015*a51d7062SLad Prabhakar 	      DRVCTRL4_IRQ4(7);
1016*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL4, reg);
1017*a51d7062SLad Prabhakar 
1018*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL5);
1019*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL5_MASK) |
1020*a51d7062SLad Prabhakar 	      DRVCTRL5_IRQ5(7) |
1021*a51d7062SLad Prabhakar 	      DRVCTRL5_PWM0(7) |
1022*a51d7062SLad Prabhakar 	      DRVCTRL5_PWM1(7) |
1023*a51d7062SLad Prabhakar 	      DRVCTRL5_PWM2(7) |
1024*a51d7062SLad Prabhakar 	      DRVCTRL5_A0(3) |
1025*a51d7062SLad Prabhakar 	      DRVCTRL5_A1(3) |
1026*a51d7062SLad Prabhakar 	      DRVCTRL5_A2(3) |
1027*a51d7062SLad Prabhakar 	      DRVCTRL5_A3(3);
1028*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL5, reg);
1029*a51d7062SLad Prabhakar 
1030*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL6);
1031*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL6_MASK) |
1032*a51d7062SLad Prabhakar 	      DRVCTRL6_A4(3) |
1033*a51d7062SLad Prabhakar 	      DRVCTRL6_A5(3) |
1034*a51d7062SLad Prabhakar 	      DRVCTRL6_A6(3) |
1035*a51d7062SLad Prabhakar 	      DRVCTRL6_A7(3) |
1036*a51d7062SLad Prabhakar 	      DRVCTRL6_A8(7) |
1037*a51d7062SLad Prabhakar 	      DRVCTRL6_A9(7) |
1038*a51d7062SLad Prabhakar 	      DRVCTRL6_A10(7) |
1039*a51d7062SLad Prabhakar 	      DRVCTRL6_A11(7);
1040*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL6, reg);
1041*a51d7062SLad Prabhakar 
1042*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL7);
1043*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL7_MASK) |
1044*a51d7062SLad Prabhakar 	      DRVCTRL7_A12(3) |
1045*a51d7062SLad Prabhakar 	      DRVCTRL7_A13(3) |
1046*a51d7062SLad Prabhakar 	      DRVCTRL7_A14(3) |
1047*a51d7062SLad Prabhakar 	      DRVCTRL7_A15(3) |
1048*a51d7062SLad Prabhakar 	      DRVCTRL7_A16(3) |
1049*a51d7062SLad Prabhakar 	      DRVCTRL7_A17(3) |
1050*a51d7062SLad Prabhakar 	      DRVCTRL7_A18(3) |
1051*a51d7062SLad Prabhakar 	      DRVCTRL7_A19(3);
1052*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL7, reg);
1053*a51d7062SLad Prabhakar 
1054*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL8);
1055*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL8_MASK) |
1056*a51d7062SLad Prabhakar 	      DRVCTRL8_CLKOUT(7) |
1057*a51d7062SLad Prabhakar 	      DRVCTRL8_CS0(7) |
1058*a51d7062SLad Prabhakar 	      DRVCTRL8_CS1_A2(7) |
1059*a51d7062SLad Prabhakar 	      DRVCTRL8_BS(7) |
1060*a51d7062SLad Prabhakar 	      DRVCTRL8_RD(7) |
1061*a51d7062SLad Prabhakar 	      DRVCTRL8_RD_W(7) |
1062*a51d7062SLad Prabhakar 	      DRVCTRL8_WE0(7) |
1063*a51d7062SLad Prabhakar 	      DRVCTRL8_WE1(7);
1064*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL8, reg);
1065*a51d7062SLad Prabhakar 
1066*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL9);
1067*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL9_MASK) |
1068*a51d7062SLad Prabhakar 	      DRVCTRL9_EX_WAIT0(7) |
1069*a51d7062SLad Prabhakar 	      DRVCTRL9_PRESETOU(7) |
1070*a51d7062SLad Prabhakar 	      DRVCTRL9_D0(7) |
1071*a51d7062SLad Prabhakar 	      DRVCTRL9_D1(7) |
1072*a51d7062SLad Prabhakar 	      DRVCTRL9_D2(7) |
1073*a51d7062SLad Prabhakar 	      DRVCTRL9_D3(7) |
1074*a51d7062SLad Prabhakar 	      DRVCTRL9_D4(7) |
1075*a51d7062SLad Prabhakar 	      DRVCTRL9_D5(7);
1076*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL9, reg);
1077*a51d7062SLad Prabhakar 
1078*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL10);
1079*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL10_MASK) |
1080*a51d7062SLad Prabhakar 	      DRVCTRL10_D6(7) |
1081*a51d7062SLad Prabhakar 	      DRVCTRL10_D7(7) |
1082*a51d7062SLad Prabhakar 	      DRVCTRL10_D8(3) |
1083*a51d7062SLad Prabhakar 	      DRVCTRL10_D9(3) |
1084*a51d7062SLad Prabhakar 	      DRVCTRL10_D10(3) |
1085*a51d7062SLad Prabhakar 	      DRVCTRL10_D11(3) |
1086*a51d7062SLad Prabhakar 	      DRVCTRL10_D12(3) |
1087*a51d7062SLad Prabhakar 	      DRVCTRL10_D13(3);
1088*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL10, reg);
1089*a51d7062SLad Prabhakar 
1090*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL11);
1091*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL11_MASK) |
1092*a51d7062SLad Prabhakar 	      DRVCTRL11_D14(3) |
1093*a51d7062SLad Prabhakar 	      DRVCTRL11_D15(3) |
1094*a51d7062SLad Prabhakar 	      DRVCTRL11_AVS1(7) |
1095*a51d7062SLad Prabhakar 	      DRVCTRL11_AVS2(7) |
1096*a51d7062SLad Prabhakar 	      DRVCTRL11_GP7_02(7) |
1097*a51d7062SLad Prabhakar 	      DRVCTRL11_GP7_03(7) |
1098*a51d7062SLad Prabhakar 	      DRVCTRL11_DU_DOTCLKIN0(3) |
1099*a51d7062SLad Prabhakar 	      DRVCTRL11_DU_DOTCLKIN1(3);
1100*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL11, reg);
1101*a51d7062SLad Prabhakar 
1102*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL12);
1103*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL12_MASK) |
1104*a51d7062SLad Prabhakar 	      DRVCTRL12_DU_DOTCLKIN2(3) |
1105*a51d7062SLad Prabhakar 	      DRVCTRL12_DU_DOTCLKIN3(3) |
1106*a51d7062SLad Prabhakar 	      DRVCTRL12_DU_FSCLKST(3) |
1107*a51d7062SLad Prabhakar 	      DRVCTRL12_DU_TMS(3);
1108*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL12, reg);
1109*a51d7062SLad Prabhakar 
1110*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL13);
1111*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL13_MASK) |
1112*a51d7062SLad Prabhakar 	      DRVCTRL13_TDO(3) |
1113*a51d7062SLad Prabhakar 	      DRVCTRL13_ASEBRK(3) |
1114*a51d7062SLad Prabhakar 	      DRVCTRL13_SD0_CLK(7) |
1115*a51d7062SLad Prabhakar 	      DRVCTRL13_SD0_CMD(7) |
1116*a51d7062SLad Prabhakar 	      DRVCTRL13_SD0_DAT0(7) |
1117*a51d7062SLad Prabhakar 	      DRVCTRL13_SD0_DAT1(7) |
1118*a51d7062SLad Prabhakar 	      DRVCTRL13_SD0_DAT2(7) |
1119*a51d7062SLad Prabhakar 	      DRVCTRL13_SD0_DAT3(7);
1120*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL13, reg);
1121*a51d7062SLad Prabhakar 
1122*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL14);
1123*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL14_MASK) |
1124*a51d7062SLad Prabhakar 	      DRVCTRL14_SD1_CLK(7) |
1125*a51d7062SLad Prabhakar 	      DRVCTRL14_SD1_CMD(7) |
1126*a51d7062SLad Prabhakar 	      DRVCTRL14_SD1_DAT0(5) |
1127*a51d7062SLad Prabhakar 	      DRVCTRL14_SD1_DAT1(5) |
1128*a51d7062SLad Prabhakar 	      DRVCTRL14_SD1_DAT2(5) |
1129*a51d7062SLad Prabhakar 	      DRVCTRL14_SD1_DAT3(5) |
1130*a51d7062SLad Prabhakar 	      DRVCTRL14_SD2_CLK(5) |
1131*a51d7062SLad Prabhakar 	      DRVCTRL14_SD2_CMD(5);
1132*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL14, reg);
1133*a51d7062SLad Prabhakar 
1134*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL15);
1135*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL15_MASK) |
1136*a51d7062SLad Prabhakar 	      DRVCTRL15_SD2_DAT0(5) |
1137*a51d7062SLad Prabhakar 	      DRVCTRL15_SD2_DAT1(5) |
1138*a51d7062SLad Prabhakar 	      DRVCTRL15_SD2_DAT2(5) |
1139*a51d7062SLad Prabhakar 	      DRVCTRL15_SD2_DAT3(5) |
1140*a51d7062SLad Prabhakar 	      DRVCTRL15_SD2_DS(5) |
1141*a51d7062SLad Prabhakar 	      DRVCTRL15_SD3_CLK(7) |
1142*a51d7062SLad Prabhakar 	      DRVCTRL15_SD3_CMD(7) |
1143*a51d7062SLad Prabhakar 	      DRVCTRL15_SD3_DAT0(7);
1144*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL15, reg);
1145*a51d7062SLad Prabhakar 
1146*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL16);
1147*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL16_MASK) |
1148*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT1(7) |
1149*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT2(7) |
1150*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT3(7) |
1151*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT4(7) |
1152*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT5(7) |
1153*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT6(7) |
1154*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DAT7(7) |
1155*a51d7062SLad Prabhakar 	      DRVCTRL16_SD3_DS(7);
1156*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL16, reg);
1157*a51d7062SLad Prabhakar 
1158*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL17);
1159*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL17_MASK) |
1160*a51d7062SLad Prabhakar 	      DRVCTRL17_SD0_CD(7) |
1161*a51d7062SLad Prabhakar 	      DRVCTRL17_SD0_WP(7) |
1162*a51d7062SLad Prabhakar 	      DRVCTRL17_SD1_CD(7) |
1163*a51d7062SLad Prabhakar 	      DRVCTRL17_SD1_WP(7) |
1164*a51d7062SLad Prabhakar 	      DRVCTRL17_SCK0(7) |
1165*a51d7062SLad Prabhakar 	      DRVCTRL17_RX0(7) |
1166*a51d7062SLad Prabhakar 	      DRVCTRL17_TX0(7) |
1167*a51d7062SLad Prabhakar 	      DRVCTRL17_CTS0(7);
1168*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL17, reg);
1169*a51d7062SLad Prabhakar 
1170*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL18);
1171*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL18_MASK) |
1172*a51d7062SLad Prabhakar 	      DRVCTRL18_RTS0_TANS(7) |
1173*a51d7062SLad Prabhakar 	      DRVCTRL18_RX1(7) |
1174*a51d7062SLad Prabhakar 	      DRVCTRL18_TX1(7) |
1175*a51d7062SLad Prabhakar 	      DRVCTRL18_CTS1(7) |
1176*a51d7062SLad Prabhakar 	      DRVCTRL18_RTS1_TANS(7) |
1177*a51d7062SLad Prabhakar 	      DRVCTRL18_SCK2(7) |
1178*a51d7062SLad Prabhakar 	      DRVCTRL18_TX2(7) |
1179*a51d7062SLad Prabhakar 	      DRVCTRL18_RX2(7);
1180*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL18, reg);
1181*a51d7062SLad Prabhakar 
1182*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL19);
1183*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL19_MASK) |
1184*a51d7062SLad Prabhakar 	      DRVCTRL19_HSCK0(7) |
1185*a51d7062SLad Prabhakar 	      DRVCTRL19_HRX0(7) |
1186*a51d7062SLad Prabhakar 	      DRVCTRL19_HTX0(7) |
1187*a51d7062SLad Prabhakar 	      DRVCTRL19_HCTS0(7) |
1188*a51d7062SLad Prabhakar 	      DRVCTRL19_HRTS0(7) |
1189*a51d7062SLad Prabhakar 	      DRVCTRL19_MSIOF0_SCK(7) |
1190*a51d7062SLad Prabhakar 	      DRVCTRL19_MSIOF0_SYNC(7) |
1191*a51d7062SLad Prabhakar 	      DRVCTRL19_MSIOF0_SS1(7);
1192*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL19, reg);
1193*a51d7062SLad Prabhakar 
1194*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL20);
1195*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL20_MASK) |
1196*a51d7062SLad Prabhakar 	      DRVCTRL20_MSIOF0_TXD(7) |
1197*a51d7062SLad Prabhakar 	      DRVCTRL20_MSIOF0_SS2(7) |
1198*a51d7062SLad Prabhakar 	      DRVCTRL20_MSIOF0_RXD(7) |
1199*a51d7062SLad Prabhakar 	      DRVCTRL20_MLB_CLK(7) |
1200*a51d7062SLad Prabhakar 	      DRVCTRL20_MLB_SIG(7) |
1201*a51d7062SLad Prabhakar 	      DRVCTRL20_MLB_DAT(7) |
1202*a51d7062SLad Prabhakar 	      DRVCTRL20_MLB_REF(7) |
1203*a51d7062SLad Prabhakar 	      DRVCTRL20_SSI_SCK0129(7);
1204*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL20, reg);
1205*a51d7062SLad Prabhakar 
1206*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL21);
1207*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL21_MASK) |
1208*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_WS0129(7) |
1209*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_SDATA0(7) |
1210*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_SDATA1(7) |
1211*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_SDATA2(7) |
1212*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_SCK34(7) |
1213*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_WS34(7) |
1214*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_SDATA3(7) |
1215*a51d7062SLad Prabhakar 	      DRVCTRL21_SSI_SCK4(7);
1216*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL21, reg);
1217*a51d7062SLad Prabhakar 
1218*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL22);
1219*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL22_MASK) |
1220*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_WS4(7) |
1221*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_SDATA4(7) |
1222*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_SCK5(7) |
1223*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_WS5(7) |
1224*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_SDATA5(7) |
1225*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_SCK6(7) |
1226*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_WS6(7) |
1227*a51d7062SLad Prabhakar 	      DRVCTRL22_SSI_SDATA6(7);
1228*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL22, reg);
1229*a51d7062SLad Prabhakar 
1230*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL23);
1231*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL23_MASK) |
1232*a51d7062SLad Prabhakar 	      DRVCTRL23_SSI_SCK78(7) |
1233*a51d7062SLad Prabhakar 	      DRVCTRL23_SSI_WS78(7) |
1234*a51d7062SLad Prabhakar 	      DRVCTRL23_SSI_SDATA7(7) |
1235*a51d7062SLad Prabhakar 	      DRVCTRL23_SSI_SDATA8(7) |
1236*a51d7062SLad Prabhakar 	      DRVCTRL23_SSI_SDATA9(7) |
1237*a51d7062SLad Prabhakar 	      DRVCTRL23_AUDIO_CLKA(7) |
1238*a51d7062SLad Prabhakar 	      DRVCTRL23_AUDIO_CLKB(7) |
1239*a51d7062SLad Prabhakar 	      DRVCTRL23_USB0_PWEN(7);
1240*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL23, reg);
1241*a51d7062SLad Prabhakar 
1242*a51d7062SLad Prabhakar 	reg = mmio_read_32(PFC_DRVCTRL24);
1243*a51d7062SLad Prabhakar 	reg = (reg & DRVCTRL24_MASK) |
1244*a51d7062SLad Prabhakar 	      DRVCTRL24_USB0_OVC(7) |
1245*a51d7062SLad Prabhakar 	      DRVCTRL24_USB1_PWEN(7) |
1246*a51d7062SLad Prabhakar 	      DRVCTRL24_USB1_OVC(7) |
1247*a51d7062SLad Prabhakar 	      DRVCTRL24_USB30_PWEN(7) |
1248*a51d7062SLad Prabhakar 	      DRVCTRL24_USB30_OVC(7) |
1249*a51d7062SLad Prabhakar 	      DRVCTRL24_USB31_PWEN(7) |
1250*a51d7062SLad Prabhakar 	      DRVCTRL24_USB31_OVC(7);
1251*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_DRVCTRL24, reg);
1252*a51d7062SLad Prabhakar 
1253*a51d7062SLad Prabhakar 	/* initialize LSI pin pull-up/down control */
1254*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD0, 0x00005FBFU);
1255*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD1, 0x00300EFEU);
1256*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD2, 0x330001E6U);
1257*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD3, 0x000002E0U);
1258*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD4, 0xFFFFFF00U);
1259*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD5, 0x7F5FFF87U);
1260*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUD6, 0x00000055U);
1261*a51d7062SLad Prabhakar 
1262*a51d7062SLad Prabhakar 	/* initialize LSI pin pull-enable register */
1263*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN0, 0x00000FFFU);
1264*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN1, 0x00100234U);
1265*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN2, 0x000004C4U);
1266*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN3, 0x00000200U);
1267*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN4, 0x3E000000U);
1268*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN5, 0x1F000805U);
1269*a51d7062SLad Prabhakar 	pfc_reg_write(PFC_PUEN6, 0x00000006U);
1270*a51d7062SLad Prabhakar 
1271*a51d7062SLad Prabhakar 	/* initialize positive/negative logic select */
1272*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG0, 0x00000000U);
1273*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG1, 0x00000000U);
1274*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG2, 0x00000000U);
1275*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG3, 0x00000000U);
1276*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG4, 0x00000000U);
1277*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG5, 0x00000000U);
1278*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG6, 0x00000000U);
1279*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_POSNEG7, 0x00000000U);
1280*a51d7062SLad Prabhakar 
1281*a51d7062SLad Prabhakar 	/* initialize general IO/interrupt switching */
1282*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL0, 0x00000000U);
1283*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL1, 0x00000000U);
1284*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL2, 0x00000000U);
1285*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL3, 0x00000000U);
1286*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL4, 0x00000000U);
1287*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL5, 0x00000000U);
1288*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL6, 0x00000000U);
1289*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_IOINTSEL7, 0x00000000U);
1290*a51d7062SLad Prabhakar 
1291*a51d7062SLad Prabhakar 	/* initialize general output register */
1292*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT0, 0x00000001U);
1293*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT1, 0x00000000U);
1294*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT2, 0x00000400U);
1295*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT3, 0x00000000U);
1296*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT4, 0x00000000U);
1297*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT5, 0x00000000U);
1298*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT6, 0x00003800U);
1299*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_OUTDT7, 0x00000003U);
1300*a51d7062SLad Prabhakar 
1301*a51d7062SLad Prabhakar 	/* initialize general input/output switching */
1302*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL0, 0x00000001U);
1303*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL1, 0x00100B00U);
1304*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL2, 0x00000418U);
1305*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL3, 0x00002000U);
1306*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL4, 0x00000040U);
1307*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL5, 0x00000208U);
1308*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL6, 0x00013F00U);
1309*a51d7062SLad Prabhakar 	mmio_write_32(GPIO_INOUTSEL7, 0x00000003U);
1310*a51d7062SLad Prabhakar }
1311