uboot/arch/arm/include/asm/arch-vf610/imx-regs.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0+ */
   2/*
   3 * Copyright 2013-2014 Freescale Semiconductor, Inc.
   4 */
   5
   6#ifndef __ASM_ARCH_IMX_REGS_H__
   7#define __ASM_ARCH_IMX_REGS_H__
   8
   9#define ARCH_MXC
  10
  11#define IRAM_BASE_ADDR          0x3F000000      /* internal ram */
  12#define IRAM_SIZE               0x00080000      /* 512 KB */
  13
  14#define AIPS0_BASE_ADDR         0x40000000
  15#define AIPS1_BASE_ADDR         0x40080000
  16
  17/* AIPS 0 */
  18#define MSCM_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00001000)
  19#define MSCM_IR_BASE_ADDR       (AIPS0_BASE_ADDR + 0x00001800)
  20#define CA5SCU_BASE_ADDR        (AIPS0_BASE_ADDR + 0x00002000)
  21#define CA5_INTD_BASE_ADDR      (AIPS0_BASE_ADDR + 0x00003000)
  22#define CA5_L2C_BASE_ADDR       (AIPS0_BASE_ADDR + 0x00006000)
  23#define NIC0_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00008000)
  24#define NIC1_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00009000)
  25#define NIC2_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0000A000)
  26#define NIC3_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0000B000)
  27#define NIC4_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0000C000)
  28#define NIC5_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0000D000)
  29#define NIC6_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0000E000)
  30#define NIC7_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0000F000)
  31#define AHBTZASC_BASE_ADDR      (AIPS0_BASE_ADDR + 0x00010000)
  32#define TZASC_SYS0_BASE_ADDR    (AIPS0_BASE_ADDR + 0x00011000)
  33#define TZASC_SYS1_BASE_ADDR    (AIPS0_BASE_ADDR + 0x00012000)
  34#define TZASC_GFX_BASE_ADDR     (AIPS0_BASE_ADDR + 0x00013000)
  35#define TZASC_DDR0_BASE_ADDR    (AIPS0_BASE_ADDR + 0x00014000)
  36#define TZASC_DDR1_BASE_ADDR    (AIPS0_BASE_ADDR + 0x00015000)
  37#define CSU_BASE_ADDR           (AIPS0_BASE_ADDR + 0x00017000)
  38#define DMA0_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00018000)
  39#define DMA0_TCD_BASE_ADDR      (AIPS0_BASE_ADDR + 0x00019000)
  40#define SEMA4_BASE_ADDR         (AIPS0_BASE_ADDR + 0x0001D000)
  41#define FB_BASE_ADDR            (AIPS0_BASE_ADDR + 0x0001E000)
  42#define DMA_MUX0_BASE_ADDR      (AIPS0_BASE_ADDR + 0x00024000)
  43#define UART0_BASE              (AIPS0_BASE_ADDR + 0x00027000)
  44#define UART1_BASE              (AIPS0_BASE_ADDR + 0x00028000)
  45#define UART2_BASE              (AIPS0_BASE_ADDR + 0x00029000)
  46#define UART3_BASE              (AIPS0_BASE_ADDR + 0x0002A000)
  47#define SPI0_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0002C000)
  48#define SPI1_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0002D000)
  49#define SAI0_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0002F000)
  50#define SAI1_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00030000)
  51#define SAI2_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00031000)
  52#define SAI3_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00032000)
  53#define CRC_BASE_ADDR           (AIPS0_BASE_ADDR + 0x00033000)
  54#define USBC0_BASE_ADDR     (AIPS0_BASE_ADDR + 0x00034000)
  55#define PDB_BASE_ADDR           (AIPS0_BASE_ADDR + 0x00036000)
  56#define PIT_BASE_ADDR           (AIPS0_BASE_ADDR + 0x00037000)
  57#define FTM0_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00038000)
  58#define FTM1_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00039000)
  59#define ADC_BASE_ADDR           (AIPS0_BASE_ADDR + 0x0003B000)
  60#define TCON0_BASE_ADDR         (AIPS0_BASE_ADDR + 0x0003D000)
  61#define WDOG1_BASE_ADDR         (AIPS0_BASE_ADDR + 0x0003E000)
  62#define LPTMR_BASE_ADDR         (AIPS0_BASE_ADDR + 0x00040000)
  63#define RLE_BASE_ADDR           (AIPS0_BASE_ADDR + 0x00042000)
  64#define MLB_BASE_ADDR           (AIPS0_BASE_ADDR + 0x00043000)
  65#define QSPI0_BASE_ADDR         (AIPS0_BASE_ADDR + 0x00044000)
  66#define IOMUXC_BASE_ADDR        (AIPS0_BASE_ADDR + 0x00048000)
  67#define ANADIG_BASE_ADDR        (AIPS0_BASE_ADDR + 0x00050000)
  68#define USB_PHY0_BASE_ADDR  (AIPS0_BASE_ADDR + 0x00050800)
  69#define USB_PHY1_BASE_ADDR  (AIPS0_BASE_ADDR + 0x00050C00)
  70#define SCSC_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00052000)
  71#define DCU0_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00058000)
  72#define ASRC_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00060000)
  73#define SPDIF_BASE_ADDR         (AIPS0_BASE_ADDR + 0x00061000)
  74#define ESAI_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00062000)
  75#define ESAI_FIFO_BASE_ADDR     (AIPS0_BASE_ADDR + 0x00063000)
  76#define WDOG_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00065000)
  77#define I2C1_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00066000)
  78#define I2C2_BASE_ADDR          (AIPS0_BASE_ADDR + 0x00067000)
  79#define I2C3_BASE_ADDR          (AIPS0_BASE_ADDR + 0x000E6000)
  80#define I2C4_BASE_ADDR          (AIPS0_BASE_ADDR + 0x000E7000)
  81#define WKUP_BASE_ADDR          (AIPS0_BASE_ADDR + 0x0006A000)
  82#define CCM_BASE_ADDR           (AIPS0_BASE_ADDR + 0x0006B000)
  83#define GPC_BASE_ADDR           (AIPS0_BASE_ADDR + 0x0006C000)
  84#define VREG_DIG_BASE_ADDR      (AIPS0_BASE_ADDR + 0x0006D000)
  85#define SRC_BASE_ADDR           (AIPS0_BASE_ADDR + 0x0006E000)
  86#define CMU_BASE_ADDR           (AIPS0_BASE_ADDR + 0x0006F000)
  87#define GPIO0_BASE_ADDR         (AIPS0_BASE_ADDR + 0x000FF000)
  88#define GPIO1_BASE_ADDR         (AIPS0_BASE_ADDR + 0x000FF040)
  89#define GPIO2_BASE_ADDR         (AIPS0_BASE_ADDR + 0x000FF080)
  90#define GPIO3_BASE_ADDR         (AIPS0_BASE_ADDR + 0x000FF0C0)
  91#define GPIO4_BASE_ADDR         (AIPS0_BASE_ADDR + 0x000FF100)
  92
  93/* AIPS 1 */
  94#define OCOTP_BASE_ADDR         (AIPS1_BASE_ADDR + 0x00025000)
  95#define DDR_BASE_ADDR           (AIPS1_BASE_ADDR + 0x0002E000)
  96#define ESDHC0_BASE_ADDR        (AIPS1_BASE_ADDR + 0x00031000)
  97#define ESDHC1_BASE_ADDR        (AIPS1_BASE_ADDR + 0x00032000)
  98#define USBC1_BASE_ADDR     (AIPS1_BASE_ADDR + 0x00034000)
  99#define ENET_BASE_ADDR          (AIPS1_BASE_ADDR + 0x00050000)
 100#define ENET1_BASE_ADDR         (AIPS1_BASE_ADDR + 0x00051000)
 101#define DCU1_BASE_ADDR          (AIPS1_BASE_ADDR + 0x00058000)
 102#define NFC_BASE_ADDR           (AIPS1_BASE_ADDR + 0x00060000)
 103
 104#define QSPI0_AMBA_BASE         0x20000000
 105
 106/* MUX mode and PAD ctrl are in one register */
 107#define CONFIG_IOMUX_SHARE_CONF_REG
 108
 109#define FEC_QUIRK_ENET_MAC
 110#define I2C_QUIRK_REG
 111
 112/* MSCM interrupt rounter */
 113#define MSCM_IRSPRC_CP0_EN                              1
 114#define MSCM_IRSPRC_NUM                                 112
 115
 116/* DDRMC */
 117#define DDRMC_PHY_DQ_TIMING                             0x00002613
 118#define DDRMC_PHY_DQS_TIMING                            0x00002615
 119#define DDRMC_PHY_CTRL                                  0x00210000
 120#define DDRMC_PHY_MASTER_CTRL                           0x0001012a
 121#define DDRMC_PHY_SLAVE_CTRL                            0x00002000
 122#define DDRMC_PHY_OFF                                   0x00000000
 123#define DDRMC_PHY_PROC_PAD_ODT                          0x00010101
 124
 125#define DDRMC_PHY50_DDR3_MODE                           (1 << 12)
 126#define DDRMC_PHY50_EN_SW_HALF_CYCLE                    (1 << 8)
 127
 128#define DDRMC_CR00_DRAM_CLASS_DDR3                      (0x6 << 8)
 129#define DDRMC_CR00_DRAM_CLASS_LPDDR2                    (0x5 << 8)
 130#define DDRMC_CR00_START                                1
 131#define DDRMC_CR02_DRAM_TINIT(v)                        ((v) & 0xffffff)
 132#define DDRMC_CR10_TRST_PWRON(v)                        (v)
 133#define DDRMC_CR11_CKE_INACTIVE(v)                      (v)
 134#define DDRMC_CR12_WRLAT(v)                             (((v) & 0x1f) << 8)
 135#define DDRMC_CR12_CASLAT_LIN(v)                        ((v) & 0x3f)
 136#define DDRMC_CR13_TRC(v)                               (((v) & 0xff) << 24)
 137#define DDRMC_CR13_TRRD(v)                              (((v) & 0xff) << 16)
 138#define DDRMC_CR13_TCCD(v)                              (((v) & 0x1f) << 8)
 139#define DDRMC_CR13_TBST_INT_INTERVAL(v)                 ((v) & 0x7)
 140#define DDRMC_CR14_TFAW(v)                              (((v) & 0x3f) << 24)
 141#define DDRMC_CR14_TRP(v)                               (((v) & 0x1f) << 16)
 142#define DDRMC_CR14_TWTR(v)                              (((v) & 0xf) << 8)
 143#define DDRMC_CR14_TRAS_MIN(v)                          ((v) & 0xff)
 144#define DDRMC_CR16_TMRD(v)                              (((v) & 0x1f) << 24)
 145#define DDRMC_CR16_TRTP(v)                              (((v) & 0xf) << 16)
 146#define DDRMC_CR17_TRAS_MAX(v)                          (((v) & 0x1ffff) << 8)
 147#define DDRMC_CR17_TMOD(v)                              ((v) & 0xff)
 148#define DDRMC_CR18_TCKESR(v)                            (((v) & 0x1f) << 8)
 149#define DDRMC_CR18_TCKE(v)                              ((v) & 0x7)
 150#define DDRMC_CR20_AP_EN                                (1 << 24)
 151#define DDRMC_CR21_TRCD_INT(v)                          (((v) & 0xff) << 16)
 152#define DDRMC_CR21_TRAS_LOCKOUT(v)                      ((v) << 8)
 153#define DDRMC_CR21_CCMAP_EN                             1
 154#define DDRMC_CR22_TDAL(v)                              (((v) & 0x3f) << 16)
 155#define DDRMC_CR23_BSTLEN(v)                            (((v) & 0x7) << 24)
 156#define DDRMC_CR23_TDLL(v)                              ((v) & 0xffff)
 157#define DDRMC_CR24_TRP_AB(v)                            ((v) & 0x1f)
 158#define DDRMC_CR25_TREF_EN                              (1 << 16)
 159#define DDRMC_CR26_TREF(v)                              (((v) & 0xffff) << 16)
 160#define DDRMC_CR26_TRFC(v)                              ((v) & 0x3ff)
 161#define DDRMC_CR28_TREF_INT(v)                          ((v) & 0xffff)
 162#define DDRMC_CR29_TPDEX(v)                             ((v) & 0xffff)
 163#define DDRMC_CR30_TXPDLL(v)                            ((v) & 0xffff)
 164#define DDRMC_CR31_TXSNR(v)                             (((v) & 0xffff) << 16)
 165#define DDRMC_CR31_TXSR(v)                              ((v) & 0xffff)
 166#define DDRMC_CR33_EN_QK_SREF                           (1 << 16)
 167#define DDRMC_CR34_CKSRX(v)                             (((v) & 0xf) << 16)
 168#define DDRMC_CR34_CKSRE(v)                             (((v) & 0xf) << 8)
 169#define DDRMC_CR38_FREQ_CHG_EN(v)                       (((v) & 0x1) << 8)
 170#define DDRMC_CR39_PHY_INI_COM(v)                       (((v) & 0xffff) << 16)
 171#define DDRMC_CR39_PHY_INI_STA(v)                       (((v) & 0xff) << 8)
 172#define DDRMC_CR39_FRQ_CH_DLLOFF(v)                     ((v) & 0x3)
 173#define DDRMC_CR41_PHY_INI_STRT_INI_DIS                 1
 174#define DDRMC_CR48_MR1_DA_0(v)                          (((v) & 0xffff) << 16)
 175#define DDRMC_CR48_MR0_DA_0(v)                          ((v) & 0xffff)
 176#define DDRMC_CR66_ZQCL(v)                              (((v) & 0xfff) << 16)
 177#define DDRMC_CR66_ZQINIT(v)                            ((v) & 0xfff)
 178#define DDRMC_CR67_ZQCS(v)                              ((v) & 0xfff)
 179#define DDRMC_CR69_ZQ_ON_SREF_EX(v)                     (((v) & 0xf) << 8)
 180#define DDRMC_CR70_REF_PER_ZQ(v)                        (v)
 181#define DDRMC_CR72_ZQCS_ROTATE(v)                       (((v) & 0x1) << 24)
 182#define DDRMC_CR73_APREBIT(v)                           (((v) & 0xf) << 24)
 183#define DDRMC_CR73_COL_DIFF(v)                          (((v) & 0x7) << 16)
 184#define DDRMC_CR73_ROW_DIFF(v)                          (((v) & 0x3) << 8)
 185#define DDRMC_CR74_BANKSPLT_EN                          (1 << 24)
 186#define DDRMC_CR74_ADDR_CMP_EN                          (1 << 16)
 187#define DDRMC_CR74_CMD_AGE_CNT(v)                       (((v) & 0xff) << 8)
 188#define DDRMC_CR74_AGE_CNT(v)                           ((v) & 0xff)
 189#define DDRMC_CR75_RW_PG_EN                             (1 << 24)
 190#define DDRMC_CR75_RW_EN                                (1 << 16)
 191#define DDRMC_CR75_PRI_EN                               (1 << 8)
 192#define DDRMC_CR75_PLEN                                 1
 193#define DDRMC_CR76_NQENT_ACTDIS(v)                      (((v) & 0x7) << 24)
 194#define DDRMC_CR76_D_RW_G_BKCN(v)                       (((v) & 0x3) << 16)
 195#define DDRMC_CR76_W2R_SPLT_EN                          (1 << 8)
 196#define DDRMC_CR76_CS_EN                                1
 197#define DDRMC_CR77_CS_MAP                               (1 << 24)
 198#define DDRMC_CR77_DI_RD_INTLEAVE                       (1 << 8)
 199#define DDRMC_CR77_SWAP_EN                              1
 200#define DDRMC_CR78_Q_FULLNESS(v)                        (((v) & 0x7) << 24)
 201#define DDRMC_CR78_BUR_ON_FLY_BIT(v)                    ((v) & 0xf)
 202#define DDRMC_CR79_CTLUPD_AREF(v)                       (((v) & 0x1) << 24)
 203#define DDRMC_CR82_INT_MASK                             0x10000000
 204#define DDRMC_CR87_ODT_WR_MAPCS0(v)                     ((v) << 24)
 205#define DDRMC_CR87_ODT_RD_MAPCS0(v)                     ((v) << 16)
 206#define DDRMC_CR88_TODTL_CMD(v)                         (((v) & 0x1f) << 16)
 207#define DDRMC_CR89_AODT_RWSMCS(v)                       ((v) & 0xf)
 208#define DDRMC_CR91_R2W_SMCSDL(v)                        (((v) & 0x7) << 16)
 209#define DDRMC_CR96_WLMRD(v)                             (((v) & 0x3f) << 8)
 210#define DDRMC_CR96_WLDQSEN(v)                           ((v) & 0x3f)
 211#define DDRMC_CR97_WRLVL_EN                             (1 << 24)
 212#define DDRMC_CR98_WRLVL_DL_0(v)                        ((v) & 0xffff)
 213#define DDRMC_CR99_WRLVL_DL_1(v)                        ((v) & 0xffff)
 214#define DDRMC_CR102_RDLVL_GT_REGEN                      (1 << 16)
 215#define DDRMC_CR102_RDLVL_REG_EN                        (1 << 8)
 216#define DDRMC_CR105_RDLVL_DL_0(v)                       (((v) & 0xff) << 8)
 217#define DDRMC_CR106_RDLVL_GTDL_0(v)                     ((v) & 0xff)
 218#define DDRMC_CR110_RDLVL_DL_1(v)                       ((v) & 0xff)
 219#define DDRMC_CR110_RDLVL_GTDL_1(v)                     (((v) & 0xff) << 16)
 220#define DDRMC_CR114_RDLVL_GTDL_2(v)                     (((v) & 0xffff) << 8)
 221#define DDRMC_CR115_RDLVL_GTDL_2(v)                     ((v) & 0xff)
 222#define DDRMC_CR117_AXI0_W_PRI(v)                       (((v) & 0x3) << 8)
 223#define DDRMC_CR117_AXI0_R_PRI(v)                       ((v) & 0x3)
 224#define DDRMC_CR118_AXI1_W_PRI(v)                       (((v) & 0x3) << 24)
 225#define DDRMC_CR118_AXI1_R_PRI(v)                       (((v) & 0x3) << 16)
 226#define DDRMC_CR120_AXI0_PRI1_RPRI(v)                   (((v) & 0xf) << 24)
 227#define DDRMC_CR120_AXI0_PRI0_RPRI(v)                   (((v) & 0xf) << 16)
 228#define DDRMC_CR121_AXI0_PRI3_RPRI(v)                   (((v) & 0xf) << 8)
 229#define DDRMC_CR121_AXI0_PRI2_RPRI(v)                   ((v) & 0xf)
 230#define DDRMC_CR122_AXI1_PRI1_RPRI(v)                   (((v) & 0xf) << 24)
 231#define DDRMC_CR122_AXI1_PRI0_RPRI(v)                   (((v) & 0xf) << 16)
 232#define DDRMC_CR122_AXI0_PRIRLX(v)                      ((v) & 0x3ff)
 233#define DDRMC_CR123_AXI1_PRI3_RPRI(v)                   (((v) & 0xf) << 8)
 234#define DDRMC_CR123_AXI1_PRI2_RPRI(v)                   ((v) & 0xf)
 235#define DDRMC_CR123_AXI1_P_ODR_EN                       (1 << 16)
 236#define DDRMC_CR124_AXI1_PRIRLX(v)                      ((v) & 0x3ff)
 237#define DDRMC_CR126_PHY_RDLAT(v)                        (((v) & 0x3f) << 8)
 238#define DDRMC_CR132_WRLAT_ADJ(v)                        (((v) & 0x1f) << 8)
 239#define DDRMC_CR132_RDLAT_ADJ(v)                        ((v) & 0x3f)
 240#define DDRMC_CR137_PHYCTL_DL(v)                        (((v) & 0xf) << 16)
 241#define DDRMC_CR138_PHY_WRLV_MXDL(v)                    (((v) & 0xffff) << 16)
 242#define DDRMC_CR138_PHYDRAM_CK_EN(v)                    (((v) & 0x8) << 8)
 243#define DDRMC_CR139_PHY_WRLV_RESPLAT(v)                 (((v) & 0xff) << 24)
 244#define DDRMC_CR139_PHY_WRLV_LOAD(v)                    (((v) & 0xff) << 16)
 245#define DDRMC_CR139_PHY_WRLV_DLL(v)                     (((v) & 0xff) << 8)
 246#define DDRMC_CR139_PHY_WRLV_EN(v)                      ((v) & 0xff)
 247#define DDRMC_CR140_PHY_WRLV_WW(v)                      ((v) & 0x3ff)
 248#define DDRMC_CR143_RDLV_GAT_MXDL(v)                    (((v) & 0xffff) << 16)
 249#define DDRMC_CR143_RDLV_MXDL(v)                        ((v) & 0xffff)
 250#define DDRMC_CR144_PHY_RDLVL_RES(v)                    (((v) & 0xff) << 24)
 251#define DDRMC_CR144_PHY_RDLV_LOAD(v)                    (((v) & 0xff) << 16)
 252#define DDRMC_CR144_PHY_RDLV_DLL(v)                     (((v) & 0xff) << 8)
 253#define DDRMC_CR144_PHY_RDLV_EN(v)                      ((v) & 0xff)
 254#define DDRMC_CR145_PHY_RDLV_RR(v)                      ((v) & 0x3ff)
 255#define DDRMC_CR146_PHY_RDLVL_RESP(v)                   (v)
 256#define DDRMC_CR147_RDLV_RESP_MASK(v)                   ((v) & 0xfffff)
 257#define DDRMC_CR148_RDLV_GATE_RESP_MASK(v)              ((v) & 0xfffff)
 258#define DDRMC_CR151_RDLV_GAT_DQ_ZERO_CNT(v)             (((v) & 0xf) << 8)
 259#define DDRMC_CR151_RDLVL_DQ_ZERO_CNT(v)                ((v) & 0xf)
 260#define DDRMC_CR154_PAD_ZQ_EARLY_CMP_EN_TIMER(v)        (((v) & 0x1f) << 27)
 261#define DDRMC_CR154_PAD_ZQ_MODE(v)                      (((v) & 0x3) << 21)
 262#define DDRMC_CR154_DDR_SEL_PAD_CONTR(v)                (((v) & 0x3) << 18)
 263#define DDRMC_CR154_PAD_ZQ_HW_FOR(v)                    (((v) & 0x1) << 14)
 264#define DDRMC_CR155_AXI0_AWCACHE                        (1 << 10)
 265#define DDRMC_CR155_PAD_ODT_BYTE1(v)                    (((v) & 0x7) << 3)
 266#define DDRMC_CR155_PAD_ODT_BYTE0(v)                    ((v) & 0x7)
 267#define DDRMC_CR158_TWR(v)                              ((v) & 0x3f)
 268#define DDRMC_CR161_ODT_EN(v)                           (((v) & 0x1) << 16)
 269#define DDRMC_CR161_TODTH_RD(v)                         (((v) & 0xf) << 8)
 270#define DDRMC_CR161_TODTH_WR(v)                         ((v) & 0xf)
 271
 272/* System Reset Controller (SRC) */
 273#define SRC_SRSR_SW_RST                                 (0x1 << 18)
 274#define SRC_SRSR_RESETB                                 (0x1 << 7)
 275#define SRC_SRSR_JTAG_RST                               (0x1 << 5)
 276#define SRC_SRSR_WDOG_M4                                (0x1 << 4)
 277#define SRC_SRSR_WDOG_A5                                (0x1 << 3)
 278#define SRC_SRSR_POR_RST                                (0x1 << 0)
 279#define SRC_SBMR2_BMOD_MASK             (0x3 << 24)
 280#define SRC_SBMR2_BMOD_SHIFT            24
 281#define SRC_SBMR2_BMOD_FUSES            0x0
 282#define SRC_SBMR2_BMOD_SERIAL           0x1
 283#define SRC_SBMR2_BMOD_RCON             0x2
 284
 285/* Slow Clock Source Controller Module (SCSC) */
 286#define SCSC_SOSC_CTR_SOSC_EN            0x1
 287
 288#if !(defined(__KERNEL_STRICT_NAMES) || defined(__ASSEMBLY__))
 289#include <asm/types.h>
 290
 291/* System Reset Controller (SRC) */
 292struct src {
 293        u32 scr;
 294        u32 sbmr1;
 295        u32 srsr;
 296        u32 secr;
 297        u32 gpsr;
 298        u32 sicr;
 299        u32 simr;
 300        u32 sbmr2;
 301        u32 gpr0;
 302        u32 gpr1;
 303        u32 gpr2;
 304        u32 gpr3;
 305        u32 gpr4;
 306        u32 hab0;
 307        u32 hab1;
 308        u32 hab2;
 309        u32 hab3;
 310        u32 hab4;
 311        u32 hab5;
 312        u32 misc0;
 313        u32 misc1;
 314        u32 misc2;
 315        u32 misc3;
 316};
 317
 318/* Periodic Interrupt Timer (PIT) */
 319struct pit_reg {
 320        u32 mcr;
 321        u32 recv0[55];
 322        u32 ltmr64h;
 323        u32 ltmr64l;
 324        u32 recv1[6];
 325        u32 ldval0;
 326        u32 cval0;
 327        u32 tctrl0;
 328        u32 tflg0;
 329        u32 ldval1;
 330        u32 cval1;
 331        u32 tctrl1;
 332        u32 tflg1;
 333        u32 ldval2;
 334        u32 cval2;
 335        u32 tctrl2;
 336        u32 tflg2;
 337        u32 ldval3;
 338        u32 cval3;
 339        u32 tctrl3;
 340        u32 tflg3;
 341        u32 ldval4;
 342        u32 cval4;
 343        u32 tctrl4;
 344        u32 tflg4;
 345        u32 ldval5;
 346        u32 cval5;
 347        u32 tctrl5;
 348        u32 tflg5;
 349        u32 ldval6;
 350        u32 cval6;
 351        u32 tctrl6;
 352        u32 tflg6;
 353        u32 ldval7;
 354        u32 cval7;
 355        u32 tctrl7;
 356        u32 tflg7;
 357};
 358
 359/* Watchdog Timer (WDOG) */
 360struct wdog_regs {
 361        u16 wcr;
 362        u16 wsr;
 363        u16 wrsr;
 364        u16 wicr;
 365        u16 wmcr;
 366};
 367
 368/* LPDDR2/DDR3 SDRAM Memory Controller (DDRMC) */
 369struct ddrmr_regs {
 370        u32 cr[162];
 371        u32 rsvd[94];
 372        u32 phy[53];
 373};
 374
 375/* On-Chip One Time Programmable Controller (OCOTP) */
 376struct ocotp_regs {
 377        u32 ctrl;
 378        u32 ctrl_set;
 379        u32 ctrl_clr;
 380        u32 ctrl_tog;
 381        u32 timing;
 382        u32 rsvd0[3];
 383        u32 data;
 384        u32 rsvd1[3];
 385        u32 read_ctrl;
 386        u32 rsvd2[3];
 387        u32 read_fuse_data;
 388        u32 rsvd3[7];
 389        u32 scs;
 390        u32 scs_set;
 391        u32 scs_clr;
 392        u32 scs_tog;
 393        u32 crc_addr;
 394        u32 rsvd4[3];
 395        u32 crc_value;
 396        u32 rsvd5[3];
 397        u32 version;
 398        u32 rsvd6[0xdb];
 399
 400        struct fuse_bank {
 401                u32 fuse_regs[0x20];
 402        } bank[16];
 403};
 404
 405struct fuse_bank0_regs {
 406        u32 lock;
 407        u32 rsvd0[3];
 408        u32 uid_low;
 409        u32 rsvd1[3];
 410        u32 uid_high;
 411        u32 rsvd2[0x17];
 412};
 413
 414struct fuse_bank4_regs {
 415        u32 sjc_resp0;
 416        u32 rsvd0[3];
 417        u32 sjc_resp1;
 418        u32 rsvd1[3];
 419        u32 mac_addr0;
 420        u32 rsvd2[3];
 421        u32 mac_addr1;
 422        u32 rsvd3[3];
 423        u32 mac_addr2;
 424        u32 rsvd4[3];
 425        u32 mac_addr3;
 426        u32 rsvd5[3];
 427        u32 gp1;
 428        u32 rsvd6[3];
 429        u32 gp2;
 430        u32 rsvd7[3];
 431};
 432
 433/* MSCM Interrupt Router */
 434struct mscm_ir {
 435        u32 ircp0ir;
 436        u32 ircp1ir;
 437        u32 rsvd1[6];
 438        u32 ircpgir;
 439        u32 rsvd2[23];
 440        u16 irsprc[112];
 441        u16 rsvd3[848];
 442};
 443
 444/* SCSC */
 445struct scsc_reg {
 446        u32 sirc_ctr;
 447        u32 sosc_ctr;
 448};
 449
 450/* MSCM */
 451struct mscm {
 452        u32 cpxtype;
 453        u32 cpxnum;
 454        u32 cpxmaster;
 455        u32 cpxcount;
 456        u32 cpxcfg0;
 457        u32 cpxcfg1;
 458        u32 cpxcfg2;
 459        u32 cpxcfg3;
 460};
 461
 462#endif  /* __ASSEMBLER__*/
 463
 464#endif  /* __ASM_ARCH_IMX_REGS_H__ */
 465