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