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