xref: /openbmc/u-boot/arch/arm/include/asm/arch-vf610/crm_regs.h (revision 83d290c56fab2d38cd1ab4c4cc7099559c1d5046)
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