blob: d7b6c83ea63f1883e09aa8424d23667ee79e9832 [file] [log] [blame]
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +02001/*
2 * Copyright (c) 2014 MundoReader S.L.
3 * Author: Heiko Stuebner <heiko@sntech.de>
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 */
15
Heiko Stuebner7c8f03d2015-07-05 11:00:19 +020016#ifndef _DT_BINDINGS_CLK_ROCKCHIP_RK3288_H
17#define _DT_BINDINGS_CLK_ROCKCHIP_RK3288_H
18
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +020019/* core clocks */
20#define PLL_APLL 1
21#define PLL_DPLL 2
22#define PLL_CPLL 3
23#define PLL_GPLL 4
24#define PLL_NPLL 5
Heiko Stuebner4d742e62014-09-05 11:28:12 +020025#define ARMCLK 6
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +020026
27/* sclk gates (special clocks) */
28#define SCLK_GPU 64
29#define SCLK_SPI0 65
30#define SCLK_SPI1 66
31#define SCLK_SPI2 67
32#define SCLK_SDMMC 68
33#define SCLK_SDIO0 69
34#define SCLK_SDIO1 70
35#define SCLK_EMMC 71
36#define SCLK_TSADC 72
37#define SCLK_SARADC 73
38#define SCLK_PS2C 74
39#define SCLK_NANDC0 75
40#define SCLK_NANDC1 76
41#define SCLK_UART0 77
42#define SCLK_UART1 78
43#define SCLK_UART2 79
44#define SCLK_UART3 80
45#define SCLK_UART4 81
46#define SCLK_I2S0 82
47#define SCLK_SPDIF 83
48#define SCLK_SPDIF8CH 84
49#define SCLK_TIMER0 85
50#define SCLK_TIMER1 86
51#define SCLK_TIMER2 87
52#define SCLK_TIMER3 88
53#define SCLK_TIMER4 89
54#define SCLK_TIMER5 90
55#define SCLK_TIMER6 91
56#define SCLK_HSADC 92
57#define SCLK_OTGPHY0 93
58#define SCLK_OTGPHY1 94
59#define SCLK_OTGPHY2 95
60#define SCLK_OTG_ADP 96
61#define SCLK_HSICPHY480M 97
62#define SCLK_HSICPHY12M 98
63#define SCLK_MACREF 99
64#define SCLK_LCDC_PWM0 100
65#define SCLK_LCDC_PWM1 101
66#define SCLK_MAC_RX 102
67#define SCLK_MAC_TX 103
Kever Yang5e9a3d72014-09-24 21:36:34 +080068#define SCLK_EDP_24M 104
69#define SCLK_EDP 105
70#define SCLK_RGA 106
71#define SCLK_ISP 107
72#define SCLK_ISP_JPE 108
73#define SCLK_HDMI_HDCP 109
74#define SCLK_HDMI_CEC 110
75#define SCLK_HEVC_CABAC 111
76#define SCLK_HEVC_CORE 112
Sonny Rao6d288b12014-11-18 23:15:19 -080077#define SCLK_I2S0_OUT 113
Alexandru M Stanc1c9f2c2014-11-26 17:30:26 -080078#define SCLK_SDMMC_DRV 114
79#define SCLK_SDIO0_DRV 115
80#define SCLK_SDIO1_DRV 116
81#define SCLK_EMMC_DRV 117
82#define SCLK_SDMMC_SAMPLE 118
83#define SCLK_SDIO0_SAMPLE 119
84#define SCLK_SDIO1_SAMPLE 120
85#define SCLK_EMMC_SAMPLE 121
Kever Yang19ce8282014-11-13 15:22:36 +080086#define SCLK_USBPHY480M_SRC 122
Huang Lin19da34b2014-12-18 16:13:45 -080087#define SCLK_PVTM_CORE 123
88#define SCLK_PVTM_GPU 124
Zain Wang94d5d6a2015-11-17 12:00:45 +080089#define SCLK_CRYPTO 125
Chris Zhongc6d49fb2015-11-26 15:50:15 +080090#define SCLK_MIPIDSI_24M 126
Jacob Chendb86dad2017-01-18 13:42:38 +080091#define SCLK_VIP_OUT 127
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +020092
Roger Chen3cf8e532014-12-29 17:43:55 +080093#define SCLK_MAC 151
94#define SCLK_MACREF_OUT 152
95
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +020096#define DCLK_VOP0 190
97#define DCLK_VOP1 191
98
99/* aclk gates */
100#define ACLK_GPU 192
101#define ACLK_DMAC1 193
102#define ACLK_DMAC2 194
103#define ACLK_MMU 195
104#define ACLK_GMAC 196
105#define ACLK_VOP0 197
106#define ACLK_VOP1 198
107#define ACLK_CRYPTO 199
108#define ACLK_RGA 200
Kever Yang5e9a3d72014-09-24 21:36:34 +0800109#define ACLK_RGA_NIU 201
110#define ACLK_IEP 202
111#define ACLK_VIO0_NIU 203
112#define ACLK_VIP 204
113#define ACLK_ISP 205
114#define ACLK_VIO1_NIU 206
115#define ACLK_HEVC 207
116#define ACLK_VCODEC 208
117#define ACLK_CPU 209
118#define ACLK_PERI 210
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +0200119
120/* pclk gates */
121#define PCLK_GPIO0 320
122#define PCLK_GPIO1 321
123#define PCLK_GPIO2 322
124#define PCLK_GPIO3 323
125#define PCLK_GPIO4 324
126#define PCLK_GPIO5 325
127#define PCLK_GPIO6 326
128#define PCLK_GPIO7 327
129#define PCLK_GPIO8 328
130#define PCLK_GRF 329
131#define PCLK_SGRF 330
132#define PCLK_PMU 331
133#define PCLK_I2C0 332
134#define PCLK_I2C1 333
135#define PCLK_I2C2 334
136#define PCLK_I2C3 335
137#define PCLK_I2C4 336
138#define PCLK_I2C5 337
139#define PCLK_SPI0 338
140#define PCLK_SPI1 339
141#define PCLK_SPI2 340
142#define PCLK_UART0 341
143#define PCLK_UART1 342
144#define PCLK_UART2 343
145#define PCLK_UART3 344
146#define PCLK_UART4 345
147#define PCLK_TSADC 346
148#define PCLK_SARADC 347
149#define PCLK_SIM 348
150#define PCLK_GMAC 349
151#define PCLK_PWM 350
152#define PCLK_RKPWM 351
153#define PCLK_PS2C 352
154#define PCLK_TIMER 353
155#define PCLK_TZPC 354
Kever Yang5e9a3d72014-09-24 21:36:34 +0800156#define PCLK_EDP_CTRL 355
157#define PCLK_MIPI_DSI0 356
158#define PCLK_MIPI_DSI1 357
159#define PCLK_MIPI_CSI 358
160#define PCLK_LVDS_PHY 359
161#define PCLK_HDMI_CTRL 360
162#define PCLK_VIO2_H2P 361
163#define PCLK_CPU 362
164#define PCLK_PERI 363
Jeff Chen1ae2b012014-11-25 16:13:02 -0800165#define PCLK_DDRUPCTL0 364
166#define PCLK_PUBL0 365
167#define PCLK_DDRUPCTL1 366
168#define PCLK_PUBL1 367
Heiko Stuebnerb82465c2015-01-20 21:05:51 +0100169#define PCLK_WDT 368
ZhengShunQianb457c1e2015-08-11 18:13:40 +0800170#define PCLK_EFUSE256 369
171#define PCLK_EFUSE1024 370
Jacob Chen65476532017-01-10 19:59:17 +0800172#define PCLK_ISP_IN 371
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +0200173
174/* hclk gates */
175#define HCLK_GPS 448
176#define HCLK_OTG0 449
177#define HCLK_USBHOST0 450
178#define HCLK_USBHOST1 451
179#define HCLK_HSIC 452
180#define HCLK_NANDC0 453
181#define HCLK_NANDC1 454
182#define HCLK_TSP 455
183#define HCLK_SDMMC 456
184#define HCLK_SDIO0 457
185#define HCLK_SDIO1 458
186#define HCLK_EMMC 459
187#define HCLK_HSADC 460
188#define HCLK_CRYPTO 461
189#define HCLK_I2S0 462
190#define HCLK_SPDIF 463
191#define HCLK_SPDIF8CH 464
192#define HCLK_VOP0 465
193#define HCLK_VOP1 466
194#define HCLK_ROM 467
195#define HCLK_IEP 468
196#define HCLK_ISP 469
197#define HCLK_RGA 470
Kever Yang5e9a3d72014-09-24 21:36:34 +0800198#define HCLK_VIO_AHB_ARBI 471
199#define HCLK_VIO_NIU 472
200#define HCLK_VIP 473
201#define HCLK_VIO2_H2P 474
202#define HCLK_HEVC 475
203#define HCLK_VCODEC 476
204#define HCLK_CPU 477
205#define HCLK_PERI 478
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +0200206
Kever Yang5e9a3d72014-09-24 21:36:34 +0800207#define CLK_NR_CLKS (HCLK_PERI + 1)
Heiko Stübnerb9e4ba52014-07-03 02:02:37 +0200208
209/* soft-reset indices */
210#define SRST_CORE0 0
211#define SRST_CORE1 1
212#define SRST_CORE2 2
213#define SRST_CORE3 3
214#define SRST_CORE0_PO 4
215#define SRST_CORE1_PO 5
216#define SRST_CORE2_PO 6
217#define SRST_CORE3_PO 7
218#define SRST_PDCORE_STRSYS 8
219#define SRST_PDBUS_STRSYS 9
220#define SRST_L2C 10
221#define SRST_TOPDBG 11
222#define SRST_CORE0_DBG 12
223#define SRST_CORE1_DBG 13
224#define SRST_CORE2_DBG 14
225#define SRST_CORE3_DBG 15
226
227#define SRST_PDBUG_AHB_ARBITOR 16
228#define SRST_EFUSE256 17
229#define SRST_DMAC1 18
230#define SRST_INTMEM 19
231#define SRST_ROM 20
232#define SRST_SPDIF8CH 21
233#define SRST_TIMER 22
234#define SRST_I2S0 23
235#define SRST_SPDIF 24
236#define SRST_TIMER0 25
237#define SRST_TIMER1 26
238#define SRST_TIMER2 27
239#define SRST_TIMER3 28
240#define SRST_TIMER4 29
241#define SRST_TIMER5 30
242#define SRST_EFUSE 31
243
244#define SRST_GPIO0 32
245#define SRST_GPIO1 33
246#define SRST_GPIO2 34
247#define SRST_GPIO3 35
248#define SRST_GPIO4 36
249#define SRST_GPIO5 37
250#define SRST_GPIO6 38
251#define SRST_GPIO7 39
252#define SRST_GPIO8 40
253#define SRST_I2C0 42
254#define SRST_I2C1 43
255#define SRST_I2C2 44
256#define SRST_I2C3 45
257#define SRST_I2C4 46
258#define SRST_I2C5 47
259
260#define SRST_DWPWM 48
261#define SRST_MMC_PERI 49
262#define SRST_PERIPH_MMU 50
263#define SRST_DAP 51
264#define SRST_DAP_SYS 52
265#define SRST_TPIU 53
266#define SRST_PMU_APB 54
267#define SRST_GRF 55
268#define SRST_PMU 56
269#define SRST_PERIPH_AXI 57
270#define SRST_PERIPH_AHB 58
271#define SRST_PERIPH_APB 59
272#define SRST_PERIPH_NIU 60
273#define SRST_PDPERI_AHB_ARBI 61
274#define SRST_EMEM 62
275#define SRST_USB_PERI 63
276
277#define SRST_DMAC2 64
278#define SRST_MAC 66
279#define SRST_GPS 67
280#define SRST_RKPWM 69
281#define SRST_CCP 71
282#define SRST_USBHOST0 72
283#define SRST_HSIC 73
284#define SRST_HSIC_AUX 74
285#define SRST_HSIC_PHY 75
286#define SRST_HSADC 76
287#define SRST_NANDC0 77
288#define SRST_NANDC1 78
289
290#define SRST_TZPC 80
291#define SRST_SPI0 83
292#define SRST_SPI1 84
293#define SRST_SPI2 85
294#define SRST_SARADC 87
295#define SRST_PDALIVE_NIU 88
296#define SRST_PDPMU_INTMEM 89
297#define SRST_PDPMU_NIU 90
298#define SRST_SGRF 91
299
300#define SRST_VIO_ARBI 96
301#define SRST_RGA_NIU 97
302#define SRST_VIO0_NIU_AXI 98
303#define SRST_VIO_NIU_AHB 99
304#define SRST_LCDC0_AXI 100
305#define SRST_LCDC0_AHB 101
306#define SRST_LCDC0_DCLK 102
307#define SRST_VIO1_NIU_AXI 103
308#define SRST_VIP 104
309#define SRST_RGA_CORE 105
310#define SRST_IEP_AXI 106
311#define SRST_IEP_AHB 107
312#define SRST_RGA_AXI 108
313#define SRST_RGA_AHB 109
314#define SRST_ISP 110
315#define SRST_EDP 111
316
317#define SRST_VCODEC_AXI 112
318#define SRST_VCODEC_AHB 113
319#define SRST_VIO_H2P 114
320#define SRST_MIPIDSI0 115
321#define SRST_MIPIDSI1 116
322#define SRST_MIPICSI 117
323#define SRST_LVDS_PHY 118
324#define SRST_LVDS_CON 119
325#define SRST_GPU 120
326#define SRST_HDMI 121
327#define SRST_CORE_PVTM 124
328#define SRST_GPU_PVTM 125
329
330#define SRST_MMC0 128
331#define SRST_SDIO0 129
332#define SRST_SDIO1 130
333#define SRST_EMMC 131
334#define SRST_USBOTG_AHB 132
335#define SRST_USBOTG_PHY 133
336#define SRST_USBOTG_CON 134
337#define SRST_USBHOST0_AHB 135
338#define SRST_USBHOST0_PHY 136
339#define SRST_USBHOST0_CON 137
340#define SRST_USBHOST1_AHB 138
341#define SRST_USBHOST1_PHY 139
342#define SRST_USBHOST1_CON 140
343#define SRST_USB_ADP 141
344#define SRST_ACC_EFUSE 142
Mark yao4b47c3f2014-09-12 19:45:27 +0800345
346#define SRST_CORESIGHT 144
347#define SRST_PD_CORE_AHB_NOC 145
348#define SRST_PD_CORE_APB_NOC 146
349#define SRST_PD_CORE_MP_AXI 147
350#define SRST_GIC 148
351#define SRST_LCDC_PWM0 149
352#define SRST_LCDC_PWM1 150
353#define SRST_VIO0_H2P_BRG 151
354#define SRST_VIO1_H2P_BRG 152
355#define SRST_RGA_H2P_BRG 153
356#define SRST_HEVC 154
357#define SRST_TSADC 159
358
359#define SRST_DDRPHY0 160
360#define SRST_DDRPHY0_APB 161
361#define SRST_DDRCTRL0 162
362#define SRST_DDRCTRL0_APB 163
363#define SRST_DDRPHY0_CTRL 164
364#define SRST_DDRPHY1 165
365#define SRST_DDRPHY1_APB 166
366#define SRST_DDRCTRL1 167
367#define SRST_DDRCTRL1_APB 168
368#define SRST_DDRPHY1_CTRL 169
369#define SRST_DDRMSCH0 170
370#define SRST_DDRMSCH1 171
371#define SRST_CRYPTO 174
372#define SRST_C2C_HOST 175
373
374#define SRST_LCDC1_AXI 176
375#define SRST_LCDC1_AHB 177
376#define SRST_LCDC1_DCLK 178
377#define SRST_UART0 179
378#define SRST_UART1 180
379#define SRST_UART2 181
380#define SRST_UART3 182
381#define SRST_UART4 183
382#define SRST_SIMC 186
383#define SRST_PS2C 187
384#define SRST_TSP 188
385#define SRST_TSP_CLKIN0 189
386#define SRST_TSP_CLKIN1 190
387#define SRST_TSP_27M 191
Heiko Stuebner7c8f03d2015-07-05 11:00:19 +0200388
389#endif