xref: /freebsd/sys/arm64/freescale/imx/imx8mq_ccm.h (revision 29fc4075e69fd27de0cded313ac6000165d99f8b)
1 /*-
2  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3  *
4  * Copyright (c) 2020 Oleksandr Tymoshenko <gonzo@FreeBSD.org>
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  * 2. Redistributions in binary form must reproduce the above copyright
12  *    notice, this list of conditions and the following disclaimer in the
13  *    documentation and/or other materials provided with the distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25  * SUCH DAMAGE.
26  *
27  * $FreeBSD$
28  */
29 
30 #ifndef	__IMX8MQ_CCM_H__
31 #define	__IMX8MQ_CCM_H__
32 
33 #define	IMX8MQ_CLK_DUMMY	0
34 #define	IMX8MQ_CLK_32K		1
35 #define	IMX8MQ_CLK_25M		2
36 #define	IMX8MQ_CLK_27M		3
37 #define	IMX8MQ_CLK_EXT1		4
38 #define	IMX8MQ_CLK_EXT2		5
39 #define	IMX8MQ_CLK_EXT3		6
40 #define	IMX8MQ_CLK_EXT4		7
41 
42 #define	IMX8MQ_ARM_PLL_REF_SEL	8
43 #define	IMX8MQ_ARM_PLL_REF_DIV	9
44 #define	IMX8MQ_ARM_PLL		10
45 #define	IMX8MQ_ARM_PLL_BYPASS	11
46 #define	IMX8MQ_ARM_PLL_OUT	12
47 
48 #define	IMX8MQ_GPU_PLL_REF_SEL	13
49 #define	IMX8MQ_GPU_PLL_REF_DIV	14
50 #define	IMX8MQ_GPU_PLL		15
51 #define	IMX8MQ_GPU_PLL_BYPASS	16
52 #define	IMX8MQ_GPU_PLL_OUT	17
53 
54 #define	IMX8MQ_VPU_PLL_REF_SEL	18
55 #define	IMX8MQ_VPU_PLL_REF_DIV	19
56 #define	IMX8MQ_VPU_PLL		20
57 #define	IMX8MQ_VPU_PLL_BYPASS	21
58 #define	IMX8MQ_VPU_PLL_OUT	22
59 
60 #define	IMX8MQ_AUDIO_PLL1_REF_SEL	23
61 #define	IMX8MQ_AUDIO_PLL1_REF_DIV	24
62 #define	IMX8MQ_AUDIO_PLL1		25
63 #define	IMX8MQ_AUDIO_PLL1_BYPASS	26
64 #define	IMX8MQ_AUDIO_PLL1_OUT		27
65 
66 #define	IMX8MQ_AUDIO_PLL2_REF_SEL	28
67 #define	IMX8MQ_AUDIO_PLL2_REF_DIV	29
68 #define	IMX8MQ_AUDIO_PLL2		30
69 #define	IMX8MQ_AUDIO_PLL2_BYPASS	31
70 #define	IMX8MQ_AUDIO_PLL2_OUT		32
71 
72 #define	IMX8MQ_VIDEO_PLL1_REF_SEL	33
73 #define	IMX8MQ_VIDEO_PLL1_REF_DIV	34
74 #define	IMX8MQ_VIDEO_PLL1		35
75 #define	IMX8MQ_VIDEO_PLL1_BYPASS	36
76 #define	IMX8MQ_VIDEO_PLL1_OUT		37
77 
78 #define	IMX8MQ_SYS3_PLL1_REF_SEL	54
79 #define	IMX8MQ_SYS3_PLL1		56
80 
81 #define	IMX8MQ_DRAM_PLL1_REF_SEL	62
82 
83 #define	IMX8MQ_SYS1_PLL_40M	70
84 #define	IMX8MQ_SYS1_PLL_80M	71
85 #define	IMX8MQ_SYS1_PLL_100M	72
86 #define	IMX8MQ_SYS1_PLL_133M	73
87 #define	IMX8MQ_SYS1_PLL_160M	74
88 #define	IMX8MQ_SYS1_PLL_200M	75
89 #define	IMX8MQ_SYS1_PLL_266M	76
90 #define	IMX8MQ_SYS1_PLL_400M	77
91 #define	IMX8MQ_SYS1_PLL_800M	78
92 
93 #define	IMX8MQ_SYS2_PLL_50M	79
94 #define	IMX8MQ_SYS2_PLL_100M	80
95 #define	IMX8MQ_SYS2_PLL_125M	81
96 #define	IMX8MQ_SYS2_PLL_166M	82
97 #define	IMX8MQ_SYS2_PLL_200M	83
98 #define	IMX8MQ_SYS2_PLL_250M	84
99 #define	IMX8MQ_SYS2_PLL_333M	85
100 #define	IMX8MQ_SYS2_PLL_500M	86
101 #define	IMX8MQ_SYS2_PLL_1000M	87
102 
103 #define	IMX8MQ_CLK_ENET_AXI	104
104 #define	IMX8MQ_CLK_USB_BUS	110
105 
106 #define	IMX8MQ_CLK_AHB		116
107 
108 #define	IMX8MQ_CLK_ENET_REF	137
109 #define	IMX8MQ_CLK_ENET_TIMER	138
110 #define	IMX8MQ_CLK_ENET_PHY_REF	139
111 #define	IMX8MQ_CLK_USDHC1	142
112 #define	IMX8MQ_CLK_USDHC2	143
113 #define	IMX8MQ_CLK_I2C1		144
114 #define	IMX8MQ_CLK_I2C2		145
115 #define	IMX8MQ_CLK_I2C3		146
116 #define	IMX8MQ_CLK_I2C4		147
117 #define	IMX8MQ_CLK_UART1	148
118 #define	IMX8MQ_CLK_UART2	149
119 #define	IMX8MQ_CLK_UART3	150
120 #define	IMX8MQ_CLK_UART4	151
121 #define	IMX8MQ_CLK_USB_CORE_REF	152
122 #define	IMX8MQ_CLK_USB_PHY_REF	153
123 
124 #define	IMX8MQ_CLK_ENET1_ROOT		182
125 #define	IMX8MQ_CLK_I2C1_ROOT		184
126 #define	IMX8MQ_CLK_I2C2_ROOT		185
127 #define	IMX8MQ_CLK_I2C3_ROOT		186
128 #define	IMX8MQ_CLK_I2C4_ROOT		187
129 #define	IMX8MQ_CLK_UART1_ROOT		202
130 #define	IMX8MQ_CLK_UART2_ROOT		203
131 #define	IMX8MQ_CLK_UART3_ROOT		204
132 #define	IMX8MQ_CLK_UART4_ROOT		205
133 #define	IMX8MQ_CLK_USB1_CTRL_ROOT	206
134 #define	IMX8MQ_CLK_USB2_CTRL_ROOT	207
135 #define	IMX8MQ_CLK_USB1_PHY_ROOT	208
136 #define	IMX8MQ_CLK_USB2_PHY_ROOT	209
137 #define	IMX8MQ_CLK_USDHC1_ROOT		210
138 #define	IMX8MQ_CLK_USDHC2_ROOT		211
139 
140 #define	IMX8MQ_SYS1_PLL_OUT		231
141 #define	IMX8MQ_SYS2_PLL_OUT		232
142 #define	IMX8MQ_SYS3_PLL_OUT		233
143 
144 #define	IMX8MQ_CLK_IPG_ROOT		236
145 
146 #define	IMX8MQ_CLK_TMU_ROOT		246
147 
148 #define	IMX8MQ_CLK_GPIO1_ROOT		259
149 #define	IMX8MQ_CLK_GPIO2_ROOT		260
150 #define	IMX8MQ_CLK_GPIO3_ROOT		261
151 #define	IMX8MQ_CLK_GPIO4_ROOT		262
152 #define	IMX8MQ_CLK_GPIO5_ROOT		263
153 
154 #define	IMX8MQ_VIDEO2_PLL1_REF_SEL	266
155 
156 #define	IMX8MQ_SYS1_PLL_40M_CG		267
157 #define	IMX8MQ_SYS1_PLL_80M_CG		268
158 #define	IMX8MQ_SYS1_PLL_100M_CG		269
159 #define	IMX8MQ_SYS1_PLL_133M_CG		270
160 #define	IMX8MQ_SYS1_PLL_160M_CG		271
161 #define	IMX8MQ_SYS1_PLL_200M_CG		272
162 #define	IMX8MQ_SYS1_PLL_266M_CG		273
163 #define	IMX8MQ_SYS1_PLL_400M_CG		274
164 #define	IMX8MQ_SYS1_PLL_800M_CG		275
165 #define	IMX8MQ_SYS2_PLL_50M_CG		276
166 #define	IMX8MQ_SYS2_PLL_100M_CG		277
167 #define	IMX8MQ_SYS2_PLL_125M_CG		278
168 #define	IMX8MQ_SYS2_PLL_166M_CG		279
169 #define	IMX8MQ_SYS2_PLL_200M_CG		280
170 #define	IMX8MQ_SYS2_PLL_250M_CG		281
171 #define	IMX8MQ_SYS2_PLL_333M_CG		282
172 #define	IMX8MQ_SYS2_PLL_500M_CG		283
173 #define	IMX8MQ_SYS2_PLL_1000M_CG	284
174 
175 #endif
176