1 /*
2  * Copyright 2013 Ideas On Board SPRL
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License as published by
6  * the Free Software Foundation; either version 2 of the License, or
7  * (at your option) any later version.
8  */
9 
10 #ifndef __DT_BINDINGS_CLOCK_R8A7791_H__
11 #define __DT_BINDINGS_CLOCK_R8A7791_H__
12 
13 /* CPG */
14 #define R8A7791_CLK_MAIN		0
15 #define R8A7791_CLK_PLL0		1
16 #define R8A7791_CLK_PLL1		2
17 #define R8A7791_CLK_PLL3		3
18 #define R8A7791_CLK_LB			4
19 #define R8A7791_CLK_QSPI		5
20 #define R8A7791_CLK_SDH			6
21 #define R8A7791_CLK_SD0			7
22 #define R8A7791_CLK_Z			8
23 #define R8A7791_CLK_RCAN		9
24 #define R8A7791_CLK_ADSP		10
25 
26 /* MSTP0 */
27 #define R8A7791_CLK_MSIOF0		0
28 
29 /* MSTP1 */
30 #define R8A7791_CLK_VCP0		1
31 #define R8A7791_CLK_VPC0		3
32 #define R8A7791_CLK_JPU			6
33 #define R8A7791_CLK_SSP1		9
34 #define R8A7791_CLK_TMU1		11
35 #define R8A7791_CLK_3DG			12
36 #define R8A7791_CLK_2DDMAC		15
37 #define R8A7791_CLK_FDP1_1		18
38 #define R8A7791_CLK_FDP1_0		19
39 #define R8A7791_CLK_TMU3		21
40 #define R8A7791_CLK_TMU2		22
41 #define R8A7791_CLK_CMT0		24
42 #define R8A7791_CLK_TMU0		25
43 #define R8A7791_CLK_VSP1_DU1		27
44 #define R8A7791_CLK_VSP1_DU0		28
45 #define R8A7791_CLK_VSP1_S		31
46 
47 /* MSTP2 */
48 #define R8A7791_CLK_SCIFA2		2
49 #define R8A7791_CLK_SCIFA1		3
50 #define R8A7791_CLK_SCIFA0		4
51 #define R8A7791_CLK_MSIOF2		5
52 #define R8A7791_CLK_SCIFB0		6
53 #define R8A7791_CLK_SCIFB1		7
54 #define R8A7791_CLK_MSIOF1		8
55 #define R8A7791_CLK_SCIFB2		16
56 #define R8A7791_CLK_SYS_DMAC1		18
57 #define R8A7791_CLK_SYS_DMAC0		19
58 
59 /* MSTP3 */
60 #define R8A7791_CLK_TPU0		4
61 #define R8A7791_CLK_SDHI2		11
62 #define R8A7791_CLK_SDHI1		12
63 #define R8A7791_CLK_SDHI0		14
64 #define R8A7791_CLK_MMCIF0		15
65 #define R8A7791_CLK_IIC0		18
66 #define R8A7791_CLK_PCIEC		19
67 #define R8A7791_CLK_IIC1		23
68 #define R8A7791_CLK_SSUSB		28
69 #define R8A7791_CLK_CMT1		29
70 #define R8A7791_CLK_USBDMAC0		30
71 #define R8A7791_CLK_USBDMAC1		31
72 
73 /* MSTP4 */
74 #define R8A7791_CLK_IRQC		7
75 
76 /* MSTP5 */
77 #define R8A7791_CLK_AUDIO_DMAC1		1
78 #define R8A7791_CLK_AUDIO_DMAC0		2
79 #define R8A7791_CLK_ADSP_MOD		6
80 #define R8A7791_CLK_THERMAL		22
81 #define R8A7791_CLK_PWM			23
82 
83 /* MSTP7 */
84 #define R8A7791_CLK_EHCI		3
85 #define R8A7791_CLK_HSUSB		4
86 #define R8A7791_CLK_HSCIF2		13
87 #define R8A7791_CLK_SCIF5		14
88 #define R8A7791_CLK_SCIF4		15
89 #define R8A7791_CLK_HSCIF1		16
90 #define R8A7791_CLK_HSCIF0		17
91 #define R8A7791_CLK_SCIF3		18
92 #define R8A7791_CLK_SCIF2		19
93 #define R8A7791_CLK_SCIF1		20
94 #define R8A7791_CLK_SCIF0		21
95 #define R8A7791_CLK_DU1			23
96 #define R8A7791_CLK_DU0			24
97 #define R8A7791_CLK_LVDS0		26
98 
99 /* MSTP8 */
100 #define R8A7791_CLK_IPMMU_SGX		0
101 #define R8A7791_CLK_MLB			2
102 #define R8A7791_CLK_VIN2		9
103 #define R8A7791_CLK_VIN1		10
104 #define R8A7791_CLK_VIN0		11
105 #define R8A7791_CLK_ETHERAVB		12
106 #define R8A7791_CLK_ETHER		13
107 #define R8A7791_CLK_SATA1		14
108 #define R8A7791_CLK_SATA0		15
109 
110 /* MSTP9 */
111 #define R8A7791_CLK_GPIO7		4
112 #define R8A7791_CLK_GPIO6		5
113 #define R8A7791_CLK_GPIO5		7
114 #define R8A7791_CLK_GPIO4		8
115 #define R8A7791_CLK_GPIO3		9
116 #define R8A7791_CLK_GPIO2		10
117 #define R8A7791_CLK_GPIO1		11
118 #define R8A7791_CLK_GPIO0		12
119 #define R8A7791_CLK_RCAN1		15
120 #define R8A7791_CLK_RCAN0		16
121 #define R8A7791_CLK_QSPI_MOD		17
122 #define R8A7791_CLK_I2C5		25
123 #define R8A7791_CLK_IICDVFS		26
124 #define R8A7791_CLK_I2C4		27
125 #define R8A7791_CLK_I2C3		28
126 #define R8A7791_CLK_I2C2		29
127 #define R8A7791_CLK_I2C1		30
128 #define R8A7791_CLK_I2C0		31
129 
130 /* MSTP10 */
131 #define R8A7791_CLK_SSI_ALL		5
132 #define R8A7791_CLK_SSI9		6
133 #define R8A7791_CLK_SSI8		7
134 #define R8A7791_CLK_SSI7		8
135 #define R8A7791_CLK_SSI6		9
136 #define R8A7791_CLK_SSI5		10
137 #define R8A7791_CLK_SSI4		11
138 #define R8A7791_CLK_SSI3		12
139 #define R8A7791_CLK_SSI2		13
140 #define R8A7791_CLK_SSI1		14
141 #define R8A7791_CLK_SSI0		15
142 #define R8A7791_CLK_SCU_ALL		17
143 #define R8A7791_CLK_SCU_DVC1		18
144 #define R8A7791_CLK_SCU_DVC0		19
145 #define R8A7791_CLK_SCU_CTU1_MIX1	20
146 #define R8A7791_CLK_SCU_CTU0_MIX0	21
147 #define R8A7791_CLK_SCU_SRC9		22
148 #define R8A7791_CLK_SCU_SRC8		23
149 #define R8A7791_CLK_SCU_SRC7		24
150 #define R8A7791_CLK_SCU_SRC6		25
151 #define R8A7791_CLK_SCU_SRC5		26
152 #define R8A7791_CLK_SCU_SRC4		27
153 #define R8A7791_CLK_SCU_SRC3		28
154 #define R8A7791_CLK_SCU_SRC2		29
155 #define R8A7791_CLK_SCU_SRC1		30
156 #define R8A7791_CLK_SCU_SRC0		31
157 
158 /* MSTP11 */
159 #define R8A7791_CLK_SCIFA3		6
160 #define R8A7791_CLK_SCIFA4		7
161 #define R8A7791_CLK_SCIFA5		8
162 
163 #endif /* __DT_BINDINGS_CLOCK_R8A7791_H__ */
164