Home | History | Annotate | Download | only in arch-vf610
      1 /* SPDX-License-Identifier: GPL-2.0+ */
      2 /*
      3  * Copyright 2013-2014 Freescale Semiconductor, Inc.
      4  */
      5 
      6 #ifndef __ARCH_ARM_MACH_VF610_CCM_REGS_H__
      7 #define __ARCH_ARM_MACH_VF610_CCM_REGS_H__
      8 
      9 #ifndef __ASSEMBLY__
     10 
     11 #include <linux/types.h>
     12 
     13 /* Clock Controller Module (CCM) */
     14 struct ccm_reg {
     15 	u32 ccr;
     16 	u32 csr;
     17 	u32 ccsr;
     18 	u32 cacrr;
     19 	u32 cscmr1;
     20 	u32 cscdr1;
     21 	u32 cscdr2;
     22 	u32 cscdr3;
     23 	u32 cscmr2;
     24 	u32 cscdr4;
     25 	u32 ctor;
     26 	u32 clpcr;
     27 	u32 cisr;
     28 	u32 cimr;
     29 	u32 ccosr;
     30 	u32 cgpr;
     31 	u32 ccgr0;
     32 	u32 ccgr1;
     33 	u32 ccgr2;
     34 	u32 ccgr3;
     35 	u32 ccgr4;
     36 	u32 ccgr5;
     37 	u32 ccgr6;
     38 	u32 ccgr7;
     39 	u32 ccgr8;
     40 	u32 ccgr9;
     41 	u32 ccgr10;
     42 	u32 ccgr11;
     43 	u32 cmeor0;
     44 	u32 cmeor1;
     45 	u32 cmeor2;
     46 	u32 cmeor3;
     47 	u32 cmeor4;
     48 	u32 cmeor5;
     49 	u32 cppdsr;
     50 	u32 ccowr;
     51 	u32 ccpgr0;
     52 	u32 ccpgr1;
     53 	u32 ccpgr2;
     54 	u32 ccpgr3;
     55 };
     56 
     57 /* Analog components control digital interface (ANADIG) */
     58 struct anadig_reg {
     59 	u32 reserved_0x000[4];
     60 	u32 pll3_ctrl;
     61 	u32 reserved_0x014[3];
     62 	u32 pll7_ctrl;
     63 	u32 reserved_0x024[3];
     64 	u32 pll2_ctrl;
     65 	u32 reserved_0x034[3];
     66 	u32 pll2_ss;
     67 	u32 reserved_0x044[3];
     68 	u32 pll2_num;
     69 	u32 reserved_0x054[3];
     70 	u32 pll2_denom;
     71 	u32 reserved_0x064[3];
     72 	u32 pll4_ctrl;
     73 	u32 reserved_0x074[3];
     74 	u32 pll4_num;
     75 	u32 reserved_0x084[3];
     76 	u32 pll4_denom;
     77 	u32 reserved_0x094[3];
     78 	u32 pll6_ctrl;
     79 	u32 reserved_0x0A4[3];
     80 	u32 pll6_num;
     81 	u32 reserved_0x0B4[3];
     82 	u32 pll6_denom;
     83 	u32 reserved_0x0C4[7];
     84 	u32 pll5_ctrl;
     85 	u32 reserved_0x0E4[3];
     86 	u32 pll3_pfd;
     87 	u32 reserved_0x0F4[3];
     88 	u32 pll2_pfd;
     89 	u32 reserved_0x104[3];
     90 	u32 reg_1p1;
     91 	u32 reserved_0x114[3];
     92 	u32 reg_3p0;
     93 	u32 reserved_0x124[3];
     94 	u32 reg_2p5;
     95 	u32 reserved_0x134[7];
     96 	u32 ana_misc0;
     97 	u32 reserved_0x154[3];
     98 	u32 ana_misc1;
     99 	u32 reserved_0x164[63];
    100 	u32 anadig_digprog;
    101 	u32 reserved_0x264[3];
    102 	u32 pll1_ctrl;
    103 	u32 reserved_0x274[3];
    104 	u32 pll1_ss;
    105 	u32 reserved_0x284[3];
    106 	u32 pll1_num;
    107 	u32 reserved_0x294[3];
    108 	u32 pll1_denom;
    109 	u32 reserved_0x2A4[3];
    110 	u32 pll1_pdf;
    111 	u32 reserved_0x2B4[3];
    112 	u32 pll_lock;
    113 };
    114 #endif
    115 
    116 #define CCM_CCR_FIRC_EN				(1 << 16)
    117 #define CCM_CCR_OSCNT_MASK			0xff
    118 #define CCM_CCR_OSCNT(v)			((v) & 0xff)
    119 
    120 #define CCM_CCSR_PLL2_PFD_CLK_SEL_OFFSET	19
    121 #define CCM_CCSR_PLL2_PFD_CLK_SEL_MASK		(0x7 << 19)
    122 #define CCM_CCSR_PLL2_PFD_CLK_SEL(v)		(((v) & 0x7) << 19)
    123 
    124 #define CCM_CCSR_PLL1_PFD_CLK_SEL_OFFSET	16
    125 #define CCM_CCSR_PLL1_PFD_CLK_SEL_MASK		(0x7 << 16)
    126 #define CCM_CCSR_PLL1_PFD_CLK_SEL(v)		(((v) & 0x7) << 16)
    127 
    128 #define CCM_CCSR_PLL2_PFD4_EN			(1 << 15)
    129 #define CCM_CCSR_PLL2_PFD3_EN			(1 << 14)
    130 #define CCM_CCSR_PLL2_PFD2_EN			(1 << 13)
    131 #define CCM_CCSR_PLL2_PFD1_EN			(1 << 12)
    132 #define CCM_CCSR_PLL1_PFD4_EN			(1 << 11)
    133 #define CCM_CCSR_PLL1_PFD3_EN			(1 << 10)
    134 #define CCM_CCSR_PLL1_PFD2_EN			(1 << 9)
    135 #define CCM_CCSR_PLL1_PFD1_EN			(1 << 8)
    136 
    137 #define CCM_CCSR_DDRC_CLK_SEL(v)		((v) << 6)
    138 #define CCM_CCSR_FAST_CLK_SEL(v)		((v) << 5)
    139 
    140 #define CCM_CCSR_SYS_CLK_SEL_OFFSET		0
    141 #define CCM_CCSR_SYS_CLK_SEL_MASK		0x7
    142 #define CCM_CCSR_SYS_CLK_SEL(v)			((v) & 0x7)
    143 
    144 #define CCM_CACRR_IPG_CLK_DIV_OFFSET		11
    145 #define CCM_CACRR_IPG_CLK_DIV_MASK		(0x3 << 11)
    146 #define CCM_CACRR_IPG_CLK_DIV(v)		(((v) & 0x3) << 11)
    147 #define CCM_CACRR_BUS_CLK_DIV_OFFSET		3
    148 #define CCM_CACRR_BUS_CLK_DIV_MASK		(0x7 << 3)
    149 #define CCM_CACRR_BUS_CLK_DIV(v)		(((v) & 0x7) << 3)
    150 #define CCM_CACRR_ARM_CLK_DIV_OFFSET		0
    151 #define CCM_CACRR_ARM_CLK_DIV_MASK		0x7
    152 #define CCM_CACRR_ARM_CLK_DIV(v)		((v) & 0x7)
    153 
    154 #define CCM_CSCMR1_DCU1_CLK_SEL			(1 << 29)
    155 #define CCM_CSCMR1_DCU0_CLK_SEL			(1 << 28)
    156 
    157 #define CCM_CSCMR1_QSPI0_CLK_SEL_OFFSET		22
    158 #define CCM_CSCMR1_QSPI0_CLK_SEL_MASK		(0x3 << 22)
    159 #define CCM_CSCMR1_QSPI0_CLK_SEL(v)		(((v) & 0x3) << 22)
    160 #define CCM_CSCMR1_ESDHC1_CLK_SEL_OFFSET	18
    161 #define CCM_CSCMR1_ESDHC1_CLK_SEL_MASK		(0x3 << 18)
    162 #define CCM_CSCMR1_ESDHC1_CLK_SEL(v)		(((v) & 0x3) << 18)
    163 #define CCM_CSCMR1_NFC_CLK_SEL_OFFSET		12
    164 #define CCM_CSCMR1_NFC_CLK_SEL_MASK		(0x3 << 12)
    165 #define CCM_CSCMR1_NFC_CLK_SEL(v)		(((v) & 0x3) << 12)
    166 
    167 #define CCM_CSCDR1_RMII_CLK_EN			(1 << 24)
    168 
    169 #define CCM_CSCDR2_NFC_EN			(1 << 9)
    170 #define CCM_CSCDR2_NFC_FRAC_DIV_EN		(1 << 13)
    171 #define CCM_CSCDR2_NFC_CLK_INV			(1 << 14)
    172 #define CCM_CSCDR2_NFC_FRAC_DIV_OFFSET		4
    173 #define CCM_CSCDR2_NFC_FRAC_DIV_MASK		(0xf << 4)
    174 #define CCM_CSCDR2_NFC_FRAC_DIV(v)		(((v) & 0xf) << 4)
    175 
    176 #define CCM_CSCDR2_ESDHC1_EN			(1 << 29)
    177 #define CCM_CSCDR2_ESDHC1_CLK_DIV_OFFSET	20
    178 #define CCM_CSCDR2_ESDHC1_CLK_DIV_MASK		(0xf << 20)
    179 #define CCM_CSCDR2_ESDHC1_CLK_DIV(v)		(((v) & 0xf) << 20)
    180 
    181 #define CCM_CSCDR3_DCU1_EN			(1 << 23)
    182 #define CCM_CSCDR3_DCU1_DIV_MASK		(0x7 << 20)
    183 #define CCM_CSCDR3_DCU1_DIV(v)			(((v) & 0x7) << 20)
    184 #define CCM_CSCDR3_DCU0_EN			(1 << 19)
    185 #define CCM_CSCDR3_DCU0_DIV_MASK		(0x7 << 16)
    186 #define CCM_CSCDR3_DCU0_DIV(v)			(((v) & 0x7) << 16)
    187 
    188 #define CCM_CSCDR3_NFC_PRE_DIV_OFFSET		13
    189 #define CCM_CSCDR3_NFC_PRE_DIV_MASK		(0x7 << 13)
    190 #define CCM_CSCDR3_NFC_PRE_DIV(v)		(((v) & 0x7) << 13)
    191 #define CCM_CSCDR3_QSPI0_EN			(1 << 4)
    192 #define CCM_CSCDR3_QSPI0_DIV(v)			((v) << 3)
    193 #define CCM_CSCDR3_QSPI0_X2_DIV(v)		((v) << 2)
    194 #define CCM_CSCDR3_QSPI0_X4_DIV(v)		((v) & 0x3)
    195 
    196 #define CCM_CSCMR2_RMII_CLK_SEL_OFFSET		4
    197 #define CCM_CSCMR2_RMII_CLK_SEL_MASK		(0x3 << 4)
    198 #define CCM_CSCMR2_RMII_CLK_SEL(v)		(((v) & 0x3) << 4)
    199 
    200 #define CCM_REG_CTRL_MASK			0xffffffff
    201 #define CCM_CCGR0_UART0_CTRL_MASK               (0x3 << 14)
    202 #define CCM_CCGR0_UART1_CTRL_MASK		(0x3 << 16)
    203 #define CCM_CCGR0_DSPI0_CTRL_MASK		(0x3 << 24)
    204 #define CCM_CCGR0_DSPI1_CTRL_MASK		(0x3 << 26)
    205 #define CCM_CCGR1_USBC0_CTRL_MASK       (0x3 << 8)
    206 #define CCM_CCGR1_PIT_CTRL_MASK			(0x3 << 14)
    207 #define CCM_CCGR1_TCON0_CTRL_MASK		(0x3 << 26)
    208 #define CCM_CCGR1_WDOGA5_CTRL_MASK		(0x3 << 28)
    209 #define CCM_CCGR2_QSPI0_CTRL_MASK		(0x3 << 8)
    210 #define CCM_CCGR2_IOMUXC_CTRL_MASK		(0x3 << 16)
    211 #define CCM_CCGR2_PORTA_CTRL_MASK		(0x3 << 18)
    212 #define CCM_CCGR2_PORTB_CTRL_MASK		(0x3 << 20)
    213 #define CCM_CCGR2_PORTC_CTRL_MASK		(0x3 << 22)
    214 #define CCM_CCGR2_PORTD_CTRL_MASK		(0x3 << 24)
    215 #define CCM_CCGR2_PORTE_CTRL_MASK		(0x3 << 26)
    216 #define CCM_CCGR3_ANADIG_CTRL_MASK		0x3
    217 #define CCM_CCGR3_SCSC_CTRL_MASK        (0x3 << 4)
    218 #define CCM_CCGR3_DCU0_CTRL_MASK		(0x3 << 16)
    219 #define CCM_CCGR4_WKUP_CTRL_MASK		(0x3 << 20)
    220 #define CCM_CCGR4_CCM_CTRL_MASK			(0x3 << 22)
    221 #define CCM_CCGR4_GPC_CTRL_MASK			(0x3 << 24)
    222 #define CCM_CCGR4_I2C0_CTRL_MASK		(0x3 << 12)
    223 #define CCM_CCGR4_I2C1_CTRL_MASK		(0x3 << 14)
    224 #define CCM_CCGR6_OCOTP_CTRL_MASK		(0x3 << 10)
    225 #define CCM_CCGR6_DSPI2_CTRL_MASK		(0x3 << 24)
    226 #define CCM_CCGR6_DSPI3_CTRL_MASK		(0x3 << 26)
    227 #define CCM_CCGR6_DDRMC_CTRL_MASK		(0x3 << 28)
    228 #define CCM_CCGR7_SDHC1_CTRL_MASK		(0x3 << 4)
    229 #define CCM_CCGR7_USBC1_CTRL_MASK       (0x3 << 8)
    230 #define CCM_CCGR9_FEC0_CTRL_MASK		0x3
    231 #define CCM_CCGR9_FEC1_CTRL_MASK		(0x3 << 2)
    232 #define CCM_CCGR10_NFC_CTRL_MASK		0x3
    233 #define CCM_CCGR10_I2C2_CTRL_MASK		(0x3 << 12)
    234 #define CCM_CCGR10_I2C3_CTRL_MASK		(0x3 << 14)
    235 
    236 #define ANADIG_PLL7_CTRL_BYPASS         (1 << 16)
    237 #define ANADIG_PLL7_CTRL_ENABLE         (1 << 13)
    238 #define ANADIG_PLL7_CTRL_POWERDOWN      (1 << 12)
    239 #define ANADIG_PLL7_CTRL_DIV_SELECT     (1 << 1)
    240 #define ANADIG_PLL5_CTRL_BYPASS                 (1 << 16)
    241 #define ANADIG_PLL5_CTRL_ENABLE                 (1 << 13)
    242 #define ANADIG_PLL5_CTRL_POWERDOWN              (1 << 12)
    243 #define ANADIG_PLL5_CTRL_DIV_SELECT		1
    244 #define ANADIG_PLL3_CTRL_BYPASS         (1 << 16)
    245 #define ANADIG_PLL3_CTRL_ENABLE         (1 << 13)
    246 #define ANADIG_PLL3_CTRL_POWERDOWN      (1 << 12)
    247 #define ANADIG_PLL3_CTRL_DIV_SELECT     (1 << 1)
    248 #define ANADIG_PLL2_CTRL_ENABLE			(1 << 13)
    249 #define ANADIG_PLL2_CTRL_POWERDOWN		(1 << 12)
    250 #define ANADIG_PLL2_CTRL_DIV_SELECT		1
    251 #define ANADIG_PLL1_CTRL_ENABLE			(1 << 13)
    252 #define ANADIG_PLL1_CTRL_POWERDOWN		(1 << 12)
    253 #define ANADIG_PLL1_CTRL_DIV_SELECT		1
    254 
    255 #define FASE_CLK_FREQ		24000000
    256 #define SLOW_CLK_FREQ		32000
    257 #define PLL1_PFD1_FREQ		500000000
    258 #define PLL1_PFD2_FREQ		452000000
    259 #define PLL1_PFD3_FREQ		396000000
    260 #define PLL1_PFD4_FREQ		528000000
    261 #define PLL1_MAIN_FREQ		528000000
    262 #define PLL2_PFD1_FREQ		500000000
    263 #define PLL2_PFD2_FREQ		396000000
    264 #define PLL2_PFD3_FREQ		339000000
    265 #define PLL2_PFD4_FREQ		413000000
    266 #define PLL2_MAIN_FREQ		528000000
    267 #define PLL3_MAIN_FREQ		480000000
    268 #define PLL3_PFD3_FREQ		298000000
    269 #define PLL5_MAIN_FREQ		500000000
    270 
    271 #define ENET_EXTERNAL_CLK	50000000
    272 #define AUDIO_EXTERNAL_CLK	24576000
    273 
    274 #endif /*__ARCH_ARM_MACH_VF610_CCM_REGS_H__ */
    275