Loading...
Note: File does not exist in v4.6.
1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright (C) 2016 Freescale Semiconductor, Inc.
4 * Copyright 2017-2018 NXP
5 * Dong Aisheng <aisheng.dong@nxp.com>
6 */
7
8#include <dt-bindings/clock/imx7ulp-clock.h>
9#include <dt-bindings/gpio/gpio.h>
10#include <dt-bindings/interrupt-controller/arm-gic.h>
11
12#include "imx7ulp-pinfunc.h"
13
14/ {
15 interrupt-parent = <&intc>;
16
17 #address-cells = <1>;
18 #size-cells = <1>;
19
20 aliases {
21 gpio0 = &gpio_ptc;
22 gpio1 = &gpio_ptd;
23 gpio2 = &gpio_pte;
24 gpio3 = &gpio_ptf;
25 i2c0 = &lpi2c6;
26 i2c1 = &lpi2c7;
27 mmc0 = &usdhc0;
28 mmc1 = &usdhc1;
29 serial0 = &lpuart4;
30 serial1 = &lpuart5;
31 serial2 = &lpuart6;
32 serial3 = &lpuart7;
33 usbphy0 = &usbphy1;
34 };
35
36 cpus {
37 #address-cells = <1>;
38 #size-cells = <0>;
39
40 cpu0: cpu@f00 {
41 compatible = "arm,cortex-a7";
42 device_type = "cpu";
43 reg = <0xf00>;
44 };
45 };
46
47 intc: interrupt-controller@40021000 {
48 compatible = "arm,cortex-a7-gic";
49 #interrupt-cells = <3>;
50 interrupt-controller;
51 reg = <0x40021000 0x1000>,
52 <0x40022000 0x1000>;
53 };
54
55 rosc: clock-rosc {
56 compatible = "fixed-clock";
57 clock-frequency = <32768>;
58 clock-output-names = "rosc";
59 #clock-cells = <0>;
60 };
61
62 sosc: clock-sosc {
63 compatible = "fixed-clock";
64 clock-frequency = <24000000>;
65 clock-output-names = "sosc";
66 #clock-cells = <0>;
67 };
68
69 sirc: clock-sirc {
70 compatible = "fixed-clock";
71 clock-frequency = <16000000>;
72 clock-output-names = "sirc";
73 #clock-cells = <0>;
74 };
75
76 firc: clock-firc {
77 compatible = "fixed-clock";
78 clock-frequency = <48000000>;
79 clock-output-names = "firc";
80 #clock-cells = <0>;
81 };
82
83 upll: clock-upll {
84 compatible = "fixed-clock";
85 clock-frequency = <480000000>;
86 clock-output-names = "upll";
87 #clock-cells = <0>;
88 };
89
90 ahbbridge0: bus@40000000 {
91 compatible = "simple-bus";
92 #address-cells = <1>;
93 #size-cells = <1>;
94 reg = <0x40000000 0x800000>;
95 ranges;
96
97 edma1: dma-controller@40080000 {
98 #dma-cells = <2>;
99 compatible = "fsl,imx7ulp-edma";
100 reg = <0x40080000 0x2000>,
101 <0x40210000 0x1000>;
102 dma-channels = <32>;
103 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>,
104 <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>,
105 <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>,
106 <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>,
107 <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>,
108 <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>,
109 <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
110 <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>,
111 <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
112 <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>,
113 <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>,
114 <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>,
115 <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>,
116 <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>,
117 <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>,
118 <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>,
119 <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>;
120 clock-names = "dma", "dmamux0";
121 clocks = <&pcc2 IMX7ULP_CLK_DMA1>,
122 <&pcc2 IMX7ULP_CLK_DMA_MUX1>;
123 };
124
125 crypto: crypto@40240000 {
126 compatible = "fsl,sec-v4.0";
127 #address-cells = <1>;
128 #size-cells = <1>;
129 reg = <0x40240000 0x10000>;
130 ranges = <0 0x40240000 0x10000>;
131 clocks = <&pcc2 IMX7ULP_CLK_CAAM>,
132 <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>;
133 clock-names = "aclk", "ipg";
134
135 sec_jr0: jr@1000 {
136 compatible = "fsl,sec-v4.0-job-ring";
137 reg = <0x1000 0x1000>;
138 interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
139 };
140
141 sec_jr1: jr@2000 {
142 compatible = "fsl,sec-v4.0-job-ring";
143 reg = <0x2000 0x1000>;
144 interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
145 };
146 };
147
148 lpuart4: serial@402d0000 {
149 compatible = "fsl,imx7ulp-lpuart";
150 reg = <0x402d0000 0x1000>;
151 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
152 clocks = <&pcc2 IMX7ULP_CLK_LPUART4>;
153 clock-names = "ipg";
154 assigned-clocks = <&pcc2 IMX7ULP_CLK_LPUART4>;
155 assigned-clock-parents = <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>;
156 assigned-clock-rates = <24000000>;
157 status = "disabled";
158 };
159
160 lpuart5: serial@402e0000 {
161 compatible = "fsl,imx7ulp-lpuart";
162 reg = <0x402e0000 0x1000>;
163 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
164 clocks = <&pcc2 IMX7ULP_CLK_LPUART5>;
165 clock-names = "ipg";
166 assigned-clocks = <&pcc2 IMX7ULP_CLK_LPUART5>;
167 assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>;
168 assigned-clock-rates = <48000000>;
169 status = "disabled";
170 };
171
172 tpm4: pwm@40250000 {
173 compatible = "fsl,imx7ulp-pwm";
174 reg = <0x40250000 0x1000>;
175 assigned-clocks = <&pcc2 IMX7ULP_CLK_LPTPM4>;
176 assigned-clock-parents = <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>;
177 clocks = <&pcc2 IMX7ULP_CLK_LPTPM4>;
178 #pwm-cells = <3>;
179 status = "disabled";
180 };
181
182 tpm5: tpm@40260000 {
183 compatible = "fsl,imx7ulp-tpm";
184 reg = <0x40260000 0x1000>;
185 interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
186 clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>,
187 <&pcc2 IMX7ULP_CLK_LPTPM5>;
188 clock-names = "ipg", "per";
189 };
190
191 usbotg1: usb@40330000 {
192 compatible = "fsl,imx7ulp-usb", "fsl,imx6ul-usb";
193 reg = <0x40330000 0x200>;
194 interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
195 clocks = <&pcc2 IMX7ULP_CLK_USB0>;
196 phys = <&usbphy1>;
197 fsl,usbmisc = <&usbmisc1 0>;
198 ahb-burst-config = <0x0>;
199 tx-burst-size-dword = <0x8>;
200 rx-burst-size-dword = <0x8>;
201 status = "disabled";
202 };
203
204 usbmisc1: usbmisc@40330200 {
205 compatible = "fsl,imx7ulp-usbmisc", "fsl,imx7d-usbmisc";
206 #index-cells = <1>;
207 reg = <0x40330200 0x200>;
208 };
209
210 usbphy1: usb-phy@40350000 {
211 compatible = "fsl,imx7ulp-usbphy", "fsl,imx6ul-usbphy";
212 reg = <0x40350000 0x1000>;
213 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
214 clocks = <&pcc2 IMX7ULP_CLK_USB_PHY>;
215 #phy-cells = <0>;
216 };
217
218 usdhc0: mmc@40370000 {
219 compatible = "fsl,imx7ulp-usdhc", "fsl,imx6sx-usdhc";
220 reg = <0x40370000 0x10000>;
221 interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
222 clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>,
223 <&scg1 IMX7ULP_CLK_NIC1_DIV>,
224 <&pcc2 IMX7ULP_CLK_USDHC0>;
225 clock-names = "ipg", "ahb", "per";
226 bus-width = <4>;
227 fsl,tuning-start-tap = <20>;
228 fsl,tuning-step = <2>;
229 status = "disabled";
230 };
231
232 usdhc1: mmc@40380000 {
233 compatible = "fsl,imx7ulp-usdhc", "fsl,imx6sx-usdhc";
234 reg = <0x40380000 0x10000>;
235 interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
236 clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>,
237 <&scg1 IMX7ULP_CLK_NIC1_DIV>,
238 <&pcc2 IMX7ULP_CLK_USDHC1>;
239 clock-names = "ipg", "ahb", "per";
240 bus-width = <4>;
241 fsl,tuning-start-tap = <20>;
242 fsl,tuning-step = <2>;
243 status = "disabled";
244 };
245
246 scg1: clock-controller@403e0000 {
247 compatible = "fsl,imx7ulp-scg1";
248 reg = <0x403e0000 0x10000>;
249 clocks = <&rosc>, <&sosc>, <&sirc>,
250 <&firc>, <&upll>;
251 clock-names = "rosc", "sosc", "sirc",
252 "firc", "upll";
253 #clock-cells = <1>;
254 };
255
256 wdog1: watchdog@403d0000 {
257 compatible = "fsl,imx7ulp-wdt";
258 reg = <0x403d0000 0x10000>;
259 interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
260 clocks = <&pcc2 IMX7ULP_CLK_WDG1>;
261 assigned-clocks = <&pcc2 IMX7ULP_CLK_WDG1>;
262 assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC_BUS_CLK>;
263 timeout-sec = <40>;
264 };
265
266 pcc2: clock-controller@403f0000 {
267 compatible = "fsl,imx7ulp-pcc2";
268 reg = <0x403f0000 0x10000>;
269 #clock-cells = <1>;
270 clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>,
271 <&scg1 IMX7ULP_CLK_NIC1_DIV>,
272 <&scg1 IMX7ULP_CLK_DDR_DIV>,
273 <&scg1 IMX7ULP_CLK_APLL_PFD2>,
274 <&scg1 IMX7ULP_CLK_APLL_PFD1>,
275 <&scg1 IMX7ULP_CLK_APLL_PFD0>,
276 <&scg1 IMX7ULP_CLK_UPLL>,
277 <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>,
278 <&scg1 IMX7ULP_CLK_FIRC_BUS_CLK>,
279 <&scg1 IMX7ULP_CLK_ROSC>,
280 <&scg1 IMX7ULP_CLK_SPLL_BUS_CLK>;
281 clock-names = "nic1_bus_clk", "nic1_clk", "ddr_clk",
282 "apll_pfd2", "apll_pfd1", "apll_pfd0",
283 "upll", "sosc_bus_clk",
284 "firc_bus_clk", "rosc", "spll_bus_clk";
285 assigned-clocks = <&pcc2 IMX7ULP_CLK_LPTPM5>;
286 assigned-clock-parents = <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>;
287 };
288
289 smc1: clock-controller@40410000 {
290 compatible = "fsl,imx7ulp-smc1";
291 reg = <0x40410000 0x1000>;
292 #clock-cells = <1>;
293 clocks = <&scg1 IMX7ULP_CLK_CORE_DIV>,
294 <&scg1 IMX7ULP_CLK_HSRUN_CORE_DIV>;
295 clock-names = "divcore", "hsrun_divcore";
296 };
297
298 pcc3: clock-controller@40b30000 {
299 compatible = "fsl,imx7ulp-pcc3";
300 reg = <0x40b30000 0x10000>;
301 #clock-cells = <1>;
302 clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>,
303 <&scg1 IMX7ULP_CLK_NIC1_DIV>,
304 <&scg1 IMX7ULP_CLK_DDR_DIV>,
305 <&scg1 IMX7ULP_CLK_APLL_PFD2>,
306 <&scg1 IMX7ULP_CLK_APLL_PFD1>,
307 <&scg1 IMX7ULP_CLK_APLL_PFD0>,
308 <&scg1 IMX7ULP_CLK_UPLL>,
309 <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>,
310 <&scg1 IMX7ULP_CLK_FIRC_BUS_CLK>,
311 <&scg1 IMX7ULP_CLK_ROSC>,
312 <&scg1 IMX7ULP_CLK_SPLL_BUS_CLK>;
313 clock-names = "nic1_bus_clk", "nic1_clk", "ddr_clk",
314 "apll_pfd2", "apll_pfd1", "apll_pfd0",
315 "upll", "sosc_bus_clk",
316 "firc_bus_clk", "rosc", "spll_bus_clk";
317 };
318 };
319
320 ahbbridge1: bus@40800000 {
321 compatible = "simple-bus";
322 #address-cells = <1>;
323 #size-cells = <1>;
324 reg = <0x40800000 0x800000>;
325 ranges;
326
327 lpi2c6: i2c@40a40000 {
328 compatible = "fsl,imx7ulp-lpi2c";
329 reg = <0x40a40000 0x10000>;
330 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
331 clocks = <&pcc3 IMX7ULP_CLK_LPI2C6>,
332 <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>;
333 clock-names = "per", "ipg";
334 assigned-clocks = <&pcc3 IMX7ULP_CLK_LPI2C6>;
335 assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>;
336 assigned-clock-rates = <48000000>;
337 status = "disabled";
338 };
339
340 lpi2c7: i2c@40a50000 {
341 compatible = "fsl,imx7ulp-lpi2c";
342 reg = <0x40a50000 0x10000>;
343 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
344 clocks = <&pcc3 IMX7ULP_CLK_LPI2C7>,
345 <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>;
346 clock-names = "per", "ipg";
347 assigned-clocks = <&pcc3 IMX7ULP_CLK_LPI2C7>;
348 assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>;
349 assigned-clock-rates = <48000000>;
350 status = "disabled";
351 };
352
353 lpuart6: serial@40a60000 {
354 compatible = "fsl,imx7ulp-lpuart";
355 reg = <0x40a60000 0x1000>;
356 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
357 clocks = <&pcc3 IMX7ULP_CLK_LPUART6>;
358 clock-names = "ipg";
359 assigned-clocks = <&pcc3 IMX7ULP_CLK_LPUART6>;
360 assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>;
361 assigned-clock-rates = <48000000>;
362 status = "disabled";
363 };
364
365 lpuart7: serial@40a70000 {
366 compatible = "fsl,imx7ulp-lpuart";
367 reg = <0x40a70000 0x1000>;
368 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
369 clocks = <&pcc3 IMX7ULP_CLK_LPUART7>;
370 clock-names = "ipg";
371 assigned-clocks = <&pcc3 IMX7ULP_CLK_LPUART7>;
372 assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>;
373 assigned-clock-rates = <48000000>;
374 status = "disabled";
375 };
376
377 memory-controller@40ab0000 {
378 compatible = "fsl,imx7ulp-mmdc", "fsl,imx6q-mmdc";
379 reg = <0x40ab0000 0x1000>;
380 clocks = <&pcc3 IMX7ULP_CLK_MMDC>;
381 };
382
383 iomuxc1: pinctrl@40ac0000 {
384 compatible = "fsl,imx7ulp-iomuxc1";
385 reg = <0x40ac0000 0x1000>;
386 };
387
388 gpio_ptc: gpio@40ae0000 {
389 compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio";
390 reg = <0x40ae0000 0x1000 0x400f0000 0x40>;
391 gpio-controller;
392 #gpio-cells = <2>;
393 interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
394 interrupt-controller;
395 #interrupt-cells = <2>;
396 clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>,
397 <&pcc3 IMX7ULP_CLK_PCTLC>;
398 clock-names = "gpio", "port";
399 gpio-ranges = <&iomuxc1 0 0 20>;
400 };
401
402 gpio_ptd: gpio@40af0000 {
403 compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio";
404 reg = <0x40af0000 0x1000 0x400f0040 0x40>;
405 gpio-controller;
406 #gpio-cells = <2>;
407 interrupts = <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
408 interrupt-controller;
409 #interrupt-cells = <2>;
410 clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>,
411 <&pcc3 IMX7ULP_CLK_PCTLD>;
412 clock-names = "gpio", "port";
413 gpio-ranges = <&iomuxc1 0 32 12>;
414 };
415
416 gpio_pte: gpio@40b00000 {
417 compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio";
418 reg = <0x40b00000 0x1000 0x400f0080 0x40>;
419 gpio-controller;
420 #gpio-cells = <2>;
421 interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
422 interrupt-controller;
423 #interrupt-cells = <2>;
424 clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>,
425 <&pcc3 IMX7ULP_CLK_PCTLE>;
426 clock-names = "gpio", "port";
427 gpio-ranges = <&iomuxc1 0 64 16>;
428 };
429
430 gpio_ptf: gpio@40b10000 {
431 compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio";
432 reg = <0x40b10000 0x1000 0x400f00c0 0x40>;
433 gpio-controller;
434 #gpio-cells = <2>;
435 interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
436 interrupt-controller;
437 #interrupt-cells = <2>;
438 clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>,
439 <&pcc3 IMX7ULP_CLK_PCTLF>;
440 clock-names = "gpio", "port";
441 gpio-ranges = <&iomuxc1 0 96 20>;
442 };
443 };
444
445 m4aips1: bus@41080000 {
446 compatible = "simple-bus";
447 #address-cells = <1>;
448 #size-cells = <1>;
449 reg = <0x41080000 0x80000>;
450 ranges;
451
452 sim: sim@410a3000 {
453 compatible = "fsl,imx7ulp-sim", "syscon";
454 reg = <0x410a3000 0x1000>;
455 };
456
457 ocotp: efuse@410a6000 {
458 compatible = "fsl,imx7ulp-ocotp", "syscon";
459 reg = <0x410a6000 0x4000>;
460 clocks = <&scg1 IMX7ULP_CLK_DUMMY>;
461 };
462 };
463};