xref: /qemu/include/hw/misc/imx6_ccm.h (revision a66d815cd558193182b09fb23211f7ebf88d0661)
1*a66d815cSJean-Christophe Dubois /*
2*a66d815cSJean-Christophe Dubois  * IMX6 Clock Control Module
3*a66d815cSJean-Christophe Dubois  *
4*a66d815cSJean-Christophe Dubois  * Copyright (C) 2012 NICTA
5*a66d815cSJean-Christophe Dubois  * Updated by Jean-Christophe Dubois <jcd@tribudubois.net>
6*a66d815cSJean-Christophe Dubois  *
7*a66d815cSJean-Christophe Dubois  * This work is licensed under the terms of the GNU GPL, version 2 or later.
8*a66d815cSJean-Christophe Dubois  * See the COPYING file in the top-level directory.
9*a66d815cSJean-Christophe Dubois  */
10*a66d815cSJean-Christophe Dubois 
11*a66d815cSJean-Christophe Dubois #ifndef IMX6_CCM_H
12*a66d815cSJean-Christophe Dubois #define IMX6_CCM_H
13*a66d815cSJean-Christophe Dubois 
14*a66d815cSJean-Christophe Dubois #include "hw/misc/imx_ccm.h"
15*a66d815cSJean-Christophe Dubois #include "qemu/bitops.h"
16*a66d815cSJean-Christophe Dubois 
17*a66d815cSJean-Christophe Dubois #define CCM_CCR 0
18*a66d815cSJean-Christophe Dubois #define CCM_CCDR 1
19*a66d815cSJean-Christophe Dubois #define CCM_CSR 2
20*a66d815cSJean-Christophe Dubois #define CCM_CCSR 3
21*a66d815cSJean-Christophe Dubois #define CCM_CACRR 4
22*a66d815cSJean-Christophe Dubois #define CCM_CBCDR 5
23*a66d815cSJean-Christophe Dubois #define CCM_CBCMR 6
24*a66d815cSJean-Christophe Dubois #define CCM_CSCMR1 7
25*a66d815cSJean-Christophe Dubois #define CCM_CSCMR2 8
26*a66d815cSJean-Christophe Dubois #define CCM_CSCDR1 9
27*a66d815cSJean-Christophe Dubois #define CCM_CS1CDR 10
28*a66d815cSJean-Christophe Dubois #define CCM_CS2CDR 11
29*a66d815cSJean-Christophe Dubois #define CCM_CDCDR 12
30*a66d815cSJean-Christophe Dubois #define CCM_CHSCCDR 13
31*a66d815cSJean-Christophe Dubois #define CCM_CSCDR2 14
32*a66d815cSJean-Christophe Dubois #define CCM_CSCDR3 15
33*a66d815cSJean-Christophe Dubois #define CCM_CDHIPR 18
34*a66d815cSJean-Christophe Dubois #define CCM_CTOR 20
35*a66d815cSJean-Christophe Dubois #define CCM_CLPCR 21
36*a66d815cSJean-Christophe Dubois #define CCM_CISR 22
37*a66d815cSJean-Christophe Dubois #define CCM_CIMR 23
38*a66d815cSJean-Christophe Dubois #define CCM_CCOSR 24
39*a66d815cSJean-Christophe Dubois #define CCM_CGPR 25
40*a66d815cSJean-Christophe Dubois #define CCM_CCGR0 26
41*a66d815cSJean-Christophe Dubois #define CCM_CCGR1 27
42*a66d815cSJean-Christophe Dubois #define CCM_CCGR2 28
43*a66d815cSJean-Christophe Dubois #define CCM_CCGR3 29
44*a66d815cSJean-Christophe Dubois #define CCM_CCGR4 30
45*a66d815cSJean-Christophe Dubois #define CCM_CCGR5 31
46*a66d815cSJean-Christophe Dubois #define CCM_CCGR6 32
47*a66d815cSJean-Christophe Dubois #define CCM_CMEOR 34
48*a66d815cSJean-Christophe Dubois #define CCM_MAX 35
49*a66d815cSJean-Christophe Dubois 
50*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ARM 0
51*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ARM_SET 1
52*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ARM_CLR 2
53*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ARM_TOG 3
54*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB1 4
55*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB1_SET 5
56*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB1_CLR 6
57*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB1_TOG 7
58*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB2 8
59*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB2_SET 9
60*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB2_CLR 10
61*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_USB2_TOG 11
62*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS 12
63*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS_SET 13
64*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS_CLR 14
65*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS_TOG 15
66*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS_SS 16
67*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS_NUM 20
68*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_SYS_DENOM 24
69*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_AUDIO 28
70*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_AUDIO_SET 29
71*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_AUDIO_CLR 30
72*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_AUDIO_TOG 31
73*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_AUDIO_NUM 32
74*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_AUDIO_DENOM 36
75*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_VIDEO 40
76*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_VIDEO_SET 41
77*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_VIDEO_CLR 42
78*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_VIDEO_TOG 44
79*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_VIDEO_NUM 46
80*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_VIDEO_DENOM 48
81*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_MLB 52
82*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_MLB_SET 53
83*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_MLB_CLR 54
84*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_MLB_TOG 55
85*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ENET 56
86*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ENET_SET 57
87*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ENET_CLR 58
88*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_ENET_TOG 59
89*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_480 60
90*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_480_SET 61
91*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_480_CLR 62
92*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_480_TOG 63
93*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_528 64
94*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_528_SET 65
95*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_528_CLR 66
96*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PFD_528_TOG 67
97*a66d815cSJean-Christophe Dubois 
98*a66d815cSJean-Christophe Dubois /* PMU registers */
99*a66d815cSJean-Christophe Dubois #define PMU_REG_1P1 68
100*a66d815cSJean-Christophe Dubois #define PMU_REG_3P0 72
101*a66d815cSJean-Christophe Dubois #define PMU_REG_2P5 76
102*a66d815cSJean-Christophe Dubois #define PMU_REG_CORE 80
103*a66d815cSJean-Christophe Dubois 
104*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC0 84
105*a66d815cSJean-Christophe Dubois #define PMU_MISC0 84
106*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC0_SET 85
107*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC0_CLR 86
108*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC0_TOG 87
109*a66d815cSJean-Christophe Dubois 
110*a66d815cSJean-Christophe Dubois #define PMU_MISC1 88
111*a66d815cSJean-Christophe Dubois #define PMU_MISC1_SET 89
112*a66d815cSJean-Christophe Dubois #define PMU_MISC1_CLR 90
113*a66d815cSJean-Christophe Dubois #define PMU_MISC1_TOG 91
114*a66d815cSJean-Christophe Dubois 
115*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC2 92
116*a66d815cSJean-Christophe Dubois #define PMU_MISC2 92
117*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC2_SET 93
118*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC2_CLR 94
119*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MISC2_TOG 95
120*a66d815cSJean-Christophe Dubois 
121*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_VBUS_DETECT 104
122*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_VBUS_DETECT_SET 105
123*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_VBUS_DETECT_CLR 106
124*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_VBUS_DETECT_TOG 107
125*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_CHRG_DETECT 108
126*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_CHRG_DETECT_SET 109
127*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_CHRG_DETECT_CLR 110
128*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_CHRG_DETECT_TOG 111
129*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_VBUS_DETECT_STAT 112
130*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_CHRG_DETECT_STAT 116
131*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_MISC 124
132*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_MISC_SET 125
133*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_MISC_CLR 126
134*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB1_MISC_TOG 127
135*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_VBUS_DETECT 128
136*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_VBUS_DETECT_SET 129
137*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_VBUS_DETECT_CLR 130
138*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_VBUS_DETECT_TOG 131
139*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_CHRG_DETECT 132
140*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_CHRG_DETECT_SET 133
141*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_CHRG_DETECT_CLR 134
142*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_CHRG_DETECT_TOG 135
143*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_VBUS_DETECT_STAT 136
144*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_CHRG_DETECT_STAT 140
145*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_MISC 148
146*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_MISC_SET 149
147*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_MISC_CLR 150
148*a66d815cSJean-Christophe Dubois #define USB_ANALOG_USB2_MISC_TOG 151
149*a66d815cSJean-Christophe Dubois #define USB_ANALOG_DIGPROG 152
150*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_MAX 153
151*a66d815cSJean-Christophe Dubois 
152*a66d815cSJean-Christophe Dubois /* CCM_CBCMR */
153*a66d815cSJean-Christophe Dubois #define PRE_PERIPH_CLK_SEL_SHIFT  (18)
154*a66d815cSJean-Christophe Dubois #define PRE_PERIPH_CLK_SEL_LENGTH (2)
155*a66d815cSJean-Christophe Dubois 
156*a66d815cSJean-Christophe Dubois /* CCM_CBCDR */
157*a66d815cSJean-Christophe Dubois #define AHB_PODF_SHIFT           (10)
158*a66d815cSJean-Christophe Dubois #define AHB_PODF_LENGTH          (3)
159*a66d815cSJean-Christophe Dubois #define IPG_PODF_SHIFT           (8)
160*a66d815cSJean-Christophe Dubois #define IPG_PODF_LENGTH          (2)
161*a66d815cSJean-Christophe Dubois 
162*a66d815cSJean-Christophe Dubois /* CCM_CSCMR1 */
163*a66d815cSJean-Christophe Dubois #define PERCLK_PODF_SHIFT        (0)
164*a66d815cSJean-Christophe Dubois #define PERCLK_PODF_LENGTH       (6)
165*a66d815cSJean-Christophe Dubois 
166*a66d815cSJean-Christophe Dubois /* CCM_ANALOG_PFD_528 */
167*a66d815cSJean-Christophe Dubois #define PFD0_FRAC_SHIFT          (0)
168*a66d815cSJean-Christophe Dubois #define PFD0_FRAC_LENGTH         (6)
169*a66d815cSJean-Christophe Dubois #define PFD2_FRAC_SHIFT          (16)
170*a66d815cSJean-Christophe Dubois #define PFD2_FRAC_LENGTH         (6)
171*a66d815cSJean-Christophe Dubois 
172*a66d815cSJean-Christophe Dubois /* CCM_ANALOG_PLL_SYS */
173*a66d815cSJean-Christophe Dubois #define DIV_SELECT_SHIFT         (0)
174*a66d815cSJean-Christophe Dubois #define DIV_SELECT_LENGTH        (1)
175*a66d815cSJean-Christophe Dubois 
176*a66d815cSJean-Christophe Dubois #define CCM_ANALOG_PLL_LOCK      (1 << 31);
177*a66d815cSJean-Christophe Dubois 
178*a66d815cSJean-Christophe Dubois #define EXTRACT(value, name) extract32(value, name##_SHIFT, name##_LENGTH)
179*a66d815cSJean-Christophe Dubois 
180*a66d815cSJean-Christophe Dubois #define TYPE_IMX6_CCM "imx6.ccm"
181*a66d815cSJean-Christophe Dubois #define IMX6_CCM(obj) OBJECT_CHECK(IMX6CCMState, (obj), TYPE_IMX6_CCM)
182*a66d815cSJean-Christophe Dubois 
183*a66d815cSJean-Christophe Dubois typedef struct IMX6CCMState {
184*a66d815cSJean-Christophe Dubois     /* <private> */
185*a66d815cSJean-Christophe Dubois     IMXCCMState parent_obj;
186*a66d815cSJean-Christophe Dubois 
187*a66d815cSJean-Christophe Dubois     /* <public> */
188*a66d815cSJean-Christophe Dubois     MemoryRegion container;
189*a66d815cSJean-Christophe Dubois     MemoryRegion ioccm;
190*a66d815cSJean-Christophe Dubois     MemoryRegion ioanalog;
191*a66d815cSJean-Christophe Dubois 
192*a66d815cSJean-Christophe Dubois     uint32_t ccm[CCM_MAX];
193*a66d815cSJean-Christophe Dubois     uint32_t analog[CCM_ANALOG_MAX];
194*a66d815cSJean-Christophe Dubois 
195*a66d815cSJean-Christophe Dubois } IMX6CCMState;
196*a66d815cSJean-Christophe Dubois 
197*a66d815cSJean-Christophe Dubois #endif /* IMX6_CCM_H */
198