1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright 2018-2020 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
10lsio_subsys: bus@5d000000 {
11	compatible = "simple-bus";
12	#address-cells = <1>;
13	#size-cells = <1>;
14	ranges = <0x5d000000 0x0 0x5d000000 0x1000000>,
15		 <0x08000000 0x0 0x08000000 0x10000000>;
16
17	lsio_mem_clk: clock-lsio-mem {
18		compatible = "fixed-clock";
19		#clock-cells = <0>;
20		clock-frequency = <200000000>;
21		clock-output-names = "lsio_mem_clk";
22	};
23
24	lsio_bus_clk: clock-lsio-bus {
25		compatible = "fixed-clock";
26		#clock-cells = <0>;
27		clock-frequency = <100000000>;
28		clock-output-names = "lsio_bus_clk";
29	};
30
31	lsio_gpio0: gpio@5d080000 {
32		reg = <0x5d080000 0x10000>;
33		interrupts = <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>;
34		gpio-controller;
35		#gpio-cells = <2>;
36		interrupt-controller;
37		#interrupt-cells = <2>;
38		power-domains = <&pd IMX_SC_R_GPIO_0>;
39	};
40
41	lsio_gpio1: gpio@5d090000 {
42		reg = <0x5d090000 0x10000>;
43		interrupts = <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>;
44		gpio-controller;
45		#gpio-cells = <2>;
46		interrupt-controller;
47		#interrupt-cells = <2>;
48		power-domains = <&pd IMX_SC_R_GPIO_1>;
49	};
50
51	lsio_gpio2: gpio@5d0a0000 {
52		reg = <0x5d0a0000 0x10000>;
53		interrupts = <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>;
54		gpio-controller;
55		#gpio-cells = <2>;
56		interrupt-controller;
57		#interrupt-cells = <2>;
58		power-domains = <&pd IMX_SC_R_GPIO_2>;
59	};
60
61	lsio_gpio3: gpio@5d0b0000 {
62		reg = <0x5d0b0000 0x10000>;
63		interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
64		gpio-controller;
65		#gpio-cells = <2>;
66		interrupt-controller;
67		#interrupt-cells = <2>;
68		power-domains = <&pd IMX_SC_R_GPIO_3>;
69	};
70
71	lsio_gpio4: gpio@5d0c0000 {
72		reg = <0x5d0c0000 0x10000>;
73		interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
74		gpio-controller;
75		#gpio-cells = <2>;
76		interrupt-controller;
77		#interrupt-cells = <2>;
78		power-domains = <&pd IMX_SC_R_GPIO_4>;
79	};
80
81	lsio_gpio5: gpio@5d0d0000 {
82		reg = <0x5d0d0000 0x10000>;
83		interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>;
84		gpio-controller;
85		#gpio-cells = <2>;
86		interrupt-controller;
87		#interrupt-cells = <2>;
88		power-domains = <&pd IMX_SC_R_GPIO_5>;
89	};
90
91	lsio_gpio6: gpio@5d0e0000 {
92		reg = <0x5d0e0000 0x10000>;
93		interrupts = <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>;
94		gpio-controller;
95		#gpio-cells = <2>;
96		interrupt-controller;
97		#interrupt-cells = <2>;
98		power-domains = <&pd IMX_SC_R_GPIO_6>;
99	};
100
101	lsio_gpio7: gpio@5d0f0000 {
102		reg = <0x5d0f0000 0x10000>;
103		interrupts = <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
104		gpio-controller;
105		#gpio-cells = <2>;
106		interrupt-controller;
107		#interrupt-cells = <2>;
108		power-domains = <&pd IMX_SC_R_GPIO_7>;
109	};
110
111	flexspi0: spi@5d120000 {
112		#address-cells = <1>;
113		#size-cells = <0>;
114		compatible = "nxp,imx8qxp-fspi";
115		reg = <0x5d120000 0x10000>, <0x08000000 0x10000000>;
116		reg-names = "fspi_base", "fspi_mmap";
117		interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
118		clocks = <&clk IMX_SC_R_FSPI_0 IMX_SC_PM_CLK_PER>,
119			 <&clk IMX_SC_R_FSPI_0 IMX_SC_PM_CLK_PER>;
120		clock-names = "fspi", "fspi_en";
121		power-domains = <&pd IMX_SC_R_FSPI_0>;
122		status = "disabled";
123	};
124
125	lsio_mu0: mailbox@5d1b0000 {
126		reg = <0x5d1b0000 0x10000>;
127		interrupts = <GIC_SPI 176 IRQ_TYPE_LEVEL_HIGH>;
128		#mbox-cells = <2>;
129		status = "disabled";
130	};
131
132	lsio_mu1: mailbox@5d1c0000 {
133		reg = <0x5d1c0000 0x10000>;
134		interrupts = <GIC_SPI 177 IRQ_TYPE_LEVEL_HIGH>;
135		#mbox-cells = <2>;
136	};
137
138	lsio_mu2: mailbox@5d1d0000 {
139		reg = <0x5d1d0000 0x10000>;
140		interrupts = <GIC_SPI 178 IRQ_TYPE_LEVEL_HIGH>;
141		#mbox-cells = <2>;
142		status = "disabled";
143	};
144
145	lsio_mu3: mailbox@5d1e0000 {
146		reg = <0x5d1e0000 0x10000>;
147		interrupts = <GIC_SPI 179 IRQ_TYPE_LEVEL_HIGH>;
148		#mbox-cells = <2>;
149		status = "disabled";
150	};
151
152	lsio_mu4: mailbox@5d1f0000 {
153		reg = <0x5d1f0000 0x10000>;
154		interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_HIGH>;
155		#mbox-cells = <2>;
156		status = "disabled";
157	};
158
159	lsio_mu5: mailbox@5d200000 {
160		reg = <0x5d200000 0x10000>;
161		interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>;
162		#mbox-cells = <2>;
163		power-domains = <&pd IMX_SC_R_MU_5A>;
164		status = "disabled";
165	};
166
167	lsio_mu6: mailbox@5d210000 {
168		reg = <0x5d210000 0x10000>;
169		interrupts = <GIC_SPI 185 IRQ_TYPE_LEVEL_HIGH>;
170		#mbox-cells = <2>;
171		power-domains = <&pd IMX_SC_R_MU_6A>;
172		status = "disabled";
173	};
174
175	lsio_mu13: mailbox@5d280000 {
176		reg = <0x5d280000 0x10000>;
177		interrupts = <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>;
178		#mbox-cells = <2>;
179		power-domains = <&pd IMX_SC_R_MU_13A>;
180	};
181
182	/* LPCG clocks */
183	pwm0_lpcg: clock-controller@5d400000 {
184		compatible = "fsl,imx8qxp-lpcg";
185		reg = <0x5d400000 0x10000>;
186		#clock-cells = <1>;
187		clocks = <&clk IMX_SC_R_PWM_0 IMX_SC_PM_CLK_PER>,
188			 <&clk IMX_SC_R_PWM_0 IMX_SC_PM_CLK_PER>,
189			 <&clk IMX_SC_R_PWM_0 IMX_SC_PM_CLK_PER>,
190			 <&lsio_bus_clk>,
191			 <&clk IMX_SC_R_PWM_0 IMX_SC_PM_CLK_PER>;
192		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
193				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
194				<IMX_LPCG_CLK_6>;
195		clock-output-names = "pwm0_lpcg_ipg_clk",
196				     "pwm0_lpcg_ipg_hf_clk",
197				     "pwm0_lpcg_ipg_s_clk",
198				     "pwm0_lpcg_ipg_slv_clk",
199				     "pwm0_lpcg_ipg_mstr_clk";
200		power-domains = <&pd IMX_SC_R_PWM_0>;
201	};
202
203	pwm1_lpcg: clock-controller@5d410000 {
204		compatible = "fsl,imx8qxp-lpcg";
205		reg = <0x5d410000 0x10000>;
206		#clock-cells = <1>;
207		clocks = <&clk IMX_SC_R_PWM_1 IMX_SC_PM_CLK_PER>,
208			 <&clk IMX_SC_R_PWM_1 IMX_SC_PM_CLK_PER>,
209			 <&clk IMX_SC_R_PWM_1 IMX_SC_PM_CLK_PER>,
210			 <&lsio_bus_clk>,
211			 <&clk IMX_SC_R_PWM_1 IMX_SC_PM_CLK_PER>;
212		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
213				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
214				<IMX_LPCG_CLK_6>;
215		clock-output-names = "pwm1_lpcg_ipg_clk",
216				     "pwm1_lpcg_ipg_hf_clk",
217				     "pwm1_lpcg_ipg_s_clk",
218				     "pwm1_lpcg_ipg_slv_clk",
219				     "pwm1_lpcg_ipg_mstr_clk";
220		power-domains = <&pd IMX_SC_R_PWM_1>;
221	};
222
223	pwm2_lpcg: clock-controller@5d420000 {
224		compatible = "fsl,imx8qxp-lpcg";
225		reg = <0x5d420000 0x10000>;
226		#clock-cells = <1>;
227		clocks = <&clk IMX_SC_R_PWM_2 IMX_SC_PM_CLK_PER>,
228			 <&clk IMX_SC_R_PWM_2 IMX_SC_PM_CLK_PER>,
229			 <&clk IMX_SC_R_PWM_2 IMX_SC_PM_CLK_PER>,
230			 <&lsio_bus_clk>,
231			 <&clk IMX_SC_R_PWM_2 IMX_SC_PM_CLK_PER>;
232		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
233				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
234				<IMX_LPCG_CLK_6>;
235		clock-output-names = "pwm2_lpcg_ipg_clk",
236				     "pwm2_lpcg_ipg_hf_clk",
237				     "pwm2_lpcg_ipg_s_clk",
238				     "pwm2_lpcg_ipg_slv_clk",
239				     "pwm2_lpcg_ipg_mstr_clk";
240		power-domains = <&pd IMX_SC_R_PWM_2>;
241	};
242
243	pwm3_lpcg: clock-controller@5d430000 {
244		compatible = "fsl,imx8qxp-lpcg";
245		reg = <0x5d430000 0x10000>;
246		#clock-cells = <1>;
247		clocks = <&clk IMX_SC_R_PWM_3 IMX_SC_PM_CLK_PER>,
248			 <&clk IMX_SC_R_PWM_3 IMX_SC_PM_CLK_PER>,
249			 <&clk IMX_SC_R_PWM_3 IMX_SC_PM_CLK_PER>,
250			 <&lsio_bus_clk>,
251			 <&clk IMX_SC_R_PWM_3 IMX_SC_PM_CLK_PER>;
252		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
253				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
254				<IMX_LPCG_CLK_6>;
255		clock-output-names = "pwm3_lpcg_ipg_clk",
256				     "pwm3_lpcg_ipg_hf_clk",
257				     "pwm3_lpcg_ipg_s_clk",
258				     "pwm3_lpcg_ipg_slv_clk",
259				     "pwm3_lpcg_ipg_mstr_clk";
260		power-domains = <&pd IMX_SC_R_PWM_3>;
261	};
262
263	pwm4_lpcg: clock-controller@5d440000 {
264		compatible = "fsl,imx8qxp-lpcg";
265		reg = <0x5d440000 0x10000>;
266		#clock-cells = <1>;
267		clocks = <&clk IMX_SC_R_PWM_4 IMX_SC_PM_CLK_PER>,
268			 <&clk IMX_SC_R_PWM_4 IMX_SC_PM_CLK_PER>,
269			 <&clk IMX_SC_R_PWM_4 IMX_SC_PM_CLK_PER>,
270			 <&lsio_bus_clk>,
271			 <&clk IMX_SC_R_PWM_4 IMX_SC_PM_CLK_PER>;
272		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
273				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
274				<IMX_LPCG_CLK_6>;
275		clock-output-names = "pwm4_lpcg_ipg_clk",
276				     "pwm4_lpcg_ipg_hf_clk",
277				     "pwm4_lpcg_ipg_s_clk",
278				     "pwm4_lpcg_ipg_slv_clk",
279				     "pwm4_lpcg_ipg_mstr_clk";
280		power-domains = <&pd IMX_SC_R_PWM_4>;
281	};
282
283	pwm5_lpcg: clock-controller@5d450000 {
284		compatible = "fsl,imx8qxp-lpcg";
285		reg = <0x5d450000 0x10000>;
286		#clock-cells = <1>;
287		clocks = <&clk IMX_SC_R_PWM_5 IMX_SC_PM_CLK_PER>,
288			 <&clk IMX_SC_R_PWM_5 IMX_SC_PM_CLK_PER>,
289			 <&clk IMX_SC_R_PWM_5 IMX_SC_PM_CLK_PER>,
290			 <&lsio_bus_clk>,
291			 <&clk IMX_SC_R_PWM_5 IMX_SC_PM_CLK_PER>;
292		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
293				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
294				<IMX_LPCG_CLK_6>;
295		clock-output-names = "pwm5_lpcg_ipg_clk",
296				     "pwm5_lpcg_ipg_hf_clk",
297				     "pwm5_lpcg_ipg_s_clk",
298				     "pwm5_lpcg_ipg_slv_clk",
299				     "pwm5_lpcg_ipg_mstr_clk";
300		power-domains = <&pd IMX_SC_R_PWM_5>;
301	};
302
303	pwm6_lpcg: clock-controller@5d460000 {
304		compatible = "fsl,imx8qxp-lpcg";
305		reg = <0x5d460000 0x10000>;
306		#clock-cells = <1>;
307		clocks = <&clk IMX_SC_R_PWM_6 IMX_SC_PM_CLK_PER>,
308			 <&clk IMX_SC_R_PWM_6 IMX_SC_PM_CLK_PER>,
309			 <&clk IMX_SC_R_PWM_6 IMX_SC_PM_CLK_PER>,
310			 <&lsio_bus_clk>,
311			 <&clk IMX_SC_R_PWM_6 IMX_SC_PM_CLK_PER>;
312		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
313				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
314				<IMX_LPCG_CLK_6>;
315		clock-output-names = "pwm6_lpcg_ipg_clk",
316				     "pwm6_lpcg_ipg_hf_clk",
317				     "pwm6_lpcg_ipg_s_clk",
318				     "pwm6_lpcg_ipg_slv_clk",
319				     "pwm6_lpcg_ipg_mstr_clk";
320		power-domains = <&pd IMX_SC_R_PWM_6>;
321	};
322
323	pwm7_lpcg: clock-controller@5d470000 {
324		compatible = "fsl,imx8qxp-lpcg";
325		reg = <0x5d470000 0x10000>;
326		#clock-cells = <1>;
327		clocks = <&clk IMX_SC_R_PWM_7 IMX_SC_PM_CLK_PER>,
328			 <&clk IMX_SC_R_PWM_7 IMX_SC_PM_CLK_PER>,
329			 <&clk IMX_SC_R_PWM_7 IMX_SC_PM_CLK_PER>,
330			 <&lsio_bus_clk>,
331			 <&clk IMX_SC_R_PWM_7 IMX_SC_PM_CLK_PER>;
332		clock-indices = <IMX_LPCG_CLK_0>, <IMX_LPCG_CLK_1>,
333				<IMX_LPCG_CLK_4>, <IMX_LPCG_CLK_5>,
334				<IMX_LPCG_CLK_6>;
335		clock-output-names = "pwm7_lpcg_ipg_clk",
336				     "pwm7_lpcg_ipg_hf_clk",
337				     "pwm7_lpcg_ipg_s_clk",
338				     "pwm7_lpcg_ipg_slv_clk",
339				     "pwm7_lpcg_ipg_mstr_clk";
340		power-domains = <&pd IMX_SC_R_PWM_7>;
341	};
342};
343