Linux Audio

Check our new training course

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