qemu

FORK: QEMU emulator
git clone https://git.neptards.moe/neptards/qemu.git
Log | Files | Refs | Submodules | LICENSE

xlnx-versal-pmc-iou-slcr.c (54283B)


      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                                 &reg_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 = (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)