xref: /openbmc/qemu/hw/misc/xlnx-versal-pmc-iou-slcr.c (revision 8c1c0a1b72f1d9138c2a219064072a4462d4cc8e)
1*8c1c0a1bSFrancisco Iglesias /*
2*8c1c0a1bSFrancisco Iglesias  * QEMU model of Versal's PMC IOU SLCR (system level control registers)
3*8c1c0a1bSFrancisco Iglesias  *
4*8c1c0a1bSFrancisco Iglesias  * Copyright (c) 2021 Xilinx Inc.
5*8c1c0a1bSFrancisco Iglesias  * Written by Edgar E. Iglesias <edgar.iglesias@xilinx.com>
6*8c1c0a1bSFrancisco Iglesias  *
7*8c1c0a1bSFrancisco Iglesias  * Permission is hereby granted, free of charge, to any person obtaining a copy
8*8c1c0a1bSFrancisco Iglesias  * of this software and associated documentation files (the "Software"), to deal
9*8c1c0a1bSFrancisco Iglesias  * in the Software without restriction, including without limitation the rights
10*8c1c0a1bSFrancisco Iglesias  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11*8c1c0a1bSFrancisco Iglesias  * copies of the Software, and to permit persons to whom the Software is
12*8c1c0a1bSFrancisco Iglesias  * furnished to do so, subject to the following conditions:
13*8c1c0a1bSFrancisco Iglesias  *
14*8c1c0a1bSFrancisco Iglesias  * The above copyright notice and this permission notice shall be included in
15*8c1c0a1bSFrancisco Iglesias  * all copies or substantial portions of the Software.
16*8c1c0a1bSFrancisco Iglesias  *
17*8c1c0a1bSFrancisco Iglesias  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18*8c1c0a1bSFrancisco Iglesias  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19*8c1c0a1bSFrancisco Iglesias  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
20*8c1c0a1bSFrancisco Iglesias  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21*8c1c0a1bSFrancisco Iglesias  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22*8c1c0a1bSFrancisco Iglesias  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23*8c1c0a1bSFrancisco Iglesias  * THE SOFTWARE.
24*8c1c0a1bSFrancisco Iglesias  */
25*8c1c0a1bSFrancisco Iglesias 
26*8c1c0a1bSFrancisco Iglesias #include "qemu/osdep.h"
27*8c1c0a1bSFrancisco Iglesias #include "hw/sysbus.h"
28*8c1c0a1bSFrancisco Iglesias #include "hw/register.h"
29*8c1c0a1bSFrancisco Iglesias #include "hw/irq.h"
30*8c1c0a1bSFrancisco Iglesias #include "qemu/bitops.h"
31*8c1c0a1bSFrancisco Iglesias #include "qemu/log.h"
32*8c1c0a1bSFrancisco Iglesias #include "migration/vmstate.h"
33*8c1c0a1bSFrancisco Iglesias #include "hw/qdev-properties.h"
34*8c1c0a1bSFrancisco Iglesias #include "hw/misc/xlnx-versal-pmc-iou-slcr.h"
35*8c1c0a1bSFrancisco Iglesias 
36*8c1c0a1bSFrancisco Iglesias #ifndef XILINX_VERSAL_PMC_IOU_SLCR_ERR_DEBUG
37*8c1c0a1bSFrancisco Iglesias #define XILINX_VERSAL_PMC_IOU_SLCR_ERR_DEBUG 0
38*8c1c0a1bSFrancisco Iglesias #endif
39*8c1c0a1bSFrancisco Iglesias 
40*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_0, 0x0)
41*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_0, L3_SEL, 7, 3)
42*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_0, L2_SEL, 5, 2)
43*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_0, L1_SEL, 3, 2)
44*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_0, L0_SEL, 1, 2)
45*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_1, 0x4)
46*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_1, L3_SEL, 7, 3)
47*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_1, L2_SEL, 5, 2)
48*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_1, L1_SEL, 3, 2)
49*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_1, L0_SEL, 1, 2)
50*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_2, 0x8)
51*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_2, L3_SEL, 7, 3)
52*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_2, L2_SEL, 5, 2)
53*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_2, L1_SEL, 3, 2)
54*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_2, L0_SEL, 1, 2)
55*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_3, 0xc)
56*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_3, L3_SEL, 7, 3)
57*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_3, L2_SEL, 5, 2)
58*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_3, L1_SEL, 3, 2)
59*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_3, L0_SEL, 1, 2)
60*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_4, 0x10)
61*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_4, L3_SEL, 7, 3)
62*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_4, L2_SEL, 5, 2)
63*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_4, L1_SEL, 3, 2)
64*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_4, L0_SEL, 1, 2)
65*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_5, 0x14)
66*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_5, L3_SEL, 7, 3)
67*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_5, L2_SEL, 5, 2)
68*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_5, L1_SEL, 3, 2)
69*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_5, L0_SEL, 1, 2)
70*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_6, 0x18)
71*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_6, L3_SEL, 7, 3)
72*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_6, L2_SEL, 5, 2)
73*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_6, L1_SEL, 3, 2)
74*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_6, L0_SEL, 1, 2)
75*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_7, 0x1c)
76*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_7, L3_SEL, 7, 3)
77*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_7, L2_SEL, 5, 2)
78*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_7, L1_SEL, 3, 2)
79*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_7, L0_SEL, 1, 2)
80*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_8, 0x20)
81*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_8, L3_SEL, 7, 3)
82*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_8, L2_SEL, 5, 2)
83*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_8, L1_SEL, 3, 2)
84*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_8, L0_SEL, 1, 2)
85*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_9, 0x24)
86*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_9, L3_SEL, 7, 3)
87*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_9, L2_SEL, 5, 2)
88*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_9, L1_SEL, 3, 2)
89*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_9, L0_SEL, 1, 2)
90*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_10, 0x28)
91*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_10, L3_SEL, 7, 3)
92*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_10, L2_SEL, 5, 2)
93*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_10, L1_SEL, 3, 2)
94*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_10, L0_SEL, 1, 2)
95*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_11, 0x2c)
96*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_11, L3_SEL, 7, 3)
97*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_11, L2_SEL, 5, 2)
98*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_11, L1_SEL, 3, 2)
99*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_11, L0_SEL, 1, 2)
100*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_12, 0x30)
101*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_12, L3_SEL, 7, 3)
102*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_12, L2_SEL, 5, 2)
103*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_12, L1_SEL, 3, 2)
104*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_12, L0_SEL, 1, 2)
105*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_13, 0x34)
106*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_13, L3_SEL, 7, 3)
107*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_13, L2_SEL, 5, 2)
108*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_13, L1_SEL, 3, 2)
109*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_13, L0_SEL, 1, 2)
110*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_14, 0x38)
111*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_14, L3_SEL, 7, 3)
112*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_14, L2_SEL, 5, 2)
113*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_14, L1_SEL, 3, 2)
114*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_14, L0_SEL, 1, 2)
115*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_15, 0x3c)
116*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_15, L3_SEL, 7, 3)
117*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_15, L2_SEL, 5, 2)
118*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_15, L1_SEL, 3, 2)
119*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_15, L0_SEL, 1, 2)
120*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_16, 0x40)
121*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_16, L3_SEL, 7, 3)
122*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_16, L2_SEL, 5, 2)
123*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_16, L1_SEL, 3, 2)
124*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_16, L0_SEL, 1, 2)
125*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_17, 0x44)
126*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_17, L3_SEL, 7, 3)
127*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_17, L2_SEL, 5, 2)
128*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_17, L1_SEL, 3, 2)
129*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_17, L0_SEL, 1, 2)
130*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_18, 0x48)
131*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_18, L3_SEL, 7, 3)
132*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_18, L2_SEL, 5, 2)
133*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_18, L1_SEL, 3, 2)
134*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_18, L0_SEL, 1, 2)
135*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_19, 0x4c)
136*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_19, L3_SEL, 7, 3)
137*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_19, L2_SEL, 5, 2)
138*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_19, L1_SEL, 3, 2)
139*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_19, L0_SEL, 1, 2)
140*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_20, 0x50)
141*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_20, L3_SEL, 7, 3)
142*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_20, L2_SEL, 5, 2)
143*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_20, L1_SEL, 3, 2)
144*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_20, L0_SEL, 1, 2)
145*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_21, 0x54)
146*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_21, L3_SEL, 7, 3)
147*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_21, L2_SEL, 5, 2)
148*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_21, L1_SEL, 3, 2)
149*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_21, L0_SEL, 1, 2)
150*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_22, 0x58)
151*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_22, L3_SEL, 7, 3)
152*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_22, L2_SEL, 5, 2)
153*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_22, L1_SEL, 3, 2)
154*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_22, L0_SEL, 1, 2)
155*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_23, 0x5c)
156*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_23, L3_SEL, 7, 3)
157*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_23, L2_SEL, 5, 2)
158*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_23, L1_SEL, 3, 2)
159*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_23, L0_SEL, 1, 2)
160*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_24, 0x60)
161*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_24, L3_SEL, 7, 3)
162*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_24, L2_SEL, 5, 2)
163*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_24, L1_SEL, 3, 2)
164*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_24, L0_SEL, 1, 2)
165*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_25, 0x64)
166*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_25, L3_SEL, 7, 3)
167*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_25, L2_SEL, 5, 2)
168*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_25, L1_SEL, 3, 2)
169*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_25, L0_SEL, 1, 2)
170*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_26, 0x68)
171*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_26, L3_SEL, 7, 3)
172*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_26, L2_SEL, 5, 2)
173*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_26, L1_SEL, 3, 2)
174*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_26, L0_SEL, 1, 2)
175*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_27, 0x6c)
176*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_27, L3_SEL, 7, 3)
177*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_27, L2_SEL, 5, 2)
178*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_27, L1_SEL, 3, 2)
179*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_27, L0_SEL, 1, 2)
180*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_28, 0x70)
181*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_28, L3_SEL, 7, 3)
182*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_28, L2_SEL, 5, 2)
183*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_28, L1_SEL, 3, 2)
184*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_28, L0_SEL, 1, 2)
185*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_29, 0x74)
186*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_29, L3_SEL, 7, 3)
187*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_29, L2_SEL, 5, 2)
188*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_29, L1_SEL, 3, 2)
189*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_29, L0_SEL, 1, 2)
190*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_30, 0x78)
191*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_30, L3_SEL, 7, 3)
192*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_30, L2_SEL, 5, 2)
193*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_30, L1_SEL, 3, 2)
194*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_30, L0_SEL, 1, 2)
195*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_31, 0x7c)
196*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_31, L3_SEL, 7, 3)
197*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_31, L2_SEL, 5, 2)
198*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_31, L1_SEL, 3, 2)
199*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_31, L0_SEL, 1, 2)
200*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_32, 0x80)
201*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_32, L3_SEL, 7, 3)
202*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_32, L2_SEL, 5, 2)
203*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_32, L1_SEL, 3, 2)
204*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_32, L0_SEL, 1, 2)
205*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_33, 0x84)
206*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_33, L3_SEL, 7, 3)
207*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_33, L2_SEL, 5, 2)
208*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_33, L1_SEL, 3, 2)
209*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_33, L0_SEL, 1, 2)
210*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_34, 0x88)
211*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_34, L3_SEL, 7, 3)
212*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_34, L2_SEL, 5, 2)
213*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_34, L1_SEL, 3, 2)
214*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_34, L0_SEL, 1, 2)
215*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_35, 0x8c)
216*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_35, L3_SEL, 7, 3)
217*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_35, L2_SEL, 5, 2)
218*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_35, L1_SEL, 3, 2)
219*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_35, L0_SEL, 1, 2)
220*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_36, 0x90)
221*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_36, L3_SEL, 7, 3)
222*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_36, L2_SEL, 5, 2)
223*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_36, L1_SEL, 3, 2)
224*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_36, L0_SEL, 1, 2)
225*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_37, 0x94)
226*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_37, L3_SEL, 7, 3)
227*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_37, L2_SEL, 5, 2)
228*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_37, L1_SEL, 3, 2)
229*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_37, L0_SEL, 1, 2)
230*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_38, 0x98)
231*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_38, L3_SEL, 7, 3)
232*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_38, L2_SEL, 5, 2)
233*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_38, L1_SEL, 3, 2)
234*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_38, L0_SEL, 1, 2)
235*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_39, 0x9c)
236*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_39, L3_SEL, 7, 3)
237*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_39, L2_SEL, 5, 2)
238*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_39, L1_SEL, 3, 2)
239*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_39, L0_SEL, 1, 2)
240*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_40, 0xa0)
241*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_40, L3_SEL, 7, 3)
242*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_40, L2_SEL, 5, 2)
243*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_40, L1_SEL, 3, 2)
244*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_40, L0_SEL, 1, 2)
245*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_41, 0xa4)
246*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_41, L3_SEL, 7, 3)
247*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_41, L2_SEL, 5, 2)
248*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_41, L1_SEL, 3, 2)
249*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_41, L0_SEL, 1, 2)
250*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_42, 0xa8)
251*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_42, L3_SEL, 7, 3)
252*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_42, L2_SEL, 5, 2)
253*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_42, L1_SEL, 3, 2)
254*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_42, L0_SEL, 1, 2)
255*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_43, 0xac)
256*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_43, L3_SEL, 7, 3)
257*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_43, L2_SEL, 5, 2)
258*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_43, L1_SEL, 3, 2)
259*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_43, L0_SEL, 1, 2)
260*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_44, 0xb0)
261*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_44, L3_SEL, 7, 3)
262*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_44, L2_SEL, 5, 2)
263*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_44, L1_SEL, 3, 2)
264*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_44, L0_SEL, 1, 2)
265*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_45, 0xb4)
266*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_45, L3_SEL, 7, 3)
267*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_45, L2_SEL, 5, 2)
268*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_45, L1_SEL, 3, 2)
269*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_45, L0_SEL, 1, 2)
270*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_46, 0xb8)
271*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_46, L3_SEL, 7, 3)
272*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_46, L2_SEL, 5, 2)
273*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_46, L1_SEL, 3, 2)
274*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_46, L0_SEL, 1, 2)
275*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_47, 0xbc)
276*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_47, L3_SEL, 7, 3)
277*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_47, L2_SEL, 5, 2)
278*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_47, L1_SEL, 3, 2)
279*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_47, L0_SEL, 1, 2)
280*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_48, 0xc0)
281*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_48, L3_SEL, 7, 3)
282*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_48, L2_SEL, 5, 2)
283*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_48, L1_SEL, 3, 2)
284*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_48, L0_SEL, 1, 2)
285*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_49, 0xc4)
286*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_49, L3_SEL, 7, 3)
287*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_49, L2_SEL, 5, 2)
288*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_49, L1_SEL, 3, 2)
289*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_49, L0_SEL, 1, 2)
290*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_50, 0xc8)
291*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_50, L3_SEL, 7, 3)
292*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_50, L2_SEL, 5, 2)
293*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_50, L1_SEL, 3, 2)
294*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_50, L0_SEL, 1, 2)
295*8c1c0a1bSFrancisco Iglesias REG32(MIO_PIN_51, 0xcc)
296*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_51, L3_SEL, 7, 3)
297*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_51, L2_SEL, 5, 2)
298*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_51, L1_SEL, 3, 2)
299*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_PIN_51, L0_SEL, 1, 2)
300*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_RX, 0x100)
301*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_RX, BNK0_EN_RX, 0, 26)
302*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_RX0, 0x104)
303*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_RX1, 0x108)
304*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_SEL_RX1, BNK0_SEL_RX, 0, 20)
305*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_RX_SCHMITT_HYST, 0x10c)
306*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_RX_SCHMITT_HYST, BNK0_EN_RX_SCHMITT_HYST, 0, 26)
307*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_WK_PD, 0x110)
308*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_WK_PD, BNK0_EN_WK_PD, 0, 26)
309*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_WK_PU, 0x114)
310*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_WK_PU, BNK0_EN_WK_PU, 0, 26)
311*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_DRV0, 0x118)
312*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_DRV1, 0x11c)
313*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_SEL_DRV1, BNK0_SEL_DRV, 0, 20)
314*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_SLEW, 0x120)
315*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_SEL_SLEW, BNK0_SEL_SLEW, 0, 26)
316*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_DFT_OPT_INV, 0x124)
317*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_DFT_OPT_INV, BNK0_EN_DFT_OPT_INV, 0, 26)
318*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_PAD2PAD_LOOPBACK, 0x128)
319*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_PAD2PAD_LOOPBACK, BNK0_EN_PAD2PAD_LOOPBACK, 0, 13)
320*8c1c0a1bSFrancisco Iglesias REG32(BNK0_RX_SPARE0, 0x12c)
321*8c1c0a1bSFrancisco Iglesias REG32(BNK0_RX_SPARE1, 0x130)
322*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_RX_SPARE1, BNK0_RX_SPARE, 0, 20)
323*8c1c0a1bSFrancisco Iglesias REG32(BNK0_TX_SPARE0, 0x134)
324*8c1c0a1bSFrancisco Iglesias REG32(BNK0_TX_SPARE1, 0x138)
325*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_TX_SPARE1, BNK0_TX_SPARE, 0, 20)
326*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_EN1P8, 0x13c)
327*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_SEL_EN1P8, BNK0_SEL_EN1P8, 0, 1)
328*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_B_POR_DETECT, 0x140)
329*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_B_POR_DETECT, BNK0_EN_B_POR_DETECT, 0, 1)
330*8c1c0a1bSFrancisco Iglesias REG32(BNK0_LPF_BYP_POR_DETECT, 0x144)
331*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_LPF_BYP_POR_DETECT, BNK0_LPF_BYP_POR_DETECT, 0, 1)
332*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_LATCH, 0x148)
333*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_LATCH, BNK0_EN_LATCH, 0, 1)
334*8c1c0a1bSFrancisco Iglesias REG32(BNK0_VBG_LPF_BYP_B, 0x14c)
335*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_VBG_LPF_BYP_B, BNK0_VBG_LPF_BYP_B, 0, 1)
336*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_AMP_B, 0x150)
337*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_AMP_B, BNK0_EN_AMP_B, 0, 2)
338*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SPARE_BIAS, 0x154)
339*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_SPARE_BIAS, BNK0_SPARE_BIAS, 0, 4)
340*8c1c0a1bSFrancisco Iglesias REG32(BNK0_DRIVER_BIAS, 0x158)
341*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_DRIVER_BIAS, BNK0_DRIVER_BIAS, 0, 15)
342*8c1c0a1bSFrancisco Iglesias REG32(BNK0_VMODE, 0x15c)
343*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_VMODE, BNK0_VMODE, 0, 1)
344*8c1c0a1bSFrancisco Iglesias REG32(BNK0_SEL_AUX_IO_RX, 0x160)
345*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_SEL_AUX_IO_RX, BNK0_SEL_AUX_IO_RX, 0, 26)
346*8c1c0a1bSFrancisco Iglesias REG32(BNK0_EN_TX_HS_MODE, 0x164)
347*8c1c0a1bSFrancisco Iglesias     FIELD(BNK0_EN_TX_HS_MODE, BNK0_EN_TX_HS_MODE, 0, 26)
348*8c1c0a1bSFrancisco Iglesias REG32(MIO_MST_TRI0, 0x200)
349*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_25_TRI, 25, 1)
350*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_24_TRI, 24, 1)
351*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_23_TRI, 23, 1)
352*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_22_TRI, 22, 1)
353*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_21_TRI, 21, 1)
354*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_20_TRI, 20, 1)
355*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_19_TRI, 19, 1)
356*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_18_TRI, 18, 1)
357*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_17_TRI, 17, 1)
358*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_16_TRI, 16, 1)
359*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_15_TRI, 15, 1)
360*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_14_TRI, 14, 1)
361*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_13_TRI, 13, 1)
362*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_12_TRI, 12, 1)
363*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_11_TRI, 11, 1)
364*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_10_TRI, 10, 1)
365*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_09_TRI, 9, 1)
366*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_08_TRI, 8, 1)
367*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_07_TRI, 7, 1)
368*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_06_TRI, 6, 1)
369*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_05_TRI, 5, 1)
370*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_04_TRI, 4, 1)
371*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_03_TRI, 3, 1)
372*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_02_TRI, 2, 1)
373*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_01_TRI, 1, 1)
374*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI0, PIN_00_TRI, 0, 1)
375*8c1c0a1bSFrancisco Iglesias REG32(MIO_MST_TRI1, 0x204)
376*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_51_TRI, 25, 1)
377*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_50_TRI, 24, 1)
378*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_49_TRI, 23, 1)
379*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_48_TRI, 22, 1)
380*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_47_TRI, 21, 1)
381*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_46_TRI, 20, 1)
382*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_45_TRI, 19, 1)
383*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_44_TRI, 18, 1)
384*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_43_TRI, 17, 1)
385*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_42_TRI, 16, 1)
386*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_41_TRI, 15, 1)
387*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_40_TRI, 14, 1)
388*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_39_TRI, 13, 1)
389*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_38_TRI, 12, 1)
390*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_37_TRI, 11, 1)
391*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_36_TRI, 10, 1)
392*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_35_TRI, 9, 1)
393*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_34_TRI, 8, 1)
394*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_33_TRI, 7, 1)
395*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_32_TRI, 6, 1)
396*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_31_TRI, 5, 1)
397*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_30_TRI, 4, 1)
398*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_29_TRI, 3, 1)
399*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_28_TRI, 2, 1)
400*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_27_TRI, 1, 1)
401*8c1c0a1bSFrancisco Iglesias     FIELD(MIO_MST_TRI1, PIN_26_TRI, 0, 1)
402*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_RX, 0x300)
403*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_RX, BNK1_EN_RX, 0, 26)
404*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_RX0, 0x304)
405*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_RX1, 0x308)
406*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_SEL_RX1, BNK1_SEL_RX, 0, 20)
407*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_RX_SCHMITT_HYST, 0x30c)
408*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_RX_SCHMITT_HYST, BNK1_EN_RX_SCHMITT_HYST, 0, 26)
409*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_WK_PD, 0x310)
410*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_WK_PD, BNK1_EN_WK_PD, 0, 26)
411*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_WK_PU, 0x314)
412*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_WK_PU, BNK1_EN_WK_PU, 0, 26)
413*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_DRV0, 0x318)
414*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_DRV1, 0x31c)
415*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_SEL_DRV1, BNK1_SEL_DRV, 0, 20)
416*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_SLEW, 0x320)
417*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_SEL_SLEW, BNK1_SEL_SLEW, 0, 26)
418*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_DFT_OPT_INV, 0x324)
419*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_DFT_OPT_INV, BNK1_EN_DFT_OPT_INV, 0, 26)
420*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_PAD2PAD_LOOPBACK, 0x328)
421*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_PAD2PAD_LOOPBACK, BNK1_EN_PAD2PAD_LOOPBACK, 0, 13)
422*8c1c0a1bSFrancisco Iglesias REG32(BNK1_RX_SPARE0, 0x32c)
423*8c1c0a1bSFrancisco Iglesias REG32(BNK1_RX_SPARE1, 0x330)
424*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_RX_SPARE1, BNK1_RX_SPARE, 0, 20)
425*8c1c0a1bSFrancisco Iglesias REG32(BNK1_TX_SPARE0, 0x334)
426*8c1c0a1bSFrancisco Iglesias REG32(BNK1_TX_SPARE1, 0x338)
427*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_TX_SPARE1, BNK1_TX_SPARE, 0, 20)
428*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_EN1P8, 0x33c)
429*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_SEL_EN1P8, BNK1_SEL_EN1P8, 0, 1)
430*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_B_POR_DETECT, 0x340)
431*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_B_POR_DETECT, BNK1_EN_B_POR_DETECT, 0, 1)
432*8c1c0a1bSFrancisco Iglesias REG32(BNK1_LPF_BYP_POR_DETECT, 0x344)
433*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_LPF_BYP_POR_DETECT, BNK1_LPF_BYP_POR_DETECT, 0, 1)
434*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_LATCH, 0x348)
435*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_LATCH, BNK1_EN_LATCH, 0, 1)
436*8c1c0a1bSFrancisco Iglesias REG32(BNK1_VBG_LPF_BYP_B, 0x34c)
437*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_VBG_LPF_BYP_B, BNK1_VBG_LPF_BYP_B, 0, 1)
438*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_AMP_B, 0x350)
439*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_AMP_B, BNK1_EN_AMP_B, 0, 2)
440*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SPARE_BIAS, 0x354)
441*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_SPARE_BIAS, BNK1_SPARE_BIAS, 0, 4)
442*8c1c0a1bSFrancisco Iglesias REG32(BNK1_DRIVER_BIAS, 0x358)
443*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_DRIVER_BIAS, BNK1_DRIVER_BIAS, 0, 15)
444*8c1c0a1bSFrancisco Iglesias REG32(BNK1_VMODE, 0x35c)
445*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_VMODE, BNK1_VMODE, 0, 1)
446*8c1c0a1bSFrancisco Iglesias REG32(BNK1_SEL_AUX_IO_RX, 0x360)
447*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_SEL_AUX_IO_RX, BNK1_SEL_AUX_IO_RX, 0, 26)
448*8c1c0a1bSFrancisco Iglesias REG32(BNK1_EN_TX_HS_MODE, 0x364)
449*8c1c0a1bSFrancisco Iglesias     FIELD(BNK1_EN_TX_HS_MODE, BNK1_EN_TX_HS_MODE, 0, 26)
450*8c1c0a1bSFrancisco Iglesias REG32(SD0_CLK_CTRL, 0x400)
451*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CLK_CTRL, SDIO0_FBCLK_SEL, 2, 1)
452*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CLK_CTRL, SDIO0_RX_SRC_SEL, 0, 2)
453*8c1c0a1bSFrancisco Iglesias REG32(SD0_CTRL_REG, 0x404)
454*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CTRL_REG, SD0_EMMC_SEL, 0, 1)
455*8c1c0a1bSFrancisco Iglesias REG32(SD0_CONFIG_REG1, 0x410)
456*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG1, SD0_BASECLK, 7, 8)
457*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG1, SD0_TUNIGCOUNT, 1, 6)
458*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG1, SD0_ASYNCWKPENA, 0, 1)
459*8c1c0a1bSFrancisco Iglesias REG32(SD0_CONFIG_REG2, 0x414)
460*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_SLOTTYPE, 12, 2)
461*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_ASYCINTR, 11, 1)
462*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_64BIT, 10, 1)
463*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_1P8V, 9, 1)
464*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_3P0V, 8, 1)
465*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_3P3V, 7, 1)
466*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_SUSPRES, 6, 1)
467*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_SDMA, 5, 1)
468*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_HIGHSPEED, 4, 1)
469*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_ADMA2, 3, 1)
470*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_8BIT, 2, 1)
471*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG2, SD0_MAXBLK, 0, 2)
472*8c1c0a1bSFrancisco Iglesias REG32(SD0_CONFIG_REG3, 0x418)
473*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_TUNINGSDR50, 10, 1)
474*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_RETUNETMR, 6, 4)
475*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_DDRIVER, 5, 1)
476*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_CDRIVER, 4, 1)
477*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_ADRIVER, 3, 1)
478*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_DDR50, 2, 1)
479*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_SDR104, 1, 1)
480*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CONFIG_REG3, SD0_SDR50, 0, 1)
481*8c1c0a1bSFrancisco Iglesias REG32(SD0_INITPRESET, 0x41c)
482*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_INITPRESET, SD0_INITPRESET, 0, 13)
483*8c1c0a1bSFrancisco Iglesias REG32(SD0_DSPPRESET, 0x420)
484*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DSPPRESET, SD0_DSPPRESET, 0, 13)
485*8c1c0a1bSFrancisco Iglesias REG32(SD0_HSPDPRESET, 0x424)
486*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_HSPDPRESET, SD0_HSPDPRESET, 0, 13)
487*8c1c0a1bSFrancisco Iglesias REG32(SD0_SDR12PRESET, 0x428)
488*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_SDR12PRESET, SD0_SDR12PRESET, 0, 13)
489*8c1c0a1bSFrancisco Iglesias REG32(SD0_SDR25PRESET, 0x42c)
490*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_SDR25PRESET, SD0_SDR25PRESET, 0, 13)
491*8c1c0a1bSFrancisco Iglesias REG32(SD0_SDR50PRSET, 0x430)
492*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_SDR50PRSET, SD0_SDR50PRESET, 0, 13)
493*8c1c0a1bSFrancisco Iglesias REG32(SD0_SDR104PRST, 0x434)
494*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_SDR104PRST, SD0_SDR104PRESET, 0, 13)
495*8c1c0a1bSFrancisco Iglesias REG32(SD0_DDR50PRESET, 0x438)
496*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DDR50PRESET, SD0_DDR50PRESET, 0, 13)
497*8c1c0a1bSFrancisco Iglesias REG32(SD0_MAXCUR1P8, 0x43c)
498*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_MAXCUR1P8, SD0_MAXCUR1P8, 0, 8)
499*8c1c0a1bSFrancisco Iglesias REG32(SD0_MAXCUR3P0, 0x440)
500*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_MAXCUR3P0, SD0_MAXCUR3P0, 0, 8)
501*8c1c0a1bSFrancisco Iglesias REG32(SD0_MAXCUR3P3, 0x444)
502*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_MAXCUR3P3, SD0_MAXCUR3P3, 0, 8)
503*8c1c0a1bSFrancisco Iglesias REG32(SD0_DLL_CTRL, 0x448)
504*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_CLKSTABLE_CFG, 9, 1)
505*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_DLL_CFG, 5, 4)
506*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_DLL_PSDONE, 4, 1)
507*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_DLL_OVF, 3, 1)
508*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_DLL_RST, 2, 1)
509*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_DLL_TESTMODE, 1, 1)
510*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_CTRL, SD0_DLL_LOCK, 0, 1)
511*8c1c0a1bSFrancisco Iglesias REG32(SD0_CDN_CTRL, 0x44c)
512*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_CDN_CTRL, SD0_CDN_CTRL, 0, 1)
513*8c1c0a1bSFrancisco Iglesias REG32(SD0_DLL_TEST, 0x450)
514*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_TEST, DLL_DIV, 16, 8)
515*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_TEST, DLL_TX_SEL, 9, 7)
516*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_TEST, DLL_RX_SEL, 0, 9)
517*8c1c0a1bSFrancisco Iglesias REG32(SD0_RX_TUNING_SEL, 0x454)
518*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_RX_TUNING_SEL, SD0_RX_SEL, 0, 9)
519*8c1c0a1bSFrancisco Iglesias REG32(SD0_DLL_DIV_MAP0, 0x458)
520*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP0, DIV_3, 24, 8)
521*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP0, DIV_2, 16, 8)
522*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP0, DIV_1, 8, 8)
523*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP0, DIV_0, 0, 8)
524*8c1c0a1bSFrancisco Iglesias REG32(SD0_DLL_DIV_MAP1, 0x45c)
525*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP1, DIV_7, 24, 8)
526*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP1, DIV_6, 16, 8)
527*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP1, DIV_5, 8, 8)
528*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_DLL_DIV_MAP1, DIV_4, 0, 8)
529*8c1c0a1bSFrancisco Iglesias REG32(SD0_IOU_COHERENT_CTRL, 0x460)
530*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_IOU_COHERENT_CTRL, SD0_AXI_COH, 0, 4)
531*8c1c0a1bSFrancisco Iglesias REG32(SD0_IOU_INTERCONNECT_ROUTE, 0x464)
532*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_IOU_INTERCONNECT_ROUTE, SD0, 0, 1)
533*8c1c0a1bSFrancisco Iglesias REG32(SD0_IOU_RAM, 0x468)
534*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_IOU_RAM, EMASA0, 6, 1)
535*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_IOU_RAM, EMAB0, 3, 3)
536*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_IOU_RAM, EMAA0, 0, 3)
537*8c1c0a1bSFrancisco Iglesias REG32(SD0_IOU_INTERCONNECT_QOS, 0x46c)
538*8c1c0a1bSFrancisco Iglesias     FIELD(SD0_IOU_INTERCONNECT_QOS, SD0_QOS, 0, 4)
539*8c1c0a1bSFrancisco Iglesias REG32(SD1_CLK_CTRL, 0x480)
540*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CLK_CTRL, SDIO1_FBCLK_SEL, 1, 1)
541*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CLK_CTRL, SDIO1_RX_SRC_SEL, 0, 1)
542*8c1c0a1bSFrancisco Iglesias REG32(SD1_CTRL_REG, 0x484)
543*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CTRL_REG, SD1_EMMC_SEL, 0, 1)
544*8c1c0a1bSFrancisco Iglesias REG32(SD1_CONFIG_REG1, 0x490)
545*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG1, SD1_BASECLK, 7, 8)
546*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG1, SD1_TUNIGCOUNT, 1, 6)
547*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG1, SD1_ASYNCWKPENA, 0, 1)
548*8c1c0a1bSFrancisco Iglesias REG32(SD1_CONFIG_REG2, 0x494)
549*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_SLOTTYPE, 12, 2)
550*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_ASYCINTR, 11, 1)
551*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_64BIT, 10, 1)
552*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_1P8V, 9, 1)
553*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_3P0V, 8, 1)
554*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_3P3V, 7, 1)
555*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_SUSPRES, 6, 1)
556*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_SDMA, 5, 1)
557*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_HIGHSPEED, 4, 1)
558*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_ADMA2, 3, 1)
559*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_8BIT, 2, 1)
560*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG2, SD1_MAXBLK, 0, 2)
561*8c1c0a1bSFrancisco Iglesias REG32(SD1_CONFIG_REG3, 0x498)
562*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_TUNINGSDR50, 10, 1)
563*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_RETUNETMR, 6, 4)
564*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_DDRIVER, 5, 1)
565*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_CDRIVER, 4, 1)
566*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_ADRIVER, 3, 1)
567*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_DDR50, 2, 1)
568*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_SDR104, 1, 1)
569*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CONFIG_REG3, SD1_SDR50, 0, 1)
570*8c1c0a1bSFrancisco Iglesias REG32(SD1_INITPRESET, 0x49c)
571*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_INITPRESET, SD1_INITPRESET, 0, 13)
572*8c1c0a1bSFrancisco Iglesias REG32(SD1_DSPPRESET, 0x4a0)
573*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DSPPRESET, SD1_DSPPRESET, 0, 13)
574*8c1c0a1bSFrancisco Iglesias REG32(SD1_HSPDPRESET, 0x4a4)
575*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_HSPDPRESET, SD1_HSPDPRESET, 0, 13)
576*8c1c0a1bSFrancisco Iglesias REG32(SD1_SDR12PRESET, 0x4a8)
577*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_SDR12PRESET, SD1_SDR12PRESET, 0, 13)
578*8c1c0a1bSFrancisco Iglesias REG32(SD1_SDR25PRESET, 0x4ac)
579*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_SDR25PRESET, SD1_SDR25PRESET, 0, 13)
580*8c1c0a1bSFrancisco Iglesias REG32(SD1_SDR50PRSET, 0x4b0)
581*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_SDR50PRSET, SD1_SDR50PRESET, 0, 13)
582*8c1c0a1bSFrancisco Iglesias REG32(SD1_SDR104PRST, 0x4b4)
583*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_SDR104PRST, SD1_SDR104PRESET, 0, 13)
584*8c1c0a1bSFrancisco Iglesias REG32(SD1_DDR50PRESET, 0x4b8)
585*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DDR50PRESET, SD1_DDR50PRESET, 0, 13)
586*8c1c0a1bSFrancisco Iglesias REG32(SD1_MAXCUR1P8, 0x4bc)
587*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_MAXCUR1P8, SD1_MAXCUR1P8, 0, 8)
588*8c1c0a1bSFrancisco Iglesias REG32(SD1_MAXCUR3P0, 0x4c0)
589*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_MAXCUR3P0, SD1_MAXCUR3P0, 0, 8)
590*8c1c0a1bSFrancisco Iglesias REG32(SD1_MAXCUR3P3, 0x4c4)
591*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_MAXCUR3P3, SD1_MAXCUR3P3, 0, 8)
592*8c1c0a1bSFrancisco Iglesias REG32(SD1_DLL_CTRL, 0x4c8)
593*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_CLKSTABLE_CFG, 9, 1)
594*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_DLL_CFG, 5, 4)
595*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_DLL_PSDONE, 4, 1)
596*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_DLL_OVF, 3, 1)
597*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_DLL_RST, 2, 1)
598*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_DLL_TESTMODE, 1, 1)
599*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_CTRL, SD1_DLL_LOCK, 0, 1)
600*8c1c0a1bSFrancisco Iglesias REG32(SD1_CDN_CTRL, 0x4cc)
601*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_CDN_CTRL, SD1_CDN_CTRL, 0, 1)
602*8c1c0a1bSFrancisco Iglesias REG32(SD1_DLL_TEST, 0x4d0)
603*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_TEST, DLL_DIV, 16, 8)
604*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_TEST, DLL_TX_SEL, 9, 7)
605*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_TEST, DLL_RX_SEL, 0, 9)
606*8c1c0a1bSFrancisco Iglesias REG32(SD1_RX_TUNING_SEL, 0x4d4)
607*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_RX_TUNING_SEL, SD1_RX_SEL, 0, 9)
608*8c1c0a1bSFrancisco Iglesias REG32(SD1_DLL_DIV_MAP0, 0x4d8)
609*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP0, DIV_3, 24, 8)
610*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP0, DIV_2, 16, 8)
611*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP0, DIV_1, 8, 8)
612*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP0, DIV_0, 0, 8)
613*8c1c0a1bSFrancisco Iglesias REG32(SD1_DLL_DIV_MAP1, 0x4dc)
614*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP1, DIV_7, 24, 8)
615*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP1, DIV_6, 16, 8)
616*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP1, DIV_5, 8, 8)
617*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_DLL_DIV_MAP1, DIV_4, 0, 8)
618*8c1c0a1bSFrancisco Iglesias REG32(SD1_IOU_COHERENT_CTRL, 0x4e0)
619*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_IOU_COHERENT_CTRL, SD1_AXI_COH, 0, 4)
620*8c1c0a1bSFrancisco Iglesias REG32(SD1_IOU_INTERCONNECT_ROUTE, 0x4e4)
621*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_IOU_INTERCONNECT_ROUTE, SD1, 0, 1)
622*8c1c0a1bSFrancisco Iglesias REG32(SD1_IOU_RAM, 0x4e8)
623*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_IOU_RAM, EMASA0, 6, 1)
624*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_IOU_RAM, EMAB0, 3, 3)
625*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_IOU_RAM, EMAA0, 0, 3)
626*8c1c0a1bSFrancisco Iglesias REG32(SD1_IOU_INTERCONNECT_QOS, 0x4ec)
627*8c1c0a1bSFrancisco Iglesias     FIELD(SD1_IOU_INTERCONNECT_QOS, SD1_QOS, 0, 4)
628*8c1c0a1bSFrancisco Iglesias REG32(OSPI_QSPI_IOU_AXI_MUX_SEL, 0x504)
629*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_QSPI_IOU_AXI_MUX_SEL, OSPI_MUX_SEL, 1, 1)
630*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_QSPI_IOU_AXI_MUX_SEL, QSPI_OSPI_MUX_SEL, 0, 1)
631*8c1c0a1bSFrancisco Iglesias REG32(QSPI_IOU_COHERENT_CTRL, 0x508)
632*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_COHERENT_CTRL, QSPI_AXI_COH, 0, 4)
633*8c1c0a1bSFrancisco Iglesias REG32(QSPI_IOU_INTERCONNECT_ROUTE, 0x50c)
634*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_INTERCONNECT_ROUTE, QSPI, 0, 1)
635*8c1c0a1bSFrancisco Iglesias REG32(QSPI_IOU_RAM, 0x510)
636*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_RAM, EMASA1, 13, 1)
637*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_RAM, EMAB1, 10, 3)
638*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_RAM, EMAA1, 7, 3)
639*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_RAM, EMASA0, 6, 1)
640*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_RAM, EMAB0, 3, 3)
641*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_RAM, EMAA0, 0, 3)
642*8c1c0a1bSFrancisco Iglesias REG32(QSPI_IOU_INTERCONNECT_QOS, 0x514)
643*8c1c0a1bSFrancisco Iglesias     FIELD(QSPI_IOU_INTERCONNECT_QOS, QSPI_QOS, 0, 4)
644*8c1c0a1bSFrancisco Iglesias REG32(OSPI_IOU_COHERENT_CTRL, 0x530)
645*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_IOU_COHERENT_CTRL, OSPI_AXI_COH, 0, 4)
646*8c1c0a1bSFrancisco Iglesias REG32(OSPI_IOU_INTERCONNECT_ROUTE, 0x534)
647*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_IOU_INTERCONNECT_ROUTE, OSPI, 0, 1)
648*8c1c0a1bSFrancisco Iglesias REG32(OSPI_IOU_RAM, 0x538)
649*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_IOU_RAM, EMAS0, 5, 1)
650*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_IOU_RAM, EMAW0, 3, 2)
651*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_IOU_RAM, EMA0, 0, 3)
652*8c1c0a1bSFrancisco Iglesias REG32(OSPI_IOU_INTERCONNECT_QOS, 0x53c)
653*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_IOU_INTERCONNECT_QOS, OSPI_QOS, 0, 4)
654*8c1c0a1bSFrancisco Iglesias REG32(OSPI_REFCLK_DLY_CTRL, 0x540)
655*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_REFCLK_DLY_CTRL, DLY1, 3, 2)
656*8c1c0a1bSFrancisco Iglesias     FIELD(OSPI_REFCLK_DLY_CTRL, DLY0, 0, 3)
657*8c1c0a1bSFrancisco Iglesias REG32(CUR_PWR_ST, 0x600)
658*8c1c0a1bSFrancisco Iglesias     FIELD(CUR_PWR_ST, U2PMU, 0, 2)
659*8c1c0a1bSFrancisco Iglesias REG32(CONNECT_ST, 0x604)
660*8c1c0a1bSFrancisco Iglesias     FIELD(CONNECT_ST, U2PMU, 0, 1)
661*8c1c0a1bSFrancisco Iglesias REG32(PW_STATE_REQ, 0x608)
662*8c1c0a1bSFrancisco Iglesias     FIELD(PW_STATE_REQ, BIT_1_0, 0, 2)
663*8c1c0a1bSFrancisco Iglesias REG32(HOST_U2_PORT_DISABLE, 0x60c)
664*8c1c0a1bSFrancisco Iglesias     FIELD(HOST_U2_PORT_DISABLE, BIT_0, 0, 1)
665*8c1c0a1bSFrancisco Iglesias REG32(DBG_U2PMU, 0x610)
666*8c1c0a1bSFrancisco Iglesias REG32(DBG_U2PMU_EXT1, 0x614)
667*8c1c0a1bSFrancisco Iglesias REG32(DBG_U2PMU_EXT2, 0x618)
668*8c1c0a1bSFrancisco Iglesias     FIELD(DBG_U2PMU_EXT2, BIT_67_64, 0, 4)
669*8c1c0a1bSFrancisco Iglesias REG32(PME_GEN_U2PMU, 0x61c)
670*8c1c0a1bSFrancisco Iglesias     FIELD(PME_GEN_U2PMU, BIT_0, 0, 1)
671*8c1c0a1bSFrancisco Iglesias REG32(PWR_CONFIG_USB2, 0x620)
672*8c1c0a1bSFrancisco Iglesias     FIELD(PWR_CONFIG_USB2, STRAP, 0, 30)
673*8c1c0a1bSFrancisco Iglesias REG32(PHY_HUB, 0x624)
674*8c1c0a1bSFrancisco Iglesias     FIELD(PHY_HUB, VBUS_CTRL, 1, 1)
675*8c1c0a1bSFrancisco Iglesias     FIELD(PHY_HUB, OVER_CURRENT, 0, 1)
676*8c1c0a1bSFrancisco Iglesias REG32(CTRL, 0x700)
677*8c1c0a1bSFrancisco Iglesias     FIELD(CTRL, SLVERR_ENABLE, 0, 1)
678*8c1c0a1bSFrancisco Iglesias REG32(ISR, 0x800)
679*8c1c0a1bSFrancisco Iglesias     FIELD(ISR, ADDR_DECODE_ERR, 0, 1)
680*8c1c0a1bSFrancisco Iglesias REG32(IMR, 0x804)
681*8c1c0a1bSFrancisco Iglesias     FIELD(IMR, ADDR_DECODE_ERR, 0, 1)
682*8c1c0a1bSFrancisco Iglesias REG32(IER, 0x808)
683*8c1c0a1bSFrancisco Iglesias     FIELD(IER, ADDR_DECODE_ERR, 0, 1)
684*8c1c0a1bSFrancisco Iglesias REG32(IDR, 0x80c)
685*8c1c0a1bSFrancisco Iglesias     FIELD(IDR, ADDR_DECODE_ERR, 0, 1)
686*8c1c0a1bSFrancisco Iglesias REG32(ITR, 0x810)
687*8c1c0a1bSFrancisco Iglesias     FIELD(ITR, ADDR_DECODE_ERR, 0, 1)
688*8c1c0a1bSFrancisco Iglesias REG32(PARITY_ISR, 0x814)
689*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_AXI_SD1_IOU, 12, 1)
690*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_AXI_SD0_IOU, 11, 1)
691*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_AXI_QSPI_IOU, 10, 1)
692*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_AXI_OSPI_IOU, 9, 1)
693*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_IOU_SD1, 8, 1)
694*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_IOU_SD0, 7, 1)
695*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_IOU_QSPI1, 6, 1)
696*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_IOUSLCR_SECURE_APB, 5, 1)
697*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_IOUSLCR_APB, 4, 1)
698*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_QSPI0_APB, 3, 1)
699*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_OSPI_APB, 2, 1)
700*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_I2C_APB, 1, 1)
701*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ISR, PERR_GPIO_APB, 0, 1)
702*8c1c0a1bSFrancisco Iglesias REG32(PARITY_IMR, 0x818)
703*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_AXI_SD1_IOU, 12, 1)
704*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_AXI_SD0_IOU, 11, 1)
705*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_AXI_QSPI_IOU, 10, 1)
706*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_AXI_OSPI_IOU, 9, 1)
707*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_IOU_SD1, 8, 1)
708*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_IOU_SD0, 7, 1)
709*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_IOU_QSPI1, 6, 1)
710*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_IOUSLCR_SECURE_APB, 5, 1)
711*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_IOUSLCR_APB, 4, 1)
712*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_QSPI0_APB, 3, 1)
713*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_OSPI_APB, 2, 1)
714*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_I2C_APB, 1, 1)
715*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IMR, PERR_GPIO_APB, 0, 1)
716*8c1c0a1bSFrancisco Iglesias REG32(PARITY_IER, 0x81c)
717*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_AXI_SD1_IOU, 12, 1)
718*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_AXI_SD0_IOU, 11, 1)
719*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_AXI_QSPI_IOU, 10, 1)
720*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_AXI_OSPI_IOU, 9, 1)
721*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_IOU_SD1, 8, 1)
722*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_IOU_SD0, 7, 1)
723*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_IOU_QSPI1, 6, 1)
724*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_IOUSLCR_SECURE_APB, 5, 1)
725*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_IOUSLCR_APB, 4, 1)
726*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_QSPI0_APB, 3, 1)
727*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_OSPI_APB, 2, 1)
728*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_I2C_APB, 1, 1)
729*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IER, PERR_GPIO_APB, 0, 1)
730*8c1c0a1bSFrancisco Iglesias REG32(PARITY_IDR, 0x820)
731*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_AXI_SD1_IOU, 12, 1)
732*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_AXI_SD0_IOU, 11, 1)
733*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_AXI_QSPI_IOU, 10, 1)
734*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_AXI_OSPI_IOU, 9, 1)
735*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_IOU_SD1, 8, 1)
736*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_IOU_SD0, 7, 1)
737*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_IOU_QSPI1, 6, 1)
738*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_IOUSLCR_SECURE_APB, 5, 1)
739*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_IOUSLCR_APB, 4, 1)
740*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_QSPI0_APB, 3, 1)
741*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_OSPI_APB, 2, 1)
742*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_I2C_APB, 1, 1)
743*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_IDR, PERR_GPIO_APB, 0, 1)
744*8c1c0a1bSFrancisco Iglesias REG32(PARITY_ITR, 0x824)
745*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_AXI_SD1_IOU, 12, 1)
746*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_AXI_SD0_IOU, 11, 1)
747*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_AXI_QSPI_IOU, 10, 1)
748*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_AXI_OSPI_IOU, 9, 1)
749*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_IOU_SD1, 8, 1)
750*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_IOU_SD0, 7, 1)
751*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_IOU_QSPI1, 6, 1)
752*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_IOUSLCR_SECURE_APB, 5, 1)
753*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_IOUSLCR_APB, 4, 1)
754*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_QSPI0_APB, 3, 1)
755*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_OSPI_APB, 2, 1)
756*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_I2C_APB, 1, 1)
757*8c1c0a1bSFrancisco Iglesias     FIELD(PARITY_ITR, PERR_GPIO_APB, 0, 1)
758*8c1c0a1bSFrancisco Iglesias REG32(WPROT0, 0x828)
759*8c1c0a1bSFrancisco Iglesias     FIELD(WPROT0, ACTIVE, 0, 1)
760*8c1c0a1bSFrancisco Iglesias 
761*8c1c0a1bSFrancisco Iglesias static void parity_imr_update_irq(XlnxVersalPmcIouSlcr *s)
762*8c1c0a1bSFrancisco Iglesias {
763*8c1c0a1bSFrancisco Iglesias     bool pending = s->regs[R_PARITY_ISR] & ~s->regs[R_PARITY_IMR];
764*8c1c0a1bSFrancisco Iglesias     qemu_set_irq(s->irq_parity_imr, pending);
765*8c1c0a1bSFrancisco Iglesias }
766*8c1c0a1bSFrancisco Iglesias 
767*8c1c0a1bSFrancisco Iglesias static void parity_isr_postw(RegisterInfo *reg, uint64_t val64)
768*8c1c0a1bSFrancisco Iglesias {
769*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
770*8c1c0a1bSFrancisco Iglesias     parity_imr_update_irq(s);
771*8c1c0a1bSFrancisco Iglesias }
772*8c1c0a1bSFrancisco Iglesias 
773*8c1c0a1bSFrancisco Iglesias static uint64_t parity_ier_prew(RegisterInfo *reg, uint64_t val64)
774*8c1c0a1bSFrancisco Iglesias {
775*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
776*8c1c0a1bSFrancisco Iglesias     uint32_t val = val64;
777*8c1c0a1bSFrancisco Iglesias 
778*8c1c0a1bSFrancisco Iglesias     s->regs[R_PARITY_IMR] &= ~val;
779*8c1c0a1bSFrancisco Iglesias     parity_imr_update_irq(s);
780*8c1c0a1bSFrancisco Iglesias     return 0;
781*8c1c0a1bSFrancisco Iglesias }
782*8c1c0a1bSFrancisco Iglesias 
783*8c1c0a1bSFrancisco Iglesias static uint64_t parity_idr_prew(RegisterInfo *reg, uint64_t val64)
784*8c1c0a1bSFrancisco Iglesias {
785*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
786*8c1c0a1bSFrancisco Iglesias     uint32_t val = val64;
787*8c1c0a1bSFrancisco Iglesias 
788*8c1c0a1bSFrancisco Iglesias     s->regs[R_PARITY_IMR] |= val;
789*8c1c0a1bSFrancisco Iglesias     parity_imr_update_irq(s);
790*8c1c0a1bSFrancisco Iglesias     return 0;
791*8c1c0a1bSFrancisco Iglesias }
792*8c1c0a1bSFrancisco Iglesias 
793*8c1c0a1bSFrancisco Iglesias static uint64_t parity_itr_prew(RegisterInfo *reg, uint64_t val64)
794*8c1c0a1bSFrancisco Iglesias {
795*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
796*8c1c0a1bSFrancisco Iglesias     uint32_t val = val64;
797*8c1c0a1bSFrancisco Iglesias 
798*8c1c0a1bSFrancisco Iglesias     s->regs[R_PARITY_ISR] |= val;
799*8c1c0a1bSFrancisco Iglesias     parity_imr_update_irq(s);
800*8c1c0a1bSFrancisco Iglesias     return 0;
801*8c1c0a1bSFrancisco Iglesias }
802*8c1c0a1bSFrancisco Iglesias 
803*8c1c0a1bSFrancisco Iglesias static void imr_update_irq(XlnxVersalPmcIouSlcr *s)
804*8c1c0a1bSFrancisco Iglesias {
805*8c1c0a1bSFrancisco Iglesias     bool pending = s->regs[R_ISR] & ~s->regs[R_IMR];
806*8c1c0a1bSFrancisco Iglesias     qemu_set_irq(s->irq_imr, pending);
807*8c1c0a1bSFrancisco Iglesias }
808*8c1c0a1bSFrancisco Iglesias 
809*8c1c0a1bSFrancisco Iglesias static void isr_postw(RegisterInfo *reg, uint64_t val64)
810*8c1c0a1bSFrancisco Iglesias {
811*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
812*8c1c0a1bSFrancisco Iglesias     imr_update_irq(s);
813*8c1c0a1bSFrancisco Iglesias }
814*8c1c0a1bSFrancisco Iglesias 
815*8c1c0a1bSFrancisco Iglesias static uint64_t ier_prew(RegisterInfo *reg, uint64_t val64)
816*8c1c0a1bSFrancisco Iglesias {
817*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
818*8c1c0a1bSFrancisco Iglesias     uint32_t val = val64;
819*8c1c0a1bSFrancisco Iglesias 
820*8c1c0a1bSFrancisco Iglesias     s->regs[R_IMR] &= ~val;
821*8c1c0a1bSFrancisco Iglesias     imr_update_irq(s);
822*8c1c0a1bSFrancisco Iglesias     return 0;
823*8c1c0a1bSFrancisco Iglesias }
824*8c1c0a1bSFrancisco Iglesias 
825*8c1c0a1bSFrancisco Iglesias static uint64_t idr_prew(RegisterInfo *reg, uint64_t val64)
826*8c1c0a1bSFrancisco Iglesias {
827*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
828*8c1c0a1bSFrancisco Iglesias     uint32_t val = val64;
829*8c1c0a1bSFrancisco Iglesias 
830*8c1c0a1bSFrancisco Iglesias     s->regs[R_IMR] |= val;
831*8c1c0a1bSFrancisco Iglesias     imr_update_irq(s);
832*8c1c0a1bSFrancisco Iglesias     return 0;
833*8c1c0a1bSFrancisco Iglesias }
834*8c1c0a1bSFrancisco Iglesias 
835*8c1c0a1bSFrancisco Iglesias static uint64_t itr_prew(RegisterInfo *reg, uint64_t val64)
836*8c1c0a1bSFrancisco Iglesias {
837*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
838*8c1c0a1bSFrancisco Iglesias     uint32_t val = val64;
839*8c1c0a1bSFrancisco Iglesias 
840*8c1c0a1bSFrancisco Iglesias     s->regs[R_ISR] |= val;
841*8c1c0a1bSFrancisco Iglesias     imr_update_irq(s);
842*8c1c0a1bSFrancisco Iglesias     return 0;
843*8c1c0a1bSFrancisco Iglesias }
844*8c1c0a1bSFrancisco Iglesias 
845*8c1c0a1bSFrancisco Iglesias static uint64_t sd0_ctrl_reg_prew(RegisterInfo *reg, uint64_t val64)
846*8c1c0a1bSFrancisco Iglesias {
847*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
848*8c1c0a1bSFrancisco Iglesias     uint32_t prev = ARRAY_FIELD_EX32(s->regs, SD0_CTRL_REG, SD0_EMMC_SEL);
849*8c1c0a1bSFrancisco Iglesias 
850*8c1c0a1bSFrancisco Iglesias     if (prev != (val64 & R_SD0_CTRL_REG_SD0_EMMC_SEL_MASK)) {
851*8c1c0a1bSFrancisco Iglesias         qemu_set_irq(s->sd_emmc_sel[0], !!val64);
852*8c1c0a1bSFrancisco Iglesias     }
853*8c1c0a1bSFrancisco Iglesias 
854*8c1c0a1bSFrancisco Iglesias     return val64;
855*8c1c0a1bSFrancisco Iglesias }
856*8c1c0a1bSFrancisco Iglesias 
857*8c1c0a1bSFrancisco Iglesias static uint64_t sd1_ctrl_reg_prew(RegisterInfo *reg, uint64_t val64)
858*8c1c0a1bSFrancisco Iglesias {
859*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
860*8c1c0a1bSFrancisco Iglesias     uint32_t prev = ARRAY_FIELD_EX32(s->regs, SD1_CTRL_REG, SD1_EMMC_SEL);
861*8c1c0a1bSFrancisco Iglesias 
862*8c1c0a1bSFrancisco Iglesias     if (prev != (val64 & R_SD1_CTRL_REG_SD1_EMMC_SEL_MASK)) {
863*8c1c0a1bSFrancisco Iglesias         qemu_set_irq(s->sd_emmc_sel[1], !!val64);
864*8c1c0a1bSFrancisco Iglesias     }
865*8c1c0a1bSFrancisco Iglesias 
866*8c1c0a1bSFrancisco Iglesias     return val64;
867*8c1c0a1bSFrancisco Iglesias }
868*8c1c0a1bSFrancisco Iglesias 
869*8c1c0a1bSFrancisco Iglesias static uint64_t ospi_qspi_iou_axi_mux_sel_prew(RegisterInfo *reg,
870*8c1c0a1bSFrancisco Iglesias                                                uint64_t val64)
871*8c1c0a1bSFrancisco Iglesias {
872*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(reg->opaque);
873*8c1c0a1bSFrancisco Iglesias     uint32_t val32 = (uint32_t) val64;
874*8c1c0a1bSFrancisco Iglesias     uint8_t ospi_mux_sel = FIELD_EX32(val32, OSPI_QSPI_IOU_AXI_MUX_SEL,
875*8c1c0a1bSFrancisco Iglesias                                       OSPI_MUX_SEL);
876*8c1c0a1bSFrancisco Iglesias     uint8_t qspi_ospi_mux_sel = FIELD_EX32(val32, OSPI_QSPI_IOU_AXI_MUX_SEL,
877*8c1c0a1bSFrancisco Iglesias                                       QSPI_OSPI_MUX_SEL);
878*8c1c0a1bSFrancisco Iglesias 
879*8c1c0a1bSFrancisco Iglesias     if (ospi_mux_sel !=
880*8c1c0a1bSFrancisco Iglesias         ARRAY_FIELD_EX32(s->regs, OSPI_QSPI_IOU_AXI_MUX_SEL, OSPI_MUX_SEL)) {
881*8c1c0a1bSFrancisco Iglesias         qemu_set_irq(s->ospi_mux_sel, !!ospi_mux_sel);
882*8c1c0a1bSFrancisco Iglesias     }
883*8c1c0a1bSFrancisco Iglesias 
884*8c1c0a1bSFrancisco Iglesias     if (qspi_ospi_mux_sel !=
885*8c1c0a1bSFrancisco Iglesias         ARRAY_FIELD_EX32(s->regs, OSPI_QSPI_IOU_AXI_MUX_SEL,
886*8c1c0a1bSFrancisco Iglesias                          QSPI_OSPI_MUX_SEL)) {
887*8c1c0a1bSFrancisco Iglesias         qemu_set_irq(s->qspi_ospi_mux_sel, !!qspi_ospi_mux_sel);
888*8c1c0a1bSFrancisco Iglesias     }
889*8c1c0a1bSFrancisco Iglesias 
890*8c1c0a1bSFrancisco Iglesias     return val64;
891*8c1c0a1bSFrancisco Iglesias }
892*8c1c0a1bSFrancisco Iglesias 
893*8c1c0a1bSFrancisco Iglesias static RegisterAccessInfo pmc_iou_slcr_regs_info[] = {
894*8c1c0a1bSFrancisco Iglesias     {   .name = "MIO_PIN_0",  .addr = A_MIO_PIN_0,
895*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
896*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_1",  .addr = A_MIO_PIN_1,
897*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
898*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_2",  .addr = A_MIO_PIN_2,
899*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
900*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_3",  .addr = A_MIO_PIN_3,
901*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
902*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_4",  .addr = A_MIO_PIN_4,
903*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
904*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_5",  .addr = A_MIO_PIN_5,
905*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
906*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_6",  .addr = A_MIO_PIN_6,
907*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
908*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_7",  .addr = A_MIO_PIN_7,
909*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
910*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_8",  .addr = A_MIO_PIN_8,
911*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
912*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_9",  .addr = A_MIO_PIN_9,
913*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
914*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_10",  .addr = A_MIO_PIN_10,
915*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
916*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_11",  .addr = A_MIO_PIN_11,
917*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
918*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_12",  .addr = A_MIO_PIN_12,
919*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
920*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_13",  .addr = A_MIO_PIN_13,
921*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
922*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_14",  .addr = A_MIO_PIN_14,
923*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
924*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_15",  .addr = A_MIO_PIN_15,
925*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
926*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_16",  .addr = A_MIO_PIN_16,
927*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
928*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_17",  .addr = A_MIO_PIN_17,
929*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
930*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_18",  .addr = A_MIO_PIN_18,
931*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
932*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_19",  .addr = A_MIO_PIN_19,
933*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
934*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_20",  .addr = A_MIO_PIN_20,
935*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
936*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_21",  .addr = A_MIO_PIN_21,
937*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
938*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_22",  .addr = A_MIO_PIN_22,
939*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
940*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_23",  .addr = A_MIO_PIN_23,
941*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
942*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_24",  .addr = A_MIO_PIN_24,
943*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
944*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_25",  .addr = A_MIO_PIN_25,
945*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
946*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_26",  .addr = A_MIO_PIN_26,
947*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
948*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_27",  .addr = A_MIO_PIN_27,
949*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
950*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_28",  .addr = A_MIO_PIN_28,
951*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
952*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_29",  .addr = A_MIO_PIN_29,
953*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
954*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_30",  .addr = A_MIO_PIN_30,
955*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
956*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_31",  .addr = A_MIO_PIN_31,
957*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
958*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_32",  .addr = A_MIO_PIN_32,
959*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
960*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_33",  .addr = A_MIO_PIN_33,
961*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
962*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_34",  .addr = A_MIO_PIN_34,
963*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
964*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_35",  .addr = A_MIO_PIN_35,
965*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
966*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_36",  .addr = A_MIO_PIN_36,
967*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
968*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_37",  .addr = A_MIO_PIN_37,
969*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
970*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_38",  .addr = A_MIO_PIN_38,
971*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
972*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_39",  .addr = A_MIO_PIN_39,
973*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
974*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_40",  .addr = A_MIO_PIN_40,
975*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
976*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_41",  .addr = A_MIO_PIN_41,
977*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
978*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_42",  .addr = A_MIO_PIN_42,
979*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
980*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_43",  .addr = A_MIO_PIN_43,
981*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
982*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_44",  .addr = A_MIO_PIN_44,
983*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
984*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_45",  .addr = A_MIO_PIN_45,
985*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
986*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_46",  .addr = A_MIO_PIN_46,
987*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
988*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_47",  .addr = A_MIO_PIN_47,
989*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
990*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_48",  .addr = A_MIO_PIN_48,
991*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
992*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_49",  .addr = A_MIO_PIN_49,
993*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
994*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_50",  .addr = A_MIO_PIN_50,
995*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
996*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_PIN_51",  .addr = A_MIO_PIN_51,
997*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc01,
998*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_RX",  .addr = A_BNK0_EN_RX,
999*8c1c0a1bSFrancisco Iglesias         .reset = 0x3ffffff,
1000*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1001*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_RX0",  .addr = A_BNK0_SEL_RX0,
1002*8c1c0a1bSFrancisco Iglesias         .reset = 0xffffffff,
1003*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_RX1",  .addr = A_BNK0_SEL_RX1,
1004*8c1c0a1bSFrancisco Iglesias         .reset = 0xfffff,
1005*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1006*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_RX_SCHMITT_HYST",  .addr = A_BNK0_EN_RX_SCHMITT_HYST,
1007*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1008*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_WK_PD",  .addr = A_BNK0_EN_WK_PD,
1009*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1010*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_WK_PU",  .addr = A_BNK0_EN_WK_PU,
1011*8c1c0a1bSFrancisco Iglesias         .reset = 0x3ffffff,
1012*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1013*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_DRV0",  .addr = A_BNK0_SEL_DRV0,
1014*8c1c0a1bSFrancisco Iglesias         .reset = 0xffffffff,
1015*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_DRV1",  .addr = A_BNK0_SEL_DRV1,
1016*8c1c0a1bSFrancisco Iglesias         .reset = 0xfffff,
1017*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1018*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_SLEW",  .addr = A_BNK0_SEL_SLEW,
1019*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1020*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_DFT_OPT_INV",  .addr = A_BNK0_EN_DFT_OPT_INV,
1021*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1022*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_PAD2PAD_LOOPBACK",
1023*8c1c0a1bSFrancisco Iglesias         .addr = A_BNK0_EN_PAD2PAD_LOOPBACK,
1024*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1025*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_RX_SPARE0",  .addr = A_BNK0_RX_SPARE0,
1026*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_RX_SPARE1",  .addr = A_BNK0_RX_SPARE1,
1027*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1028*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_TX_SPARE0",  .addr = A_BNK0_TX_SPARE0,
1029*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_TX_SPARE1",  .addr = A_BNK0_TX_SPARE1,
1030*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1031*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_EN1P8",  .addr = A_BNK0_SEL_EN1P8,
1032*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1033*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_B_POR_DETECT",  .addr = A_BNK0_EN_B_POR_DETECT,
1034*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1035*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_LPF_BYP_POR_DETECT",  .addr = A_BNK0_LPF_BYP_POR_DETECT,
1036*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1037*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1038*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_LATCH",  .addr = A_BNK0_EN_LATCH,
1039*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1040*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_VBG_LPF_BYP_B",  .addr = A_BNK0_VBG_LPF_BYP_B,
1041*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1042*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1043*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_AMP_B",  .addr = A_BNK0_EN_AMP_B,
1044*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1045*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SPARE_BIAS",  .addr = A_BNK0_SPARE_BIAS,
1046*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1047*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_DRIVER_BIAS",  .addr = A_BNK0_DRIVER_BIAS,
1048*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffff8000,
1049*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_VMODE",  .addr = A_BNK0_VMODE,
1050*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1051*8c1c0a1bSFrancisco Iglesias         .ro = 0x1,
1052*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_SEL_AUX_IO_RX",  .addr = A_BNK0_SEL_AUX_IO_RX,
1053*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1054*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK0_EN_TX_HS_MODE",  .addr = A_BNK0_EN_TX_HS_MODE,
1055*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1056*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_MST_TRI0",  .addr = A_MIO_MST_TRI0,
1057*8c1c0a1bSFrancisco Iglesias         .reset = 0x3ffffff,
1058*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1059*8c1c0a1bSFrancisco Iglesias     },{ .name = "MIO_MST_TRI1",  .addr = A_MIO_MST_TRI1,
1060*8c1c0a1bSFrancisco Iglesias         .reset = 0x3ffffff,
1061*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1062*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_RX",  .addr = A_BNK1_EN_RX,
1063*8c1c0a1bSFrancisco Iglesias         .reset = 0x3ffffff,
1064*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1065*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_RX0",  .addr = A_BNK1_SEL_RX0,
1066*8c1c0a1bSFrancisco Iglesias         .reset = 0xffffffff,
1067*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_RX1",  .addr = A_BNK1_SEL_RX1,
1068*8c1c0a1bSFrancisco Iglesias         .reset = 0xfffff,
1069*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1070*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_RX_SCHMITT_HYST",  .addr = A_BNK1_EN_RX_SCHMITT_HYST,
1071*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1072*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_WK_PD",  .addr = A_BNK1_EN_WK_PD,
1073*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1074*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_WK_PU",  .addr = A_BNK1_EN_WK_PU,
1075*8c1c0a1bSFrancisco Iglesias         .reset = 0x3ffffff,
1076*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1077*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_DRV0",  .addr = A_BNK1_SEL_DRV0,
1078*8c1c0a1bSFrancisco Iglesias         .reset = 0xffffffff,
1079*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_DRV1",  .addr = A_BNK1_SEL_DRV1,
1080*8c1c0a1bSFrancisco Iglesias         .reset = 0xfffff,
1081*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1082*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_SLEW",  .addr = A_BNK1_SEL_SLEW,
1083*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1084*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_DFT_OPT_INV",  .addr = A_BNK1_EN_DFT_OPT_INV,
1085*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1086*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_PAD2PAD_LOOPBACK",
1087*8c1c0a1bSFrancisco Iglesias         .addr = A_BNK1_EN_PAD2PAD_LOOPBACK,
1088*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1089*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_RX_SPARE0",  .addr = A_BNK1_RX_SPARE0,
1090*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_RX_SPARE1",  .addr = A_BNK1_RX_SPARE1,
1091*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1092*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_TX_SPARE0",  .addr = A_BNK1_TX_SPARE0,
1093*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_TX_SPARE1",  .addr = A_BNK1_TX_SPARE1,
1094*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfff00000,
1095*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_EN1P8",  .addr = A_BNK1_SEL_EN1P8,
1096*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1097*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_B_POR_DETECT",  .addr = A_BNK1_EN_B_POR_DETECT,
1098*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1099*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_LPF_BYP_POR_DETECT",  .addr = A_BNK1_LPF_BYP_POR_DETECT,
1100*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1101*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1102*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_LATCH",  .addr = A_BNK1_EN_LATCH,
1103*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1104*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_VBG_LPF_BYP_B",  .addr = A_BNK1_VBG_LPF_BYP_B,
1105*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1106*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1107*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_AMP_B",  .addr = A_BNK1_EN_AMP_B,
1108*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1109*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SPARE_BIAS",  .addr = A_BNK1_SPARE_BIAS,
1110*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1111*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_DRIVER_BIAS",  .addr = A_BNK1_DRIVER_BIAS,
1112*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffff8000,
1113*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_VMODE",  .addr = A_BNK1_VMODE,
1114*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1115*8c1c0a1bSFrancisco Iglesias         .ro = 0x1,
1116*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_SEL_AUX_IO_RX",  .addr = A_BNK1_SEL_AUX_IO_RX,
1117*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1118*8c1c0a1bSFrancisco Iglesias     },{ .name = "BNK1_EN_TX_HS_MODE",  .addr = A_BNK1_EN_TX_HS_MODE,
1119*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfc000000,
1120*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_CLK_CTRL",  .addr = A_SD0_CLK_CTRL,
1121*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff8,
1122*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_CTRL_REG",  .addr = A_SD0_CTRL_REG,
1123*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1124*8c1c0a1bSFrancisco Iglesias         .pre_write = sd0_ctrl_reg_prew,
1125*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_CONFIG_REG1",  .addr = A_SD0_CONFIG_REG1,
1126*8c1c0a1bSFrancisco Iglesias         .reset = 0x3250,
1127*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffff8000,
1128*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_CONFIG_REG2",  .addr = A_SD0_CONFIG_REG2,
1129*8c1c0a1bSFrancisco Iglesias         .reset = 0xffc,
1130*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffc000,
1131*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_CONFIG_REG3",  .addr = A_SD0_CONFIG_REG3,
1132*8c1c0a1bSFrancisco Iglesias         .reset = 0x407,
1133*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffff800,
1134*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_INITPRESET",  .addr = A_SD0_INITPRESET,
1135*8c1c0a1bSFrancisco Iglesias         .reset = 0x100,
1136*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1137*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_DSPPRESET",  .addr = A_SD0_DSPPRESET,
1138*8c1c0a1bSFrancisco Iglesias         .reset = 0x4,
1139*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1140*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_HSPDPRESET",  .addr = A_SD0_HSPDPRESET,
1141*8c1c0a1bSFrancisco Iglesias         .reset = 0x2,
1142*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1143*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_SDR12PRESET",  .addr = A_SD0_SDR12PRESET,
1144*8c1c0a1bSFrancisco Iglesias         .reset = 0x4,
1145*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1146*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_SDR25PRESET",  .addr = A_SD0_SDR25PRESET,
1147*8c1c0a1bSFrancisco Iglesias         .reset = 0x2,
1148*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1149*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_SDR50PRSET",  .addr = A_SD0_SDR50PRSET,
1150*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1151*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1152*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_SDR104PRST",  .addr = A_SD0_SDR104PRST,
1153*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1154*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_DDR50PRESET",  .addr = A_SD0_DDR50PRESET,
1155*8c1c0a1bSFrancisco Iglesias         .reset = 0x2,
1156*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1157*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_MAXCUR1P8",  .addr = A_SD0_MAXCUR1P8,
1158*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff00,
1159*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_MAXCUR3P0",  .addr = A_SD0_MAXCUR3P0,
1160*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff00,
1161*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_MAXCUR3P3",  .addr = A_SD0_MAXCUR3P3,
1162*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff00,
1163*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_DLL_CTRL",  .addr = A_SD0_DLL_CTRL,
1164*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1165*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc00,
1166*8c1c0a1bSFrancisco Iglesias         .ro = 0x19,
1167*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_CDN_CTRL",  .addr = A_SD0_CDN_CTRL,
1168*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1169*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_DLL_TEST",  .addr = A_SD0_DLL_TEST,
1170*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xff000000,
1171*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_RX_TUNING_SEL",  .addr = A_SD0_RX_TUNING_SEL,
1172*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffe00,
1173*8c1c0a1bSFrancisco Iglesias         .ro = 0x1ff,
1174*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_DLL_DIV_MAP0",  .addr = A_SD0_DLL_DIV_MAP0,
1175*8c1c0a1bSFrancisco Iglesias         .reset = 0x50505050,
1176*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_DLL_DIV_MAP1",  .addr = A_SD0_DLL_DIV_MAP1,
1177*8c1c0a1bSFrancisco Iglesias         .reset = 0x50505050,
1178*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_IOU_COHERENT_CTRL",  .addr = A_SD0_IOU_COHERENT_CTRL,
1179*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1180*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_IOU_INTERCONNECT_ROUTE",
1181*8c1c0a1bSFrancisco Iglesias         .addr = A_SD0_IOU_INTERCONNECT_ROUTE,
1182*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1183*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_IOU_RAM",  .addr = A_SD0_IOU_RAM,
1184*8c1c0a1bSFrancisco Iglesias         .reset = 0x24,
1185*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff80,
1186*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD0_IOU_INTERCONNECT_QOS",
1187*8c1c0a1bSFrancisco Iglesias         .addr = A_SD0_IOU_INTERCONNECT_QOS,
1188*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1189*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_CLK_CTRL",  .addr = A_SD1_CLK_CTRL,
1190*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1191*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_CTRL_REG",  .addr = A_SD1_CTRL_REG,
1192*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1193*8c1c0a1bSFrancisco Iglesias         .pre_write = sd1_ctrl_reg_prew,
1194*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_CONFIG_REG1",  .addr = A_SD1_CONFIG_REG1,
1195*8c1c0a1bSFrancisco Iglesias         .reset = 0x3250,
1196*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffff8000,
1197*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_CONFIG_REG2",  .addr = A_SD1_CONFIG_REG2,
1198*8c1c0a1bSFrancisco Iglesias         .reset = 0xffc,
1199*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffc000,
1200*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_CONFIG_REG3",  .addr = A_SD1_CONFIG_REG3,
1201*8c1c0a1bSFrancisco Iglesias         .reset = 0x407,
1202*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffff800,
1203*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_INITPRESET",  .addr = A_SD1_INITPRESET,
1204*8c1c0a1bSFrancisco Iglesias         .reset = 0x100,
1205*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1206*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_DSPPRESET",  .addr = A_SD1_DSPPRESET,
1207*8c1c0a1bSFrancisco Iglesias         .reset = 0x4,
1208*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1209*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_HSPDPRESET",  .addr = A_SD1_HSPDPRESET,
1210*8c1c0a1bSFrancisco Iglesias         .reset = 0x2,
1211*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1212*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_SDR12PRESET",  .addr = A_SD1_SDR12PRESET,
1213*8c1c0a1bSFrancisco Iglesias         .reset = 0x4,
1214*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1215*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_SDR25PRESET",  .addr = A_SD1_SDR25PRESET,
1216*8c1c0a1bSFrancisco Iglesias         .reset = 0x2,
1217*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1218*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_SDR50PRSET",  .addr = A_SD1_SDR50PRSET,
1219*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1220*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1221*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_SDR104PRST",  .addr = A_SD1_SDR104PRST,
1222*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1223*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_DDR50PRESET",  .addr = A_SD1_DDR50PRESET,
1224*8c1c0a1bSFrancisco Iglesias         .reset = 0x2,
1225*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffe000,
1226*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_MAXCUR1P8",  .addr = A_SD1_MAXCUR1P8,
1227*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff00,
1228*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_MAXCUR3P0",  .addr = A_SD1_MAXCUR3P0,
1229*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff00,
1230*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_MAXCUR3P3",  .addr = A_SD1_MAXCUR3P3,
1231*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff00,
1232*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_DLL_CTRL",  .addr = A_SD1_DLL_CTRL,
1233*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1234*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffc00,
1235*8c1c0a1bSFrancisco Iglesias         .ro = 0x19,
1236*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_CDN_CTRL",  .addr = A_SD1_CDN_CTRL,
1237*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1238*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_DLL_TEST",  .addr = A_SD1_DLL_TEST,
1239*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xff000000,
1240*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_RX_TUNING_SEL",  .addr = A_SD1_RX_TUNING_SEL,
1241*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffe00,
1242*8c1c0a1bSFrancisco Iglesias         .ro = 0x1ff,
1243*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_DLL_DIV_MAP0",  .addr = A_SD1_DLL_DIV_MAP0,
1244*8c1c0a1bSFrancisco Iglesias         .reset = 0x50505050,
1245*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_DLL_DIV_MAP1",  .addr = A_SD1_DLL_DIV_MAP1,
1246*8c1c0a1bSFrancisco Iglesias         .reset = 0x50505050,
1247*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_IOU_COHERENT_CTRL",  .addr = A_SD1_IOU_COHERENT_CTRL,
1248*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1249*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_IOU_INTERCONNECT_ROUTE",
1250*8c1c0a1bSFrancisco Iglesias         .addr = A_SD1_IOU_INTERCONNECT_ROUTE,
1251*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1252*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_IOU_RAM",  .addr = A_SD1_IOU_RAM,
1253*8c1c0a1bSFrancisco Iglesias         .reset = 0x24,
1254*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffff80,
1255*8c1c0a1bSFrancisco Iglesias     },{ .name = "SD1_IOU_INTERCONNECT_QOS",
1256*8c1c0a1bSFrancisco Iglesias         .addr = A_SD1_IOU_INTERCONNECT_QOS,
1257*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1258*8c1c0a1bSFrancisco Iglesias     },{ .name = "OSPI_QSPI_IOU_AXI_MUX_SEL",
1259*8c1c0a1bSFrancisco Iglesias         .addr = A_OSPI_QSPI_IOU_AXI_MUX_SEL,
1260*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1261*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1262*8c1c0a1bSFrancisco Iglesias         .pre_write = ospi_qspi_iou_axi_mux_sel_prew,
1263*8c1c0a1bSFrancisco Iglesias     },{ .name = "QSPI_IOU_COHERENT_CTRL",  .addr = A_QSPI_IOU_COHERENT_CTRL,
1264*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1265*8c1c0a1bSFrancisco Iglesias     },{ .name = "QSPI_IOU_INTERCONNECT_ROUTE",
1266*8c1c0a1bSFrancisco Iglesias         .addr = A_QSPI_IOU_INTERCONNECT_ROUTE,
1267*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1268*8c1c0a1bSFrancisco Iglesias     },{ .name = "QSPI_IOU_RAM",  .addr = A_QSPI_IOU_RAM,
1269*8c1c0a1bSFrancisco Iglesias         .reset = 0x1224,
1270*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffc000,
1271*8c1c0a1bSFrancisco Iglesias     },{ .name = "QSPI_IOU_INTERCONNECT_QOS",
1272*8c1c0a1bSFrancisco Iglesias         .addr = A_QSPI_IOU_INTERCONNECT_QOS,
1273*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1274*8c1c0a1bSFrancisco Iglesias     },{ .name = "OSPI_IOU_COHERENT_CTRL",  .addr = A_OSPI_IOU_COHERENT_CTRL,
1275*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1276*8c1c0a1bSFrancisco Iglesias     },{ .name = "OSPI_IOU_INTERCONNECT_ROUTE",
1277*8c1c0a1bSFrancisco Iglesias         .addr = A_OSPI_IOU_INTERCONNECT_ROUTE,
1278*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1279*8c1c0a1bSFrancisco Iglesias     },{ .name = "OSPI_IOU_RAM",  .addr = A_OSPI_IOU_RAM,
1280*8c1c0a1bSFrancisco Iglesias         .reset = 0xa,
1281*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffffc0,
1282*8c1c0a1bSFrancisco Iglesias     },{ .name = "OSPI_IOU_INTERCONNECT_QOS",
1283*8c1c0a1bSFrancisco Iglesias         .addr = A_OSPI_IOU_INTERCONNECT_QOS,
1284*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1285*8c1c0a1bSFrancisco Iglesias     },{ .name = "OSPI_REFCLK_DLY_CTRL",  .addr = A_OSPI_REFCLK_DLY_CTRL,
1286*8c1c0a1bSFrancisco Iglesias         .reset = 0x13,
1287*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xffffffe0,
1288*8c1c0a1bSFrancisco Iglesias     },{ .name = "CUR_PWR_ST",  .addr = A_CUR_PWR_ST,
1289*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1290*8c1c0a1bSFrancisco Iglesias         .ro = 0x3,
1291*8c1c0a1bSFrancisco Iglesias     },{ .name = "CONNECT_ST",  .addr = A_CONNECT_ST,
1292*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1293*8c1c0a1bSFrancisco Iglesias         .ro = 0x1,
1294*8c1c0a1bSFrancisco Iglesias     },{ .name = "PW_STATE_REQ",  .addr = A_PW_STATE_REQ,
1295*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1296*8c1c0a1bSFrancisco Iglesias     },{ .name = "HOST_U2_PORT_DISABLE",  .addr = A_HOST_U2_PORT_DISABLE,
1297*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1298*8c1c0a1bSFrancisco Iglesias     },{ .name = "DBG_U2PMU",  .addr = A_DBG_U2PMU,
1299*8c1c0a1bSFrancisco Iglesias         .ro = 0xffffffff,
1300*8c1c0a1bSFrancisco Iglesias     },{ .name = "DBG_U2PMU_EXT1",  .addr = A_DBG_U2PMU_EXT1,
1301*8c1c0a1bSFrancisco Iglesias         .ro = 0xffffffff,
1302*8c1c0a1bSFrancisco Iglesias     },{ .name = "DBG_U2PMU_EXT2",  .addr = A_DBG_U2PMU_EXT2,
1303*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffff0,
1304*8c1c0a1bSFrancisco Iglesias         .ro = 0xf,
1305*8c1c0a1bSFrancisco Iglesias     },{ .name = "PME_GEN_U2PMU",  .addr = A_PME_GEN_U2PMU,
1306*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffe,
1307*8c1c0a1bSFrancisco Iglesias         .ro = 0x1,
1308*8c1c0a1bSFrancisco Iglesias     },{ .name = "PWR_CONFIG_USB2",  .addr = A_PWR_CONFIG_USB2,
1309*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xc0000000,
1310*8c1c0a1bSFrancisco Iglesias     },{ .name = "PHY_HUB",  .addr = A_PHY_HUB,
1311*8c1c0a1bSFrancisco Iglesias         .rsvd = 0xfffffffc,
1312*8c1c0a1bSFrancisco Iglesias         .ro = 0x2,
1313*8c1c0a1bSFrancisco Iglesias     },{ .name = "CTRL",  .addr = A_CTRL,
1314*8c1c0a1bSFrancisco Iglesias     },{ .name = "ISR",  .addr = A_ISR,
1315*8c1c0a1bSFrancisco Iglesias         .w1c = 0x1,
1316*8c1c0a1bSFrancisco Iglesias         .post_write = isr_postw,
1317*8c1c0a1bSFrancisco Iglesias     },{ .name = "IMR",  .addr = A_IMR,
1318*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1319*8c1c0a1bSFrancisco Iglesias         .ro = 0x1,
1320*8c1c0a1bSFrancisco Iglesias     },{ .name = "IER",  .addr = A_IER,
1321*8c1c0a1bSFrancisco Iglesias         .pre_write = ier_prew,
1322*8c1c0a1bSFrancisco Iglesias     },{ .name = "IDR",  .addr = A_IDR,
1323*8c1c0a1bSFrancisco Iglesias         .pre_write = idr_prew,
1324*8c1c0a1bSFrancisco Iglesias     },{ .name = "ITR",  .addr = A_ITR,
1325*8c1c0a1bSFrancisco Iglesias         .pre_write = itr_prew,
1326*8c1c0a1bSFrancisco Iglesias     },{ .name = "PARITY_ISR",  .addr = A_PARITY_ISR,
1327*8c1c0a1bSFrancisco Iglesias         .w1c = 0x1fff,
1328*8c1c0a1bSFrancisco Iglesias         .post_write = parity_isr_postw,
1329*8c1c0a1bSFrancisco Iglesias     },{ .name = "PARITY_IMR",  .addr = A_PARITY_IMR,
1330*8c1c0a1bSFrancisco Iglesias         .reset = 0x1fff,
1331*8c1c0a1bSFrancisco Iglesias         .ro = 0x1fff,
1332*8c1c0a1bSFrancisco Iglesias     },{ .name = "PARITY_IER",  .addr = A_PARITY_IER,
1333*8c1c0a1bSFrancisco Iglesias         .pre_write = parity_ier_prew,
1334*8c1c0a1bSFrancisco Iglesias     },{ .name = "PARITY_IDR",  .addr = A_PARITY_IDR,
1335*8c1c0a1bSFrancisco Iglesias         .pre_write = parity_idr_prew,
1336*8c1c0a1bSFrancisco Iglesias     },{ .name = "PARITY_ITR",  .addr = A_PARITY_ITR,
1337*8c1c0a1bSFrancisco Iglesias         .pre_write = parity_itr_prew,
1338*8c1c0a1bSFrancisco Iglesias     },{ .name = "WPROT0",  .addr = A_WPROT0,
1339*8c1c0a1bSFrancisco Iglesias         .reset = 0x1,
1340*8c1c0a1bSFrancisco Iglesias     }
1341*8c1c0a1bSFrancisco Iglesias };
1342*8c1c0a1bSFrancisco Iglesias 
1343*8c1c0a1bSFrancisco Iglesias static void xlnx_versal_pmc_iou_slcr_reset_init(Object *obj, ResetType type)
1344*8c1c0a1bSFrancisco Iglesias {
1345*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(obj);
1346*8c1c0a1bSFrancisco Iglesias     unsigned int i;
1347*8c1c0a1bSFrancisco Iglesias 
1348*8c1c0a1bSFrancisco Iglesias     for (i = 0; i < ARRAY_SIZE(s->regs_info); ++i) {
1349*8c1c0a1bSFrancisco Iglesias         register_reset(&s->regs_info[i]);
1350*8c1c0a1bSFrancisco Iglesias     }
1351*8c1c0a1bSFrancisco Iglesias }
1352*8c1c0a1bSFrancisco Iglesias 
1353*8c1c0a1bSFrancisco Iglesias static void xlnx_versal_pmc_iou_slcr_reset_hold(Object *obj)
1354*8c1c0a1bSFrancisco Iglesias {
1355*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(obj);
1356*8c1c0a1bSFrancisco Iglesias 
1357*8c1c0a1bSFrancisco Iglesias     parity_imr_update_irq(s);
1358*8c1c0a1bSFrancisco Iglesias     imr_update_irq(s);
1359*8c1c0a1bSFrancisco Iglesias 
1360*8c1c0a1bSFrancisco Iglesias     /*
1361*8c1c0a1bSFrancisco Iglesias      * Setup OSPI_QSPI mux
1362*8c1c0a1bSFrancisco Iglesias      * By default axi slave interface is enabled for ospi-dma
1363*8c1c0a1bSFrancisco Iglesias      */
1364*8c1c0a1bSFrancisco Iglesias     qemu_set_irq(s->ospi_mux_sel, 0);
1365*8c1c0a1bSFrancisco Iglesias     qemu_set_irq(s->qspi_ospi_mux_sel, 1);
1366*8c1c0a1bSFrancisco Iglesias }
1367*8c1c0a1bSFrancisco Iglesias 
1368*8c1c0a1bSFrancisco Iglesias static const MemoryRegionOps pmc_iou_slcr_ops = {
1369*8c1c0a1bSFrancisco Iglesias     .read = register_read_memory,
1370*8c1c0a1bSFrancisco Iglesias     .write = register_write_memory,
1371*8c1c0a1bSFrancisco Iglesias     .endianness = DEVICE_LITTLE_ENDIAN,
1372*8c1c0a1bSFrancisco Iglesias     .valid = {
1373*8c1c0a1bSFrancisco Iglesias         .min_access_size = 4,
1374*8c1c0a1bSFrancisco Iglesias         .max_access_size = 4,
1375*8c1c0a1bSFrancisco Iglesias     },
1376*8c1c0a1bSFrancisco Iglesias };
1377*8c1c0a1bSFrancisco Iglesias 
1378*8c1c0a1bSFrancisco Iglesias static void xlnx_versal_pmc_iou_slcr_realize(DeviceState *dev, Error **errp)
1379*8c1c0a1bSFrancisco Iglesias {
1380*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(dev);
1381*8c1c0a1bSFrancisco Iglesias 
1382*8c1c0a1bSFrancisco Iglesias     qdev_init_gpio_out_named(dev, s->sd_emmc_sel, "sd-emmc-sel", 2);
1383*8c1c0a1bSFrancisco Iglesias     qdev_init_gpio_out_named(dev, &s->qspi_ospi_mux_sel,
1384*8c1c0a1bSFrancisco Iglesias                              "qspi-ospi-mux-sel", 1);
1385*8c1c0a1bSFrancisco Iglesias     qdev_init_gpio_out_named(dev, &s->ospi_mux_sel, "ospi-mux-sel", 1);
1386*8c1c0a1bSFrancisco Iglesias }
1387*8c1c0a1bSFrancisco Iglesias 
1388*8c1c0a1bSFrancisco Iglesias static void xlnx_versal_pmc_iou_slcr_init(Object *obj)
1389*8c1c0a1bSFrancisco Iglesias {
1390*8c1c0a1bSFrancisco Iglesias     XlnxVersalPmcIouSlcr *s = XILINX_VERSAL_PMC_IOU_SLCR(obj);
1391*8c1c0a1bSFrancisco Iglesias     SysBusDevice *sbd = SYS_BUS_DEVICE(obj);
1392*8c1c0a1bSFrancisco Iglesias     RegisterInfoArray *reg_array;
1393*8c1c0a1bSFrancisco Iglesias 
1394*8c1c0a1bSFrancisco Iglesias     memory_region_init(&s->iomem, obj, TYPE_XILINX_VERSAL_PMC_IOU_SLCR,
1395*8c1c0a1bSFrancisco Iglesias                        XILINX_VERSAL_PMC_IOU_SLCR_R_MAX * 4);
1396*8c1c0a1bSFrancisco Iglesias     reg_array =
1397*8c1c0a1bSFrancisco Iglesias         register_init_block32(DEVICE(obj), pmc_iou_slcr_regs_info,
1398*8c1c0a1bSFrancisco Iglesias                               ARRAY_SIZE(pmc_iou_slcr_regs_info),
1399*8c1c0a1bSFrancisco Iglesias                               s->regs_info, s->regs,
1400*8c1c0a1bSFrancisco Iglesias                               &pmc_iou_slcr_ops,
1401*8c1c0a1bSFrancisco Iglesias                               XILINX_VERSAL_PMC_IOU_SLCR_ERR_DEBUG,
1402*8c1c0a1bSFrancisco Iglesias                               XILINX_VERSAL_PMC_IOU_SLCR_R_MAX * 4);
1403*8c1c0a1bSFrancisco Iglesias     memory_region_add_subregion(&s->iomem,
1404*8c1c0a1bSFrancisco Iglesias                                 0x0,
1405*8c1c0a1bSFrancisco Iglesias                                 &reg_array->mem);
1406*8c1c0a1bSFrancisco Iglesias     sysbus_init_mmio(sbd, &s->iomem);
1407*8c1c0a1bSFrancisco Iglesias     sysbus_init_irq(sbd, &s->irq_parity_imr);
1408*8c1c0a1bSFrancisco Iglesias     sysbus_init_irq(sbd, &s->irq_imr);
1409*8c1c0a1bSFrancisco Iglesias }
1410*8c1c0a1bSFrancisco Iglesias 
1411*8c1c0a1bSFrancisco Iglesias static const VMStateDescription vmstate_pmc_iou_slcr = {
1412*8c1c0a1bSFrancisco Iglesias     .name = TYPE_XILINX_VERSAL_PMC_IOU_SLCR,
1413*8c1c0a1bSFrancisco Iglesias     .version_id = 1,
1414*8c1c0a1bSFrancisco Iglesias     .minimum_version_id = 1,
1415*8c1c0a1bSFrancisco Iglesias     .fields = (VMStateField[]) {
1416*8c1c0a1bSFrancisco Iglesias         VMSTATE_UINT32_ARRAY(regs, XlnxVersalPmcIouSlcr,
1417*8c1c0a1bSFrancisco Iglesias                              XILINX_VERSAL_PMC_IOU_SLCR_R_MAX),
1418*8c1c0a1bSFrancisco Iglesias         VMSTATE_END_OF_LIST(),
1419*8c1c0a1bSFrancisco Iglesias     }
1420*8c1c0a1bSFrancisco Iglesias };
1421*8c1c0a1bSFrancisco Iglesias 
1422*8c1c0a1bSFrancisco Iglesias static void xlnx_versal_pmc_iou_slcr_class_init(ObjectClass *klass, void *data)
1423*8c1c0a1bSFrancisco Iglesias {
1424*8c1c0a1bSFrancisco Iglesias     DeviceClass *dc = DEVICE_CLASS(klass);
1425*8c1c0a1bSFrancisco Iglesias     ResettableClass *rc = RESETTABLE_CLASS(klass);
1426*8c1c0a1bSFrancisco Iglesias 
1427*8c1c0a1bSFrancisco Iglesias     dc->realize = xlnx_versal_pmc_iou_slcr_realize;
1428*8c1c0a1bSFrancisco Iglesias     dc->vmsd = &vmstate_pmc_iou_slcr;
1429*8c1c0a1bSFrancisco Iglesias     rc->phases.enter = xlnx_versal_pmc_iou_slcr_reset_init;
1430*8c1c0a1bSFrancisco Iglesias     rc->phases.hold  = xlnx_versal_pmc_iou_slcr_reset_hold;
1431*8c1c0a1bSFrancisco Iglesias }
1432*8c1c0a1bSFrancisco Iglesias 
1433*8c1c0a1bSFrancisco Iglesias static const TypeInfo xlnx_versal_pmc_iou_slcr_info = {
1434*8c1c0a1bSFrancisco Iglesias     .name          = TYPE_XILINX_VERSAL_PMC_IOU_SLCR,
1435*8c1c0a1bSFrancisco Iglesias     .parent        = TYPE_SYS_BUS_DEVICE,
1436*8c1c0a1bSFrancisco Iglesias     .instance_size = sizeof(XlnxVersalPmcIouSlcr),
1437*8c1c0a1bSFrancisco Iglesias     .class_init    = xlnx_versal_pmc_iou_slcr_class_init,
1438*8c1c0a1bSFrancisco Iglesias     .instance_init = xlnx_versal_pmc_iou_slcr_init,
1439*8c1c0a1bSFrancisco Iglesias };
1440*8c1c0a1bSFrancisco Iglesias 
1441*8c1c0a1bSFrancisco Iglesias static void xlnx_versal_pmc_iou_slcr_register_types(void)
1442*8c1c0a1bSFrancisco Iglesias {
1443*8c1c0a1bSFrancisco Iglesias     type_register_static(&xlnx_versal_pmc_iou_slcr_info);
1444*8c1c0a1bSFrancisco Iglesias }
1445*8c1c0a1bSFrancisco Iglesias 
1446*8c1c0a1bSFrancisco Iglesias type_init(xlnx_versal_pmc_iou_slcr_register_types)
1447