blob: 457515b0736affea133007c7962b5d557b030a4c [file] [log] [blame]
Andrew Davis856ec342023-04-11 13:25:02 -05001// SPDX-License-Identifier: GPL-2.0
Lokesh Vutla7f8bd532015-09-19 15:00:18 +05302/*
3 * Device Tree Source for Keystone 2 clock tree
4 *
Andrew Davis856ec342023-04-11 13:25:02 -05005 * Copyright (C) 2013-2017 Texas Instruments Incorporated - http://www.ti.com/
Lokesh Vutla7f8bd532015-09-19 15:00:18 +05306 */
7
8clocks {
9 #address-cells = <1>;
10 #size-cells = <1>;
11 ranges;
12
13 mainmuxclk: mainmuxclk@2310108 {
14 #clock-cells = <0>;
15 compatible = "ti,keystone,pll-mux-clock";
16 clocks = <&mainpllclk>, <&refclksys>;
17 reg = <0x02310108 4>;
18 bit-shift = <23>;
19 bit-mask = <1>;
20 clock-output-names = "mainmuxclk";
21 };
22
23 chipclk1: chipclk1 {
24 #clock-cells = <0>;
25 compatible = "fixed-factor-clock";
26 clocks = <&mainmuxclk>;
27 clock-div = <1>;
28 clock-mult = <1>;
29 clock-output-names = "chipclk1";
30 };
31
32 chipclk1rstiso: chipclk1rstiso {
33 #clock-cells = <0>;
34 compatible = "fixed-factor-clock";
35 clocks = <&mainmuxclk>;
36 clock-div = <1>;
37 clock-mult = <1>;
38 clock-output-names = "chipclk1rstiso";
39 };
40
41 gemtraceclk: gemtraceclk@2310120 {
42 #clock-cells = <0>;
43 compatible = "ti,keystone,pll-divider-clock";
44 clocks = <&mainmuxclk>;
45 reg = <0x02310120 4>;
46 bit-shift = <0>;
47 bit-mask = <8>;
48 clock-output-names = "gemtraceclk";
49 };
50
Andrew Davis33e399a2023-04-11 13:25:09 -050051 chipstmxptclk: chipstmxptclk@2310164 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +053052 #clock-cells = <0>;
53 compatible = "ti,keystone,pll-divider-clock";
54 clocks = <&mainmuxclk>;
55 reg = <0x02310164 4>;
56 bit-shift = <0>;
57 bit-mask = <8>;
58 clock-output-names = "chipstmxptclk";
59 };
60
61 chipclk12: chipclk12 {
62 #clock-cells = <0>;
63 compatible = "fixed-factor-clock";
64 clocks = <&chipclk1>;
65 clock-div = <2>;
66 clock-mult = <1>;
67 clock-output-names = "chipclk12";
68 };
69
70 chipclk13: chipclk13 {
71 #clock-cells = <0>;
72 compatible = "fixed-factor-clock";
73 clocks = <&chipclk1>;
74 clock-div = <3>;
75 clock-mult = <1>;
76 clock-output-names = "chipclk13";
77 };
78
79 paclk13: paclk13 {
80 #clock-cells = <0>;
81 compatible = "fixed-factor-clock";
82 clocks = <&papllclk>;
83 clock-div = <3>;
84 clock-mult = <1>;
85 clock-output-names = "paclk13";
86 };
87
88 chipclk14: chipclk14 {
89 #clock-cells = <0>;
90 compatible = "fixed-factor-clock";
91 clocks = <&chipclk1>;
92 clock-div = <4>;
93 clock-mult = <1>;
94 clock-output-names = "chipclk14";
95 };
96
97 chipclk16: chipclk16 {
98 #clock-cells = <0>;
99 compatible = "fixed-factor-clock";
100 clocks = <&chipclk1>;
101 clock-div = <6>;
102 clock-mult = <1>;
103 clock-output-names = "chipclk16";
104 };
105
106 chipclk112: chipclk112 {
107 #clock-cells = <0>;
108 compatible = "fixed-factor-clock";
109 clocks = <&chipclk1>;
110 clock-div = <12>;
111 clock-mult = <1>;
112 clock-output-names = "chipclk112";
113 };
114
115 chipclk124: chipclk124 {
116 #clock-cells = <0>;
117 compatible = "fixed-factor-clock";
118 clocks = <&chipclk1>;
119 clock-div = <24>;
120 clock-mult = <1>;
121 clock-output-names = "chipclk114";
122 };
123
124 chipclk1rstiso13: chipclk1rstiso13 {
125 #clock-cells = <0>;
126 compatible = "fixed-factor-clock";
127 clocks = <&chipclk1rstiso>;
128 clock-div = <3>;
129 clock-mult = <1>;
130 clock-output-names = "chipclk1rstiso13";
131 };
132
133 chipclk1rstiso14: chipclk1rstiso14 {
134 #clock-cells = <0>;
135 compatible = "fixed-factor-clock";
136 clocks = <&chipclk1rstiso>;
137 clock-div = <4>;
138 clock-mult = <1>;
139 clock-output-names = "chipclk1rstiso14";
140 };
141
142 chipclk1rstiso16: chipclk1rstiso16 {
143 #clock-cells = <0>;
144 compatible = "fixed-factor-clock";
145 clocks = <&chipclk1rstiso>;
146 clock-div = <6>;
147 clock-mult = <1>;
148 clock-output-names = "chipclk1rstiso16";
149 };
150
151 chipclk1rstiso112: chipclk1rstiso112 {
152 #clock-cells = <0>;
153 compatible = "fixed-factor-clock";
154 clocks = <&chipclk1rstiso>;
155 clock-div = <12>;
156 clock-mult = <1>;
157 clock-output-names = "chipclk1rstiso112";
158 };
159
Andrew Davis33e399a2023-04-11 13:25:09 -0500160 clkmodrst0: clkmodrst0@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530161 #clock-cells = <0>;
162 compatible = "ti,keystone,psc-clock";
163 clocks = <&chipclk16>;
164 clock-output-names = "modrst0";
165 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
166 reg-names = "control", "domain";
167 domain-id = <0>;
168 };
169
170
Andrew Davis33e399a2023-04-11 13:25:09 -0500171 clkusb: clkusb@2350008 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530172 #clock-cells = <0>;
173 compatible = "ti,keystone,psc-clock";
174 clocks = <&chipclk16>;
175 clock-output-names = "usb";
176 reg = <0x02350008 0xb00>, <0x02350000 0x400>;
177 reg-names = "control", "domain";
178 domain-id = <0>;
179 };
180
Andrew Davis33e399a2023-04-11 13:25:09 -0500181 clkaemifspi: clkaemifspi@235000c {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530182 #clock-cells = <0>;
183 compatible = "ti,keystone,psc-clock";
184 clocks = <&chipclk16>;
185 clock-output-names = "aemif-spi";
186 reg = <0x0235000c 0xb00>, <0x02350000 0x400>;
187 reg-names = "control", "domain";
188 domain-id = <0>;
189 };
190
191
Andrew Davis33e399a2023-04-11 13:25:09 -0500192 clkdebugsstrc: clkdebugsstrc@2350014 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530193 #clock-cells = <0>;
194 compatible = "ti,keystone,psc-clock";
195 clocks = <&chipclk13>;
196 clock-output-names = "debugss-trc";
197 reg = <0x02350014 0xb00>, <0x02350000 0x400>;
198 reg-names = "control", "domain";
199 domain-id = <1>;
200 };
201
Andrew Davis33e399a2023-04-11 13:25:09 -0500202 clktetbtrc: clktetbtrc@2350018 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530203 #clock-cells = <0>;
204 compatible = "ti,keystone,psc-clock";
205 clocks = <&chipclk13>;
206 clock-output-names = "tetb-trc";
207 reg = <0x02350018 0xb00>, <0x02350004 0x400>;
208 reg-names = "control", "domain";
209 domain-id = <1>;
210 };
211
Andrew Davis33e399a2023-04-11 13:25:09 -0500212 clkpa: clkpa@235001c {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530213 #clock-cells = <0>;
214 compatible = "ti,keystone,psc-clock";
215 clocks = <&paclk13>;
216 clock-output-names = "pa";
217 reg = <0x0235001c 0xb00>, <0x02350008 0x400>;
218 reg-names = "control", "domain";
219 domain-id = <2>;
220 };
221
Andrew Davis33e399a2023-04-11 13:25:09 -0500222 clkcpgmac: clkcpgmac@2350020 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530223 #clock-cells = <0>;
224 compatible = "ti,keystone,psc-clock";
225 clocks = <&clkpa>;
226 clock-output-names = "cpgmac";
227 reg = <0x02350020 0xb00>, <0x02350008 0x400>;
228 reg-names = "control", "domain";
229 domain-id = <2>;
230 };
231
Andrew Davis33e399a2023-04-11 13:25:09 -0500232 clksa: clksa@2350024 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530233 #clock-cells = <0>;
234 compatible = "ti,keystone,psc-clock";
235 clocks = <&clkpa>;
236 clock-output-names = "sa";
237 reg = <0x02350024 0xb00>, <0x02350008 0x400>;
238 reg-names = "control", "domain";
239 domain-id = <2>;
240 };
241
Andrew Davis33e399a2023-04-11 13:25:09 -0500242 clkpcie: clkpcie@2350028 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530243 #clock-cells = <0>;
244 compatible = "ti,keystone,psc-clock";
245 clocks = <&chipclk12>;
246 clock-output-names = "pcie";
247 reg = <0x02350028 0xb00>, <0x0235000c 0x400>;
248 reg-names = "control", "domain";
249 domain-id = <3>;
250 };
251
Andrew Davis33e399a2023-04-11 13:25:09 -0500252 clksr: clksr@2350034 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530253 #clock-cells = <0>;
254 compatible = "ti,keystone,psc-clock";
255 clocks = <&chipclk1rstiso112>;
256 clock-output-names = "sr";
257 reg = <0x02350034 0xb00>, <0x02350018 0x400>;
258 reg-names = "control", "domain";
259 domain-id = <6>;
260 };
261
Andrew Davis33e399a2023-04-11 13:25:09 -0500262 clkgem0: clkgem0@235003c {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530263 #clock-cells = <0>;
264 compatible = "ti,keystone,psc-clock";
265 clocks = <&chipclk1>;
266 clock-output-names = "gem0";
267 reg = <0x0235003c 0xb00>, <0x02350020 0x400>;
268 reg-names = "control", "domain";
269 domain-id = <8>;
270 };
271
Andrew Davis33e399a2023-04-11 13:25:09 -0500272 clkddr30: clkddr30@235005c {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530273 #clock-cells = <0>;
274 compatible = "ti,keystone,psc-clock";
275 clocks = <&chipclk12>;
276 clock-output-names = "ddr3-0";
277 reg = <0x0235005c 0xb00>, <0x02350040 0x400>;
278 reg-names = "control", "domain";
279 domain-id = <16>;
280 };
281
Andrew Davis33e399a2023-04-11 13:25:09 -0500282 clkwdtimer0: clkwdtimer0@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530283 #clock-cells = <0>;
284 compatible = "ti,keystone,psc-clock";
285 clocks = <&clkmodrst0>;
286 clock-output-names = "timer0";
287 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
288 reg-names = "control", "domain";
289 domain-id = <0>;
290 };
291
Andrew Davis33e399a2023-04-11 13:25:09 -0500292 clkwdtimer1: clkwdtimer1@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530293 #clock-cells = <0>;
294 compatible = "ti,keystone,psc-clock";
295 clocks = <&clkmodrst0>;
296 clock-output-names = "timer1";
297 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
298 reg-names = "control", "domain";
299 domain-id = <0>;
300 };
301
Andrew Davis33e399a2023-04-11 13:25:09 -0500302 clkwdtimer2: clkwdtimer2@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530303 #clock-cells = <0>;
304 compatible = "ti,keystone,psc-clock";
305 clocks = <&clkmodrst0>;
306 clock-output-names = "timer2";
307 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
308 reg-names = "control", "domain";
309 domain-id = <0>;
310 };
311
Andrew Davis33e399a2023-04-11 13:25:09 -0500312 clkwdtimer3: clkwdtimer3@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530313 #clock-cells = <0>;
314 compatible = "ti,keystone,psc-clock";
315 clocks = <&clkmodrst0>;
316 clock-output-names = "timer3";
317 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
318 reg-names = "control", "domain";
319 domain-id = <0>;
320 };
321
Andrew Davis33e399a2023-04-11 13:25:09 -0500322 clktimer15: clktimer15@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530323 #clock-cells = <0>;
324 compatible = "ti,keystone,psc-clock";
325 clocks = <&clkmodrst0>;
326 clock-output-names = "timer15";
327 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
328 reg-names = "control", "domain";
329 domain-id = <0>;
330 };
331
Andrew Davis33e399a2023-04-11 13:25:09 -0500332 clkuart0: clkuart0@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530333 #clock-cells = <0>;
334 compatible = "ti,keystone,psc-clock";
335 clocks = <&clkmodrst0>;
336 clock-output-names = "uart0";
337 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
338 reg-names = "control", "domain";
339 domain-id = <0>;
340 };
341
Andrew Davis33e399a2023-04-11 13:25:09 -0500342 clkuart1: clkuart1@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530343 #clock-cells = <0>;
344 compatible = "ti,keystone,psc-clock";
345 clocks = <&clkmodrst0>;
346 clock-output-names = "uart1";
347 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
348 reg-names = "control", "domain";
349 domain-id = <0>;
350 };
351
Andrew Davis33e399a2023-04-11 13:25:09 -0500352 clkaemif: clkaemif@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530353 #clock-cells = <0>;
354 compatible = "ti,keystone,psc-clock";
355 clocks = <&clkaemifspi>;
356 clock-output-names = "aemif";
357 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
358 reg-names = "control", "domain";
359 domain-id = <0>;
360 };
361
Andrew Davis33e399a2023-04-11 13:25:09 -0500362 clkusim: clkusim@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530363 #clock-cells = <0>;
364 compatible = "ti,keystone,psc-clock";
365 clocks = <&clkmodrst0>;
366 clock-output-names = "usim";
367 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
368 reg-names = "control", "domain";
369 domain-id = <0>;
370 };
371
Andrew Davis33e399a2023-04-11 13:25:09 -0500372 clki2c: clki2c@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530373 #clock-cells = <0>;
374 compatible = "ti,keystone,psc-clock";
375 clocks = <&clkmodrst0>;
376 clock-output-names = "i2c";
377 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
378 reg-names = "control", "domain";
379 domain-id = <0>;
380 };
381
Andrew Davis33e399a2023-04-11 13:25:09 -0500382 clkspi: clkspi@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530383 #clock-cells = <0>;
384 compatible = "ti,keystone,psc-clock";
385 clocks = <&clkaemifspi>;
386 clock-output-names = "spi";
387 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
388 reg-names = "control", "domain";
389 domain-id = <0>;
390 };
391
Andrew Davis33e399a2023-04-11 13:25:09 -0500392 clkgpio: clkgpio@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530393 #clock-cells = <0>;
394 compatible = "ti,keystone,psc-clock";
395 clocks = <&clkmodrst0>;
396 clock-output-names = "gpio";
397 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
398 reg-names = "control", "domain";
399 domain-id = <0>;
400 };
401
Andrew Davis33e399a2023-04-11 13:25:09 -0500402 clkkeymgr: clkkeymgr@2350000 {
Lokesh Vutla7f8bd532015-09-19 15:00:18 +0530403 #clock-cells = <0>;
404 compatible = "ti,keystone,psc-clock";
405 clocks = <&clkmodrst0>;
406 clock-output-names = "keymgr";
407 reg = <0x02350000 0xb00>, <0x02350000 0x400>;
408 reg-names = "control", "domain";
409 domain-id = <0>;
410 };
411};