1*56f7d184SJoseph Chen /* 2*56f7d184SJoseph Chen * (C) Copyright 2022 Rockchip Electronics Co., Ltd. 3*56f7d184SJoseph Chen * 4*56f7d184SJoseph Chen * SPDX-License-Identifier: GPL-2.0+ 5*56f7d184SJoseph Chen */ 6*56f7d184SJoseph Chen #ifndef _ASM_ARCH_IOC_RK3562_H 7*56f7d184SJoseph Chen #define _ASM_ARCH_IOC_RK3562_H 8*56f7d184SJoseph Chen 9*56f7d184SJoseph Chen #include <common.h> 10*56f7d184SJoseph Chen 11*56f7d184SJoseph Chen struct rk3562_ioc { 12*56f7d184SJoseph Chen uint32_t gpio1a_iomux_sel_l; /* Address Offset: 0x0000 */ 13*56f7d184SJoseph Chen uint32_t gpio1a_iomux_sel_h; /* Address Offset: 0x0004 */ 14*56f7d184SJoseph Chen uint32_t gpio1b_iomux_sel_l; /* Address Offset: 0x0008 */ 15*56f7d184SJoseph Chen uint32_t gpio1b_iomux_sel_h; /* Address Offset: 0x000C */ 16*56f7d184SJoseph Chen uint32_t gpio1c_iomux_sel_l; /* Address Offset: 0x0010 */ 17*56f7d184SJoseph Chen uint32_t gpio1c_iomux_sel_h; /* Address Offset: 0x0014 */ 18*56f7d184SJoseph Chen uint32_t gpio1d_iomux_sel_l; /* Address Offset: 0x0018 */ 19*56f7d184SJoseph Chen uint32_t gpio1d_iomux_sel_h; /* Address Offset: 0x001C */ 20*56f7d184SJoseph Chen uint32_t gpio2a_iomux_sel_l; /* Address Offset: 0x0020 */ 21*56f7d184SJoseph Chen uint32_t reserved0024[23]; /* Address Offset: 0x0024 */ 22*56f7d184SJoseph Chen uint32_t gpio1a_p; /* Address Offset: 0x0080 */ 23*56f7d184SJoseph Chen uint32_t gpio1b_p; /* Address Offset: 0x0084 */ 24*56f7d184SJoseph Chen uint32_t gpio1c_p; /* Address Offset: 0x0088 */ 25*56f7d184SJoseph Chen uint32_t gpio1d_p; /* Address Offset: 0x008C */ 26*56f7d184SJoseph Chen uint32_t gpio2a_p; /* Address Offset: 0x0090 */ 27*56f7d184SJoseph Chen uint32_t reserved0094[11]; /* Address Offset: 0x0094 */ 28*56f7d184SJoseph Chen uint32_t gpio1a_ie; /* Address Offset: 0x00C0 */ 29*56f7d184SJoseph Chen uint32_t gpio1b_ie; /* Address Offset: 0x00C4 */ 30*56f7d184SJoseph Chen uint32_t gpio1c_ie; /* Address Offset: 0x00C8 */ 31*56f7d184SJoseph Chen uint32_t gpio1d_ie; /* Address Offset: 0x00CC */ 32*56f7d184SJoseph Chen uint32_t gpio2a_ie; /* Address Offset: 0x00D0 */ 33*56f7d184SJoseph Chen uint32_t reserved00d4[11]; /* Address Offset: 0x00D4 */ 34*56f7d184SJoseph Chen uint32_t gpio1a_od; /* Address Offset: 0x0100 */ 35*56f7d184SJoseph Chen uint32_t gpio1b_od; /* Address Offset: 0x0104 */ 36*56f7d184SJoseph Chen uint32_t gpio1c_od; /* Address Offset: 0x0108 */ 37*56f7d184SJoseph Chen uint32_t gpio1d_od; /* Address Offset: 0x010C */ 38*56f7d184SJoseph Chen uint32_t gpio2a_od; /* Address Offset: 0x0110 */ 39*56f7d184SJoseph Chen uint32_t reserved0114[11]; /* Address Offset: 0x0114 */ 40*56f7d184SJoseph Chen uint32_t gpio1a_sus; /* Address Offset: 0x0140 */ 41*56f7d184SJoseph Chen uint32_t gpio1b_sus; /* Address Offset: 0x0144 */ 42*56f7d184SJoseph Chen uint32_t gpio1c_sus; /* Address Offset: 0x0148 */ 43*56f7d184SJoseph Chen uint32_t gpio1d_sus; /* Address Offset: 0x014C */ 44*56f7d184SJoseph Chen uint32_t gpio2a_sus; /* Address Offset: 0x0150 */ 45*56f7d184SJoseph Chen uint32_t reserved0154[11]; /* Address Offset: 0x0154 */ 46*56f7d184SJoseph Chen uint32_t gpio1a_sl; /* Address Offset: 0x0180 */ 47*56f7d184SJoseph Chen uint32_t gpio1b_sl; /* Address Offset: 0x0184 */ 48*56f7d184SJoseph Chen uint32_t gpio1c_sl; /* Address Offset: 0x0188 */ 49*56f7d184SJoseph Chen uint32_t gpio1d_sl; /* Address Offset: 0x018C */ 50*56f7d184SJoseph Chen uint32_t gpio2a_sl; /* Address Offset: 0x0190 */ 51*56f7d184SJoseph Chen uint32_t reserved0194[27]; /* Address Offset: 0x0194 */ 52*56f7d184SJoseph Chen uint32_t gpio1a_ds0; /* Address Offset: 0x0200 */ 53*56f7d184SJoseph Chen uint32_t gpio1a_ds1; /* Address Offset: 0x0204 */ 54*56f7d184SJoseph Chen uint32_t gpio1a_ds2; /* Address Offset: 0x0208 */ 55*56f7d184SJoseph Chen uint32_t gpio1a_ds3; /* Address Offset: 0x020C */ 56*56f7d184SJoseph Chen uint32_t gpio1b_ds0; /* Address Offset: 0x0210 */ 57*56f7d184SJoseph Chen uint32_t gpio1b_ds1; /* Address Offset: 0x0214 */ 58*56f7d184SJoseph Chen uint32_t gpio1b_ds2; /* Address Offset: 0x0218 */ 59*56f7d184SJoseph Chen uint32_t gpio1b_ds3; /* Address Offset: 0x021C */ 60*56f7d184SJoseph Chen uint32_t gpio1c_ds0; /* Address Offset: 0x0220 */ 61*56f7d184SJoseph Chen uint32_t gpio1c_ds1; /* Address Offset: 0x0224 */ 62*56f7d184SJoseph Chen uint32_t gpio1c_ds2; /* Address Offset: 0x0228 */ 63*56f7d184SJoseph Chen uint32_t gpio1c_ds3; /* Address Offset: 0x022C */ 64*56f7d184SJoseph Chen uint32_t gpio1d_ds0; /* Address Offset: 0x0230 */ 65*56f7d184SJoseph Chen uint32_t gpio1d_ds1; /* Address Offset: 0x0234 */ 66*56f7d184SJoseph Chen uint32_t gpio1d_ds2; /* Address Offset: 0x0238 */ 67*56f7d184SJoseph Chen uint32_t gpio1d_ds3; /* Address Offset: 0x023C */ 68*56f7d184SJoseph Chen uint32_t gpio2a_ds0; /* Address Offset: 0x0240 */ 69*56f7d184SJoseph Chen uint32_t reserved0244[47]; /* Address Offset: 0x0244 */ 70*56f7d184SJoseph Chen uint32_t io_vsel0; /* Address Offset: 0x0300 */ 71*56f7d184SJoseph Chen uint32_t reserved0304[63]; /* Address Offset: 0x0304 */ 72*56f7d184SJoseph Chen uint32_t mac1_io_con0; /* Address Offset: 0x0400 */ 73*56f7d184SJoseph Chen uint32_t mac1_io_con1; /* Address Offset: 0x0404 */ 74*56f7d184SJoseph Chen uint32_t reserved0408[62]; /* Address Offset: 0x0408 */ 75*56f7d184SJoseph Chen uint32_t sdcard0_io_con; /* Address Offset: 0x0500 */ 76*56f7d184SJoseph Chen uint32_t jtag_m1_con; /* Address Offset: 0x0504 */ 77*56f7d184SJoseph Chen uint32_t reserved0508[16078]; /* Address Offset: 0x0508 */ 78*56f7d184SJoseph Chen uint32_t gpio3a_iomux_sel_l; /* Address Offset: 0x10040 */ 79*56f7d184SJoseph Chen uint32_t gpio3a_iomux_sel_h; /* Address Offset: 0x10044 */ 80*56f7d184SJoseph Chen uint32_t gpio3b_iomux_sel_l; /* Address Offset: 0x10048 */ 81*56f7d184SJoseph Chen uint32_t gpio3b_iomux_sel_h; /* Address Offset: 0x1004C */ 82*56f7d184SJoseph Chen uint32_t gpio3c_iomux_sel_l; /* Address Offset: 0x10050 */ 83*56f7d184SJoseph Chen uint32_t gpio3c_iomux_sel_h; /* Address Offset: 0x10054 */ 84*56f7d184SJoseph Chen uint32_t gpio3d_iomux_sel_l; /* Address Offset: 0x10058 */ 85*56f7d184SJoseph Chen uint32_t gpio3d_iomux_sel_h; /* Address Offset: 0x1005C */ 86*56f7d184SJoseph Chen uint32_t gpio4a_iomux_sel_l; /* Address Offset: 0x10060 */ 87*56f7d184SJoseph Chen uint32_t gpio4a_iomux_sel_h; /* Address Offset: 0x10064 */ 88*56f7d184SJoseph Chen uint32_t gpio4b_iomux_sel_l; /* Address Offset: 0x10068 */ 89*56f7d184SJoseph Chen uint32_t gpio4b_iomux_sel_h; /* Address Offset: 0x1006C */ 90*56f7d184SJoseph Chen uint32_t reserved10070[12]; /* Address Offset: 0x10070 */ 91*56f7d184SJoseph Chen uint32_t gpio3a_p; /* Address Offset: 0x100A0 */ 92*56f7d184SJoseph Chen uint32_t gpio3b_p; /* Address Offset: 0x100A4 */ 93*56f7d184SJoseph Chen uint32_t gpio3c_p; /* Address Offset: 0x100A8 */ 94*56f7d184SJoseph Chen uint32_t gpio3d_p; /* Address Offset: 0x100AC */ 95*56f7d184SJoseph Chen uint32_t gpio4a_p; /* Address Offset: 0x100B0 */ 96*56f7d184SJoseph Chen uint32_t gpio4b_p; /* Address Offset: 0x100B4 */ 97*56f7d184SJoseph Chen uint32_t reserved100b8[10]; /* Address Offset: 0x100B8 */ 98*56f7d184SJoseph Chen uint32_t gpio3a_ie; /* Address Offset: 0x100E0 */ 99*56f7d184SJoseph Chen uint32_t gpio3b_ie; /* Address Offset: 0x100E4 */ 100*56f7d184SJoseph Chen uint32_t gpio3c_ie; /* Address Offset: 0x100E8 */ 101*56f7d184SJoseph Chen uint32_t gpio3d_ie; /* Address Offset: 0x100EC */ 102*56f7d184SJoseph Chen uint32_t gpio4a_ie; /* Address Offset: 0x100F0 */ 103*56f7d184SJoseph Chen uint32_t gpio4b_ie; /* Address Offset: 0x100F4 */ 104*56f7d184SJoseph Chen uint32_t reserved100f8[10]; /* Address Offset: 0x100F8 */ 105*56f7d184SJoseph Chen uint32_t gpio3a_od; /* Address Offset: 0x10120 */ 106*56f7d184SJoseph Chen uint32_t gpio3b_od; /* Address Offset: 0x10124 */ 107*56f7d184SJoseph Chen uint32_t gpio3c_od; /* Address Offset: 0x10128 */ 108*56f7d184SJoseph Chen uint32_t gpio3d_od; /* Address Offset: 0x1012C */ 109*56f7d184SJoseph Chen uint32_t gpio4a_od; /* Address Offset: 0x10130 */ 110*56f7d184SJoseph Chen uint32_t gpio4b_od; /* Address Offset: 0x10134 */ 111*56f7d184SJoseph Chen uint32_t reserved10138[10]; /* Address Offset: 0x10138 */ 112*56f7d184SJoseph Chen uint32_t gpio3a_sus; /* Address Offset: 0x10160 */ 113*56f7d184SJoseph Chen uint32_t gpio3b_sus; /* Address Offset: 0x10164 */ 114*56f7d184SJoseph Chen uint32_t gpio3c_sus; /* Address Offset: 0x10168 */ 115*56f7d184SJoseph Chen uint32_t gpio3d_sus; /* Address Offset: 0x1016C */ 116*56f7d184SJoseph Chen uint32_t gpio4a_sus; /* Address Offset: 0x10170 */ 117*56f7d184SJoseph Chen uint32_t gpio4b_sus; /* Address Offset: 0x10174 */ 118*56f7d184SJoseph Chen uint32_t reserved10178[10]; /* Address Offset: 0x10178 */ 119*56f7d184SJoseph Chen uint32_t gpio3a_sl; /* Address Offset: 0x101A0 */ 120*56f7d184SJoseph Chen uint32_t gpio3b_sl; /* Address Offset: 0x101A4 */ 121*56f7d184SJoseph Chen uint32_t gpio3c_sl; /* Address Offset: 0x101A8 */ 122*56f7d184SJoseph Chen uint32_t gpio3d_sl; /* Address Offset: 0x101AC */ 123*56f7d184SJoseph Chen uint32_t gpio4a_sl; /* Address Offset: 0x101B0 */ 124*56f7d184SJoseph Chen uint32_t gpio4b_sl; /* Address Offset: 0x101B4 */ 125*56f7d184SJoseph Chen uint32_t reserved101b8[50]; /* Address Offset: 0x101B8 */ 126*56f7d184SJoseph Chen uint32_t gpio3a_ds0; /* Address Offset: 0x10280 */ 127*56f7d184SJoseph Chen uint32_t gpio3a_ds1; /* Address Offset: 0x10284 */ 128*56f7d184SJoseph Chen uint32_t gpio3a_ds2; /* Address Offset: 0x10288 */ 129*56f7d184SJoseph Chen uint32_t gpio3a_ds3; /* Address Offset: 0x1028C */ 130*56f7d184SJoseph Chen uint32_t gpio3b_ds0; /* Address Offset: 0x10290 */ 131*56f7d184SJoseph Chen uint32_t gpio3b_ds1; /* Address Offset: 0x10294 */ 132*56f7d184SJoseph Chen uint32_t gpio3b_ds2; /* Address Offset: 0x10298 */ 133*56f7d184SJoseph Chen uint32_t gpio3b_ds3; /* Address Offset: 0x1029C */ 134*56f7d184SJoseph Chen uint32_t gpio3c_ds0; /* Address Offset: 0x102A0 */ 135*56f7d184SJoseph Chen uint32_t gpio3c_ds1; /* Address Offset: 0x102A4 */ 136*56f7d184SJoseph Chen uint32_t gpio3c_ds2; /* Address Offset: 0x102A8 */ 137*56f7d184SJoseph Chen uint32_t gpio3c_ds3; /* Address Offset: 0x102AC */ 138*56f7d184SJoseph Chen uint32_t gpio3d_ds0; /* Address Offset: 0x102B0 */ 139*56f7d184SJoseph Chen uint32_t gpio3d_ds1; /* Address Offset: 0x102B4 */ 140*56f7d184SJoseph Chen uint32_t gpio3d_ds2; /* Address Offset: 0x102B8 */ 141*56f7d184SJoseph Chen uint32_t gpio3d_ds3; /* Address Offset: 0x102BC */ 142*56f7d184SJoseph Chen uint32_t gpio4a_ds0; /* Address Offset: 0x102C0 */ 143*56f7d184SJoseph Chen uint32_t gpio4a_ds1; /* Address Offset: 0x102C4 */ 144*56f7d184SJoseph Chen uint32_t gpio4a_ds2; /* Address Offset: 0x102C8 */ 145*56f7d184SJoseph Chen uint32_t gpio4a_ds3; /* Address Offset: 0x102CC */ 146*56f7d184SJoseph Chen uint32_t gpio4b_ds0; /* Address Offset: 0x102D0 */ 147*56f7d184SJoseph Chen uint32_t gpio4b_ds1; /* Address Offset: 0x102D4 */ 148*56f7d184SJoseph Chen uint32_t gpio4b_ds2; /* Address Offset: 0x102D8 */ 149*56f7d184SJoseph Chen uint32_t gpio4b_ds3; /* Address Offset: 0x102DC */ 150*56f7d184SJoseph Chen uint32_t reserved102e0[8]; /* Address Offset: 0x102E0 */ 151*56f7d184SJoseph Chen uint32_t io_vsel1; /* Address Offset: 0x10300 */ 152*56f7d184SJoseph Chen uint32_t reserved10304[63]; /* Address Offset: 0x10304 */ 153*56f7d184SJoseph Chen uint32_t mac0_io_con0; /* Address Offset: 0x10400 */ 154*56f7d184SJoseph Chen uint32_t mac0_io_con1; /* Address Offset: 0x10404 */ 155*56f7d184SJoseph Chen uint32_t reserved10408[62]; /* Address Offset: 0x10408 */ 156*56f7d184SJoseph Chen uint32_t vo_io_con; /* Address Offset: 0x10500 */ 157*56f7d184SJoseph Chen uint32_t reserved10504[35]; /* Address Offset: 0x10504 */ 158*56f7d184SJoseph Chen uint32_t saradc1_con; /* Address Offset: 0x10590 */ 159*56f7d184SJoseph Chen uint32_t reserved10594[16027]; /* Address Offset: 0x10594 */ 160*56f7d184SJoseph Chen uint32_t gpio0a_iomux_sel_l; /* Address Offset: 0x20000 */ 161*56f7d184SJoseph Chen uint32_t gpio0a_iomux_sel_h; /* Address Offset: 0x20004 */ 162*56f7d184SJoseph Chen uint32_t gpio0b_iomux_sel_l; /* Address Offset: 0x20008 */ 163*56f7d184SJoseph Chen uint32_t gpio0b_iomux_sel_h; /* Address Offset: 0x2000C */ 164*56f7d184SJoseph Chen uint32_t gpio0c_iomux_sel_l; /* Address Offset: 0x20010 */ 165*56f7d184SJoseph Chen uint32_t gpio0c_iomux_sel_h; /* Address Offset: 0x20014 */ 166*56f7d184SJoseph Chen uint32_t gpio0d_iomux_sel_l; /* Address Offset: 0x20018 */ 167*56f7d184SJoseph Chen uint32_t reserved2001c; /* Address Offset: 0x2001C */ 168*56f7d184SJoseph Chen uint32_t gpio0a_p; /* Address Offset: 0x20020 */ 169*56f7d184SJoseph Chen uint32_t gpio0b_p; /* Address Offset: 0x20024 */ 170*56f7d184SJoseph Chen uint32_t gpio0c_p; /* Address Offset: 0x20028 */ 171*56f7d184SJoseph Chen uint32_t gpio0d_p; /* Address Offset: 0x2002C */ 172*56f7d184SJoseph Chen uint32_t gpio0a_ie; /* Address Offset: 0x20030 */ 173*56f7d184SJoseph Chen uint32_t gpio0b_ie; /* Address Offset: 0x20034 */ 174*56f7d184SJoseph Chen uint32_t gpio0c_ie; /* Address Offset: 0x20038 */ 175*56f7d184SJoseph Chen uint32_t gpio0d_ie; /* Address Offset: 0x2003C */ 176*56f7d184SJoseph Chen uint32_t gpio0a_od; /* Address Offset: 0x20040 */ 177*56f7d184SJoseph Chen uint32_t gpio0b_od; /* Address Offset: 0x20044 */ 178*56f7d184SJoseph Chen uint32_t gpio0c_od; /* Address Offset: 0x20048 */ 179*56f7d184SJoseph Chen uint32_t gpio0d_od; /* Address Offset: 0x2004C */ 180*56f7d184SJoseph Chen uint32_t gpio0a_sus; /* Address Offset: 0x20050 */ 181*56f7d184SJoseph Chen uint32_t gpio0b_sus; /* Address Offset: 0x20054 */ 182*56f7d184SJoseph Chen uint32_t gpio0c_sus; /* Address Offset: 0x20058 */ 183*56f7d184SJoseph Chen uint32_t gpio0d_sus; /* Address Offset: 0x2005C */ 184*56f7d184SJoseph Chen uint32_t gpio0a_sl; /* Address Offset: 0x20060 */ 185*56f7d184SJoseph Chen uint32_t gpio0b_sl; /* Address Offset: 0x20064 */ 186*56f7d184SJoseph Chen uint32_t gpio0c_sl; /* Address Offset: 0x20068 */ 187*56f7d184SJoseph Chen uint32_t gpio0d_sl; /* Address Offset: 0x2006C */ 188*56f7d184SJoseph Chen uint32_t gpio0a_ds0; /* Address Offset: 0x20070 */ 189*56f7d184SJoseph Chen uint32_t gpio0a_ds1; /* Address Offset: 0x20074 */ 190*56f7d184SJoseph Chen uint32_t gpio0a_ds2; /* Address Offset: 0x20078 */ 191*56f7d184SJoseph Chen uint32_t gpio0a_ds3; /* Address Offset: 0x2007C */ 192*56f7d184SJoseph Chen uint32_t gpio0b_ds0; /* Address Offset: 0x20080 */ 193*56f7d184SJoseph Chen uint32_t gpio0b_ds1; /* Address Offset: 0x20084 */ 194*56f7d184SJoseph Chen uint32_t gpio0b_ds2; /* Address Offset: 0x20088 */ 195*56f7d184SJoseph Chen uint32_t gpio0b_ds3; /* Address Offset: 0x2008C */ 196*56f7d184SJoseph Chen uint32_t gpio0c_ds0; /* Address Offset: 0x20090 */ 197*56f7d184SJoseph Chen uint32_t gpio0c_ds1; /* Address Offset: 0x20094 */ 198*56f7d184SJoseph Chen uint32_t gpio0c_ds2; /* Address Offset: 0x20098 */ 199*56f7d184SJoseph Chen uint32_t gpio0c_ds3; /* Address Offset: 0x2009C */ 200*56f7d184SJoseph Chen uint32_t gpio0d_ds0; /* Address Offset: 0x200A0 */ 201*56f7d184SJoseph Chen uint32_t reserved200a4[23]; /* Address Offset: 0x200A4 */ 202*56f7d184SJoseph Chen uint32_t jtag_m0_con; /* Address Offset: 0x20100 */ 203*56f7d184SJoseph Chen uint32_t uart_io_con; /* Address Offset: 0x20104 */ 204*56f7d184SJoseph Chen uint32_t reserved20108[16]; /* Address Offset: 0x20108 */ 205*56f7d184SJoseph Chen uint32_t io_vsel2; /* Address Offset: 0x20148 */ 206*56f7d184SJoseph Chen uint32_t xin_con; /* Address Offset: 0x2014C */ 207*56f7d184SJoseph Chen }; 208*56f7d184SJoseph Chen check_member(rk3562_ioc, xin_con, 0x2014c); 209*56f7d184SJoseph Chen 210*56f7d184SJoseph Chen #endif 211*56f7d184SJoseph Chen 212