xref: /freebsd/sys/contrib/device-tree/src/arm64/freescale/imx8-ss-dma.dtsi (revision b64c5a0ace59af62eff52bfe110a521dc73c937b)
1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2018-2019 NXP
4 *	Dong Aisheng <aisheng.dong@nxp.com>
5 */
6
7#include <dt-bindings/clock/imx8-lpcg.h>
8#include <dt-bindings/firmware/imx/rsrc.h>
9
10dma_ipg_clk: clock-dma-ipg {
11	compatible = "fixed-clock";
12	#clock-cells = <0>;
13	clock-frequency = <120000000>;
14	clock-output-names = "dma_ipg_clk";
15};
16
17dma_subsys: bus@5a000000 {
18	compatible = "simple-bus";
19	#address-cells = <1>;
20	#size-cells = <1>;
21	ranges = <0x5a000000 0x0 0x5a000000 0x1000000>;
22
23	lpspi0: spi@5a000000 {
24		compatible = "fsl,imx7ulp-spi";
25		reg = <0x5a000000 0x10000>;
26		#address-cells = <1>;
27		#size-cells = <0>;
28		interrupts = <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>;
29		interrupt-parent = <&gic>;
30		clocks = <&spi0_lpcg 0>,
31			 <&spi0_lpcg 1>;
32		clock-names = "per", "ipg";
33		assigned-clocks = <&clk IMX_SC_R_SPI_0 IMX_SC_PM_CLK_PER>;
34		assigned-clock-rates = <60000000>;
35		power-domains = <&pd IMX_SC_R_SPI_0>;
36		status = "disabled";
37	};
38
39	lpspi1: spi@5a010000 {
40		compatible = "fsl,imx7ulp-spi";
41		reg = <0x5a010000 0x10000>;
42		#address-cells = <1>;
43		#size-cells = <0>;
44		interrupts = <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>;
45		interrupt-parent = <&gic>;
46		clocks = <&spi1_lpcg 0>,
47			 <&spi1_lpcg 1>;
48		clock-names = "per", "ipg";
49		assigned-clocks = <&clk IMX_SC_R_SPI_1 IMX_SC_PM_CLK_PER>;
50		assigned-clock-rates = <60000000>;
51		power-domains = <&pd IMX_SC_R_SPI_1>;
52		status = "disabled";
53	};
54
55	lpspi2: spi@5a020000 {
56		compatible = "fsl,imx7ulp-spi";
57		reg = <0x5a020000 0x10000>;
58		#address-cells = <1>;
59		#size-cells = <0>;
60		interrupts = <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>;
61		interrupt-parent = <&gic>;
62		clocks = <&spi2_lpcg 0>,
63			 <&spi2_lpcg 1>;
64		clock-names = "per", "ipg";
65		assigned-clocks = <&clk IMX_SC_R_SPI_2 IMX_SC_PM_CLK_PER>;
66		assigned-clock-rates = <60000000>;
67		power-domains = <&pd IMX_SC_R_SPI_2>;
68		status = "disabled";
69	};
70
71	lpspi3: spi@5a030000 {
72		compatible = "fsl,imx7ulp-spi";
73		reg = <0x5a030000 0x10000>;
74		#address-cells = <1>;
75		#size-cells = <0>;
76		interrupts = <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>;
77		interrupt-parent = <&gic>;
78		clocks = <&spi3_lpcg 0>,
79			 <&spi3_lpcg 1>;
80		clock-names = "per", "ipg";
81		assigned-clocks = <&clk IMX_SC_R_SPI_3 IMX_SC_PM_CLK_PER>;
82		assigned-clock-rates = <60000000>;
83		power-domains = <&pd IMX_SC_R_SPI_3>;
84		status = "disabled";
85	};
86
87	lpuart0: serial@5a060000 {
88		reg = <0x5a060000 0x1000>;
89		interrupts = <GIC_SPI 345 IRQ_TYPE_LEVEL_HIGH>;
90		clocks = <&uart0_lpcg IMX_LPCG_CLK_4>,
91			 <&uart0_lpcg IMX_LPCG_CLK_0>;
92		clock-names = "ipg", "baud";
93		assigned-clocks = <&clk IMX_SC_R_UART_0 IMX_SC_PM_CLK_PER>;
94		assigned-clock-rates = <80000000>;
95		power-domains = <&pd IMX_SC_R_UART_0>;
96		dma-names = "tx","rx";
97		dmas = <&edma2 9 0 0>, <&edma2 8 0 1>;
98		status = "disabled";
99	};
100
101	lpuart1: serial@5a070000 {
102		reg = <0x5a070000 0x1000>;
103		interrupts = <GIC_SPI 346 IRQ_TYPE_LEVEL_HIGH>;
104		clocks = <&uart1_lpcg IMX_LPCG_CLK_4>,
105			 <&uart1_lpcg IMX_LPCG_CLK_0>;
106		clock-names = "ipg", "baud";
107		assigned-clocks = <&clk IMX_SC_R_UART_1 IMX_SC_PM_CLK_PER>;
108		assigned-clock-rates = <80000000>;
109		power-domains = <&pd IMX_SC_R_UART_1>;
110		dma-names = "tx","rx";
111		dmas = <&edma2 11 0 0>, <&edma2 10 0 1>;
112		status = "disabled";
113	};
114
115	lpuart2: serial@5a080000 {
116		reg = <0x5a080000 0x1000>;
117		interrupts = <GIC_SPI 347 IRQ_TYPE_LEVEL_HIGH>;
118		clocks = <&uart2_lpcg IMX_LPCG_CLK_4>,
119			 <&uart2_lpcg IMX_LPCG_CLK_0>;
120		clock-names = "ipg", "baud";
121		assigned-clocks = <&clk IMX_SC_R_UART_2 IMX_SC_PM_CLK_PER>;
122		assigned-clock-rates = <80000000>;
123		power-domains = <&pd IMX_SC_R_UART_2>;
124		dma-names = "tx","rx";
125		dmas = <&edma2 13 0 0>, <&edma2 12 0 1>;
126		status = "disabled";
127	};
128
129	lpuart3: serial@5a090000 {
130		reg = <0x5a090000 0x1000>;
131		interrupts = <GIC_SPI 348 IRQ_TYPE_LEVEL_HIGH>;
132		clocks = <&uart3_lpcg IMX_LPCG_CLK_4>,
133			 <&uart3_lpcg IMX_LPCG_CLK_0>;
134		clock-names = "ipg", "baud";
135		assigned-clocks = <&clk IMX_SC_R_UART_3 IMX_SC_PM_CLK_PER>;
136		assigned-clock-rates = <80000000>;
137		power-domains = <&pd IMX_SC_R_UART_3>;
138		dma-names = "tx","rx";
139		dmas = <&edma2 15 0 0>, <&edma2 14 0 1>;
140		status = "disabled";
141	};
142
143	adma_pwm: pwm@5a190000 {
144		compatible = "fsl,imx8qxp-pwm", "fsl,imx27-pwm";
145		reg = <0x5a190000 0x1000>;
146		interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
147		clocks = <&adma_pwm_lpcg 1>,
148			 <&adma_pwm_lpcg 0>;
149		clock-names = "ipg", "per";
150		assigned-clocks = <&clk IMX_SC_R_LCD_0_PWM_0 IMX_SC_PM_CLK_PER>;
151		assigned-clock-rates = <24000000>;
152		#pwm-cells = <3>;
153		power-domains = <&pd IMX_SC_R_LCD_0_PWM_0>;
154	};
155
156	edma2: dma-controller@5a1f0000 {
157		compatible = "fsl,imx8qm-edma";
158		reg = <0x5a1f0000 0x170000>;
159		#dma-cells = <3>;
160		dma-channels = <16>;
161		interrupts = <GIC_SPI 416 IRQ_TYPE_LEVEL_HIGH>,
162			     <GIC_SPI 417 IRQ_TYPE_LEVEL_HIGH>,
163			     <GIC_SPI 418 IRQ_TYPE_LEVEL_HIGH>,
164			     <GIC_SPI 419 IRQ_TYPE_LEVEL_HIGH>,
165			     <GIC_SPI 420 IRQ_TYPE_LEVEL_HIGH>,
166			     <GIC_SPI 421 IRQ_TYPE_LEVEL_HIGH>,
167			     <GIC_SPI 422 IRQ_TYPE_LEVEL_HIGH>,
168			     <GIC_SPI 423 IRQ_TYPE_LEVEL_HIGH>,
169			     <GIC_SPI 434 IRQ_TYPE_LEVEL_HIGH>,
170			     <GIC_SPI 435 IRQ_TYPE_LEVEL_HIGH>,
171			     <GIC_SPI 436 IRQ_TYPE_LEVEL_HIGH>,
172			     <GIC_SPI 437 IRQ_TYPE_LEVEL_HIGH>,
173			     <GIC_SPI 438 IRQ_TYPE_LEVEL_HIGH>,
174			     <GIC_SPI 439 IRQ_TYPE_LEVEL_HIGH>,
175			     <GIC_SPI 440 IRQ_TYPE_LEVEL_HIGH>,
176			     <GIC_SPI 441 IRQ_TYPE_LEVEL_HIGH>;
177		power-domains = <&pd IMX_SC_R_DMA_2_CH0>,
178				<&pd IMX_SC_R_DMA_2_CH1>,
179				<&pd IMX_SC_R_DMA_2_CH2>,
180				<&pd IMX_SC_R_DMA_2_CH3>,
181				<&pd IMX_SC_R_DMA_2_CH4>,
182				<&pd IMX_SC_R_DMA_2_CH5>,
183				<&pd IMX_SC_R_DMA_2_CH6>,
184				<&pd IMX_SC_R_DMA_2_CH7>,
185				<&pd IMX_SC_R_DMA_2_CH8>,
186				<&pd IMX_SC_R_DMA_2_CH9>,
187				<&pd IMX_SC_R_DMA_2_CH10>,
188				<&pd IMX_SC_R_DMA_2_CH11>,
189				<&pd IMX_SC_R_DMA_2_CH12>,
190				<&pd IMX_SC_R_DMA_2_CH13>,
191				<&pd IMX_SC_R_DMA_2_CH14>,
192				<&pd IMX_SC_R_DMA_2_CH15>;
193	};
194
195	edma3: dma-controller@5a9f0000 {
196		compatible = "fsl,imx8qm-edma";
197		reg = <0x5a9f0000 0x90000>;
198		#dma-cells = <3>;
199		dma-channels = <8>;
200		interrupts = <GIC_SPI 424 IRQ_TYPE_LEVEL_HIGH>,
201			     <GIC_SPI 425 IRQ_TYPE_LEVEL_HIGH>,
202			     <GIC_SPI 426 IRQ_TYPE_LEVEL_HIGH>,
203			     <GIC_SPI 427 IRQ_TYPE_LEVEL_HIGH>,
204			     <GIC_SPI 428 IRQ_TYPE_LEVEL_HIGH>,
205			     <GIC_SPI 429 IRQ_TYPE_LEVEL_HIGH>,
206			     <GIC_SPI 430 IRQ_TYPE_LEVEL_HIGH>,
207			     <GIC_SPI 431 IRQ_TYPE_LEVEL_HIGH>;
208		power-domains = <&pd IMX_SC_R_DMA_3_CH0>,
209				<&pd IMX_SC_R_DMA_3_CH1>,
210				<&pd IMX_SC_R_DMA_3_CH2>,
211				<&pd IMX_SC_R_DMA_3_CH3>,
212				<&pd IMX_SC_R_DMA_3_CH4>,
213				<&pd IMX_SC_R_DMA_3_CH5>,
214				<&pd IMX_SC_R_DMA_3_CH6>,
215				<&pd IMX_SC_R_DMA_3_CH7>;
216	};
217
218	spi0_lpcg: clock-controller@5a400000 {
219		compatible = "fsl,imx8qxp-lpcg";
220		reg = <0x5a400000 0x10000>;
221		#clock-cells = <1>;
222		clocks = <&clk IMX_SC_R_SPI_0 IMX_SC_PM_CLK_PER>,
223			 <&dma_ipg_clk>;
224		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
225		clock-output-names = "spi0_lpcg_clk",
226				     "spi0_lpcg_ipg_clk";
227		power-domains = <&pd IMX_SC_R_SPI_0>;
228	};
229
230	spi1_lpcg: clock-controller@5a410000 {
231		compatible = "fsl,imx8qxp-lpcg";
232		reg = <0x5a410000 0x10000>;
233		#clock-cells = <1>;
234		clocks = <&clk IMX_SC_R_SPI_1 IMX_SC_PM_CLK_PER>,
235			 <&dma_ipg_clk>;
236		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
237		clock-output-names = "spi1_lpcg_clk",
238				     "spi1_lpcg_ipg_clk";
239		power-domains = <&pd IMX_SC_R_SPI_1>;
240	};
241
242	spi2_lpcg: clock-controller@5a420000 {
243		compatible = "fsl,imx8qxp-lpcg";
244		reg = <0x5a420000 0x10000>;
245		#clock-cells = <1>;
246		clocks = <&clk IMX_SC_R_SPI_2 IMX_SC_PM_CLK_PER>,
247			 <&dma_ipg_clk>;
248		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
249		clock-output-names = "spi2_lpcg_clk",
250				     "spi2_lpcg_ipg_clk";
251		power-domains = <&pd IMX_SC_R_SPI_2>;
252	};
253
254	spi3_lpcg: clock-controller@5a430000 {
255		compatible = "fsl,imx8qxp-lpcg";
256		reg = <0x5a430000 0x10000>;
257		#clock-cells = <1>;
258		clocks = <&clk IMX_SC_R_SPI_3 IMX_SC_PM_CLK_PER>,
259			 <&dma_ipg_clk>;
260		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
261		clock-output-names = "spi3_lpcg_clk",
262				     "spi3_lpcg_ipg_clk";
263		power-domains = <&pd IMX_SC_R_SPI_3>;
264	};
265
266	uart0_lpcg: clock-controller@5a460000 {
267		compatible = "fsl,imx8qxp-lpcg";
268		reg = <0x5a460000 0x10000>;
269		#clock-cells = <1>;
270		clocks = <&clk IMX_SC_R_UART_0 IMX_SC_PM_CLK_PER>,
271			 <&dma_ipg_clk>;
272		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
273		clock-output-names = "uart0_lpcg_baud_clk",
274				     "uart0_lpcg_ipg_clk";
275		power-domains = <&pd IMX_SC_R_UART_0>;
276	};
277
278	uart1_lpcg: clock-controller@5a470000 {
279		compatible = "fsl,imx8qxp-lpcg";
280		reg = <0x5a470000 0x10000>;
281		#clock-cells = <1>;
282		clocks = <&clk IMX_SC_R_UART_1 IMX_SC_PM_CLK_PER>,
283			 <&dma_ipg_clk>;
284		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
285		clock-output-names = "uart1_lpcg_baud_clk",
286				     "uart1_lpcg_ipg_clk";
287		power-domains = <&pd IMX_SC_R_UART_1>;
288	};
289
290	uart2_lpcg: clock-controller@5a480000 {
291		compatible = "fsl,imx8qxp-lpcg";
292		reg = <0x5a480000 0x10000>;
293		#clock-cells = <1>;
294		clocks = <&clk IMX_SC_R_UART_2 IMX_SC_PM_CLK_PER>,
295			 <&dma_ipg_clk>;
296		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
297		clock-output-names = "uart2_lpcg_baud_clk",
298				     "uart2_lpcg_ipg_clk";
299		power-domains = <&pd IMX_SC_R_UART_2>;
300	};
301
302	uart3_lpcg: clock-controller@5a490000 {
303		compatible = "fsl,imx8qxp-lpcg";
304		reg = <0x5a490000 0x10000>;
305		#clock-cells = <1>;
306		clocks = <&clk IMX_SC_R_UART_3 IMX_SC_PM_CLK_PER>,
307			 <&dma_ipg_clk>;
308		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
309		clock-output-names = "uart3_lpcg_baud_clk",
310				     "uart3_lpcg_ipg_clk";
311		power-domains = <&pd IMX_SC_R_UART_3>;
312	};
313
314	adma_pwm_lpcg: clock-controller@5a590000 {
315		compatible = "fsl,imx8qxp-lpcg";
316		reg = <0x5a590000 0x10000>;
317		#clock-cells = <1>;
318		clocks = <&clk IMX_SC_R_LCD_0_PWM_0 IMX_SC_PM_CLK_PER>,
319			 <&dma_ipg_clk>;
320		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
321		clock-output-names = "adma_pwm_lpcg_clk",
322				     "adma_pwm_lpcg_ipg_clk";
323		power-domains = <&pd IMX_SC_R_LCD_0_PWM_0>;
324	};
325
326	i2c0: i2c@5a800000 {
327		reg = <0x5a800000 0x4000>;
328		interrupts = <GIC_SPI 220 IRQ_TYPE_LEVEL_HIGH>;
329		clocks = <&i2c0_lpcg IMX_LPCG_CLK_0>,
330			 <&i2c0_lpcg IMX_LPCG_CLK_4>;
331		clock-names = "per", "ipg";
332		assigned-clocks = <&clk IMX_SC_R_I2C_0 IMX_SC_PM_CLK_PER>;
333		assigned-clock-rates = <24000000>;
334		power-domains = <&pd IMX_SC_R_I2C_0>;
335		status = "disabled";
336	};
337
338	i2c1: i2c@5a810000 {
339		reg = <0x5a810000 0x4000>;
340		interrupts = <GIC_SPI 221 IRQ_TYPE_LEVEL_HIGH>;
341		clocks = <&i2c1_lpcg IMX_LPCG_CLK_0>,
342			 <&i2c1_lpcg IMX_LPCG_CLK_4>;
343		clock-names = "per", "ipg";
344		assigned-clocks = <&clk IMX_SC_R_I2C_1 IMX_SC_PM_CLK_PER>;
345		assigned-clock-rates = <24000000>;
346		power-domains = <&pd IMX_SC_R_I2C_1>;
347		status = "disabled";
348	};
349
350	i2c2: i2c@5a820000 {
351		reg = <0x5a820000 0x4000>;
352		interrupts = <GIC_SPI 222 IRQ_TYPE_LEVEL_HIGH>;
353		clocks = <&i2c2_lpcg IMX_LPCG_CLK_0>,
354			 <&i2c2_lpcg IMX_LPCG_CLK_4>;
355		clock-names = "per", "ipg";
356		assigned-clocks = <&clk IMX_SC_R_I2C_2 IMX_SC_PM_CLK_PER>;
357		assigned-clock-rates = <24000000>;
358		power-domains = <&pd IMX_SC_R_I2C_2>;
359		status = "disabled";
360	};
361
362	i2c3: i2c@5a830000 {
363		reg = <0x5a830000 0x4000>;
364		interrupts = <GIC_SPI 223 IRQ_TYPE_LEVEL_HIGH>;
365		clocks = <&i2c3_lpcg IMX_LPCG_CLK_0>,
366			 <&i2c3_lpcg IMX_LPCG_CLK_4>;
367		clock-names = "per", "ipg";
368		assigned-clocks = <&clk IMX_SC_R_I2C_3 IMX_SC_PM_CLK_PER>;
369		assigned-clock-rates = <24000000>;
370		power-domains = <&pd IMX_SC_R_I2C_3>;
371		status = "disabled";
372	};
373
374	adc0: adc@5a880000 {
375		compatible = "nxp,imx8qxp-adc";
376		#io-channel-cells = <1>;
377		reg = <0x5a880000 0x10000>;
378		interrupts = <GIC_SPI 240 IRQ_TYPE_LEVEL_HIGH>;
379		interrupt-parent = <&gic>;
380		clocks = <&adc0_lpcg 0>,
381			 <&adc0_lpcg 1>;
382		clock-names = "per", "ipg";
383		assigned-clocks = <&clk IMX_SC_R_ADC_0 IMX_SC_PM_CLK_PER>;
384		assigned-clock-rates = <24000000>;
385		power-domains = <&pd IMX_SC_R_ADC_0>;
386		status = "disabled";
387	 };
388
389	adc1: adc@5a890000 {
390		compatible = "nxp,imx8qxp-adc";
391		#io-channel-cells = <1>;
392		reg = <0x5a890000 0x10000>;
393		interrupts = <GIC_SPI 241 IRQ_TYPE_LEVEL_HIGH>;
394		interrupt-parent = <&gic>;
395		clocks = <&adc1_lpcg 0>,
396			 <&adc1_lpcg 1>;
397		clock-names = "per", "ipg";
398		assigned-clocks = <&clk IMX_SC_R_ADC_1 IMX_SC_PM_CLK_PER>;
399		assigned-clock-rates = <24000000>;
400		power-domains = <&pd IMX_SC_R_ADC_1>;
401		status = "disabled";
402	};
403
404	flexcan1: can@5a8d0000 {
405		compatible = "fsl,imx8qm-flexcan";
406		reg = <0x5a8d0000 0x10000>;
407		interrupts = <GIC_SPI 235 IRQ_TYPE_LEVEL_HIGH>;
408		interrupt-parent = <&gic>;
409		clocks = <&can0_lpcg 1>,
410			 <&can0_lpcg 0>;
411		clock-names = "ipg", "per";
412		assigned-clocks = <&clk IMX_SC_R_CAN_0 IMX_SC_PM_CLK_PER>;
413		assigned-clock-rates = <40000000>;
414		power-domains = <&pd IMX_SC_R_CAN_0>;
415		/* SLSlice[4] */
416		fsl,clk-source = /bits/ 8 <0>;
417		fsl,scu-index = /bits/ 8 <0>;
418		status = "disabled";
419	};
420
421	flexcan2: can@5a8e0000 {
422		compatible = "fsl,imx8qm-flexcan";
423		reg = <0x5a8e0000 0x10000>;
424		interrupts = <GIC_SPI 236 IRQ_TYPE_LEVEL_HIGH>;
425		interrupt-parent = <&gic>;
426		/* CAN0 clock and PD is shared among all CAN instances as
427		 * CAN1 shares CAN0's clock and to enable CAN0's clock it
428		 * has to be powered on.
429		 */
430		clocks = <&can0_lpcg 1>,
431			 <&can0_lpcg 0>;
432		clock-names = "ipg", "per";
433		assigned-clocks = <&clk IMX_SC_R_CAN_0 IMX_SC_PM_CLK_PER>;
434		assigned-clock-rates = <40000000>;
435		power-domains = <&pd IMX_SC_R_CAN_1>;
436		/* SLSlice[4] */
437		fsl,clk-source = /bits/ 8 <0>;
438		fsl,scu-index = /bits/ 8 <1>;
439		status = "disabled";
440	};
441
442	flexcan3: can@5a8f0000 {
443		compatible = "fsl,imx8qm-flexcan";
444		reg = <0x5a8f0000 0x10000>;
445		interrupts = <GIC_SPI 237 IRQ_TYPE_LEVEL_HIGH>;
446		interrupt-parent = <&gic>;
447		/* CAN0 clock and PD is shared among all CAN instances as
448		 * CAN2 shares CAN0's clock and to enable CAN0's clock it
449		 * has to be powered on.
450		 */
451		clocks = <&can0_lpcg 1>,
452			 <&can0_lpcg 0>;
453		clock-names = "ipg", "per";
454		assigned-clocks = <&clk IMX_SC_R_CAN_0 IMX_SC_PM_CLK_PER>;
455		assigned-clock-rates = <40000000>;
456		power-domains = <&pd IMX_SC_R_CAN_2>;
457		/* SLSlice[4] */
458		fsl,clk-source = /bits/ 8 <0>;
459		fsl,scu-index = /bits/ 8 <2>;
460		status = "disabled";
461	};
462
463	i2c0_lpcg: clock-controller@5ac00000 {
464		compatible = "fsl,imx8qxp-lpcg";
465		reg = <0x5ac00000 0x10000>;
466		#clock-cells = <1>;
467		clocks = <&clk IMX_SC_R_I2C_0 IMX_SC_PM_CLK_PER>,
468			 <&dma_ipg_clk>;
469		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
470		clock-output-names = "i2c0_lpcg_clk",
471				     "i2c0_lpcg_ipg_clk";
472		power-domains = <&pd IMX_SC_R_I2C_0>;
473	};
474
475	i2c1_lpcg: clock-controller@5ac10000 {
476		compatible = "fsl,imx8qxp-lpcg";
477		reg = <0x5ac10000 0x10000>;
478		#clock-cells = <1>;
479		clocks = <&clk IMX_SC_R_I2C_1 IMX_SC_PM_CLK_PER>,
480			 <&dma_ipg_clk>;
481		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
482		clock-output-names = "i2c1_lpcg_clk",
483				     "i2c1_lpcg_ipg_clk";
484		power-domains = <&pd IMX_SC_R_I2C_1>;
485	};
486
487	i2c2_lpcg: clock-controller@5ac20000 {
488		compatible = "fsl,imx8qxp-lpcg";
489		reg = <0x5ac20000 0x10000>;
490		#clock-cells = <1>;
491		clocks = <&clk IMX_SC_R_I2C_2 IMX_SC_PM_CLK_PER>,
492			 <&dma_ipg_clk>;
493		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
494		clock-output-names = "i2c2_lpcg_clk",
495				     "i2c2_lpcg_ipg_clk";
496		power-domains = <&pd IMX_SC_R_I2C_2>;
497	};
498
499	i2c3_lpcg: clock-controller@5ac30000 {
500		compatible = "fsl,imx8qxp-lpcg";
501		reg = <0x5ac30000 0x10000>;
502		#clock-cells = <1>;
503		clocks = <&clk IMX_SC_R_I2C_3 IMX_SC_PM_CLK_PER>,
504			 <&dma_ipg_clk>;
505		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
506		clock-output-names = "i2c3_lpcg_clk",
507				     "i2c3_lpcg_ipg_clk";
508		power-domains = <&pd IMX_SC_R_I2C_3>;
509	};
510
511	adc0_lpcg: clock-controller@5ac80000 {
512		compatible = "fsl,imx8qxp-lpcg";
513		reg = <0x5ac80000 0x10000>;
514		#clock-cells = <1>;
515		clocks = <&clk IMX_SC_R_ADC_0 IMX_SC_PM_CLK_PER>,
516			 <&dma_ipg_clk>;
517		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
518		clock-output-names = "adc0_lpcg_clk",
519				     "adc0_lpcg_ipg_clk";
520		power-domains = <&pd IMX_SC_R_ADC_0>;
521	};
522
523	adc1_lpcg: clock-controller@5ac90000 {
524		compatible = "fsl,imx8qxp-lpcg";
525		reg = <0x5ac90000 0x10000>;
526		#clock-cells = <1>;
527		clocks = <&clk IMX_SC_R_ADC_1 IMX_SC_PM_CLK_PER>,
528			 <&dma_ipg_clk>;
529		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>;
530		clock-output-names = "adc1_lpcg_clk",
531				     "adc1_lpcg_ipg_clk";
532		power-domains = <&pd IMX_SC_R_ADC_1>;
533	};
534
535	can0_lpcg: clock-controller@5acd0000 {
536		compatible = "fsl,imx8qxp-lpcg";
537		reg = <0x5acd0000 0x10000>;
538		#clock-cells = <1>;
539		clocks = <&clk IMX_SC_R_CAN_0 IMX_SC_PM_CLK_PER>,
540			 <&dma_ipg_clk>, <&dma_ipg_clk>;
541		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>;
542		clock-output-names = "can0_lpcg_pe_clk",
543				     "can0_lpcg_ipg_clk",
544				     "can0_lpcg_chi_clk";
545		power-domains = <&pd IMX_SC_R_CAN_0>;
546	};
547};
548