// SPDX-License-Identifier: GPL-2.0+ /* * Copyright (C) 2016 Freescale Semiconductor, Inc. * Copyright 2017-2018 NXP * Dong Aisheng */ #include #include #include #include "imx7ulp-pinfunc.h" / { interrupt-parent = <&intc>; #address-cells = <1>; #size-cells = <1>; aliases { gpio0 = &gpio_ptc; gpio1 = &gpio_ptd; gpio2 = &gpio_pte; gpio3 = &gpio_ptf; i2c0 = &lpi2c6; i2c1 = &lpi2c7; mmc0 = &usdhc0; mmc1 = &usdhc1; serial0 = &lpuart4; serial1 = &lpuart5; serial2 = &lpuart6; serial3 = &lpuart7; usbphy0 = &usbphy1; }; cpus { #address-cells = <1>; #size-cells = <0>; cpu0: cpu@f00 { compatible = "arm,cortex-a7"; device_type = "cpu"; reg = <0xf00>; }; }; intc: interrupt-controller@40021000 { compatible = "arm,cortex-a7-gic"; #interrupt-cells = <3>; interrupt-controller; reg = <0x40021000 0x1000>, <0x40022000 0x1000>; }; rosc: clock-rosc { compatible = "fixed-clock"; clock-frequency = <32768>; clock-output-names = "rosc"; #clock-cells = <0>; }; sosc: clock-sosc { compatible = "fixed-clock"; clock-frequency = <24000000>; clock-output-names = "sosc"; #clock-cells = <0>; }; sirc: clock-sirc { compatible = "fixed-clock"; clock-frequency = <16000000>; clock-output-names = "sirc"; #clock-cells = <0>; }; firc: clock-firc { compatible = "fixed-clock"; clock-frequency = <48000000>; clock-output-names = "firc"; #clock-cells = <0>; }; upll: clock-upll { compatible = "fixed-clock"; clock-frequency = <480000000>; clock-output-names = "upll"; #clock-cells = <0>; }; ahbbridge0: bus@40000000 { compatible = "simple-bus"; #address-cells = <1>; #size-cells = <1>; reg = <0x40000000 0x800000>; ranges; edma1: dma-controller@40080000 { #dma-cells = <2>; compatible = "fsl,imx7ulp-edma"; reg = <0x40080000 0x2000>, <0x40210000 0x1000>; dma-channels = <32>; interrupts = , , , , , , , , , , , , , , , , ; clock-names = "dma", "dmamux0"; clocks = <&pcc2 IMX7ULP_CLK_DMA1>, <&pcc2 IMX7ULP_CLK_DMA_MUX1>; }; crypto: crypto@40240000 { compatible = "fsl,sec-v4.0"; #address-cells = <1>; #size-cells = <1>; reg = <0x40240000 0x10000>; ranges = <0 0x40240000 0x10000>; clocks = <&pcc2 IMX7ULP_CLK_CAAM>, <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>; clock-names = "aclk", "ipg"; sec_jr0: jr@1000 { compatible = "fsl,sec-v4.0-job-ring"; reg = <0x1000 0x1000>; interrupts = ; }; sec_jr1: jr@2000 { compatible = "fsl,sec-v4.0-job-ring"; reg = <0x2000 0x1000>; interrupts = ; }; }; lpuart4: serial@402d0000 { compatible = "fsl,imx7ulp-lpuart"; reg = <0x402d0000 0x1000>; interrupts = ; clocks = <&pcc2 IMX7ULP_CLK_LPUART4>; clock-names = "ipg"; assigned-clocks = <&pcc2 IMX7ULP_CLK_LPUART4>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>; assigned-clock-rates = <24000000>; status = "disabled"; }; lpuart5: serial@402e0000 { compatible = "fsl,imx7ulp-lpuart"; reg = <0x402e0000 0x1000>; interrupts = ; clocks = <&pcc2 IMX7ULP_CLK_LPUART5>; clock-names = "ipg"; assigned-clocks = <&pcc2 IMX7ULP_CLK_LPUART5>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>; assigned-clock-rates = <48000000>; status = "disabled"; }; tpm4: pwm@40250000 { compatible = "fsl,imx7ulp-pwm"; reg = <0x40250000 0x1000>; assigned-clocks = <&pcc2 IMX7ULP_CLK_LPTPM4>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>; clocks = <&pcc2 IMX7ULP_CLK_LPTPM4>; #pwm-cells = <3>; status = "disabled"; }; tpm5: tpm@40260000 { compatible = "fsl,imx7ulp-tpm"; reg = <0x40260000 0x1000>; interrupts = ; clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>, <&pcc2 IMX7ULP_CLK_LPTPM5>; clock-names = "ipg", "per"; }; usbotg1: usb@40330000 { compatible = "fsl,imx7ulp-usb", "fsl,imx6ul-usb", "fsl,imx27-usb"; reg = <0x40330000 0x200>; interrupts = ; clocks = <&pcc2 IMX7ULP_CLK_USB0>; phys = <&usbphy1>; fsl,usbmisc = <&usbmisc1 0>; ahb-burst-config = <0x0>; tx-burst-size-dword = <0x8>; rx-burst-size-dword = <0x8>; status = "disabled"; }; usbmisc1: usbmisc@40330200 { compatible = "fsl,imx7ulp-usbmisc", "fsl,imx7d-usbmisc", "fsl,imx6q-usbmisc"; #index-cells = <1>; reg = <0x40330200 0x200>; }; usbphy1: usb-phy@40350000 { compatible = "fsl,imx7ulp-usbphy"; reg = <0x40350000 0x1000>; interrupts = ; clocks = <&pcc2 IMX7ULP_CLK_USB_PHY>; #phy-cells = <0>; nxp,sim = <&sim>; }; usdhc0: mmc@40370000 { compatible = "fsl,imx7ulp-usdhc"; reg = <0x40370000 0x10000>; interrupts = ; clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>, <&scg1 IMX7ULP_CLK_NIC1_DIV>, <&pcc2 IMX7ULP_CLK_USDHC0>; clock-names = "ipg", "ahb", "per"; bus-width = <4>; fsl,tuning-start-tap = <20>; fsl,tuning-step = <2>; status = "disabled"; }; usdhc1: mmc@40380000 { compatible = "fsl,imx7ulp-usdhc"; reg = <0x40380000 0x10000>; interrupts = ; clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>, <&scg1 IMX7ULP_CLK_NIC1_DIV>, <&pcc2 IMX7ULP_CLK_USDHC1>; clock-names = "ipg", "ahb", "per"; bus-width = <4>; fsl,tuning-start-tap = <20>; fsl,tuning-step = <2>; status = "disabled"; }; scg1: clock-controller@403e0000 { compatible = "fsl,imx7ulp-scg1"; reg = <0x403e0000 0x10000>; clocks = <&rosc>, <&sosc>, <&sirc>, <&firc>, <&upll>; clock-names = "rosc", "sosc", "sirc", "firc", "upll"; #clock-cells = <1>; }; wdog1: watchdog@403d0000 { compatible = "fsl,imx7ulp-wdt"; reg = <0x403d0000 0x10000>; interrupts = ; clocks = <&pcc2 IMX7ULP_CLK_WDG1>; assigned-clocks = <&pcc2 IMX7ULP_CLK_WDG1>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC_BUS_CLK>; timeout-sec = <40>; }; pcc2: clock-controller@403f0000 { compatible = "fsl,imx7ulp-pcc2"; reg = <0x403f0000 0x10000>; #clock-cells = <1>; clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>, <&scg1 IMX7ULP_CLK_NIC1_DIV>, <&scg1 IMX7ULP_CLK_DDR_DIV>, <&scg1 IMX7ULP_CLK_APLL_PFD2>, <&scg1 IMX7ULP_CLK_APLL_PFD1>, <&scg1 IMX7ULP_CLK_APLL_PFD0>, <&scg1 IMX7ULP_CLK_UPLL>, <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>, <&scg1 IMX7ULP_CLK_FIRC_BUS_CLK>, <&scg1 IMX7ULP_CLK_ROSC>, <&scg1 IMX7ULP_CLK_SPLL_BUS_CLK>; clock-names = "nic1_bus_clk", "nic1_clk", "ddr_clk", "apll_pfd2", "apll_pfd1", "apll_pfd0", "upll", "sosc_bus_clk", "firc_bus_clk", "rosc", "spll_bus_clk"; assigned-clocks = <&pcc2 IMX7ULP_CLK_LPTPM5>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>; }; smc1: clock-controller@40410000 { compatible = "fsl,imx7ulp-smc1"; reg = <0x40410000 0x1000>; #clock-cells = <1>; clocks = <&scg1 IMX7ULP_CLK_CORE_DIV>, <&scg1 IMX7ULP_CLK_HSRUN_CORE_DIV>; clock-names = "divcore", "hsrun_divcore"; }; pcc3: clock-controller@40b30000 { compatible = "fsl,imx7ulp-pcc3"; reg = <0x40b30000 0x10000>; #clock-cells = <1>; clocks = <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>, <&scg1 IMX7ULP_CLK_NIC1_DIV>, <&scg1 IMX7ULP_CLK_DDR_DIV>, <&scg1 IMX7ULP_CLK_APLL_PFD2>, <&scg1 IMX7ULP_CLK_APLL_PFD1>, <&scg1 IMX7ULP_CLK_APLL_PFD0>, <&scg1 IMX7ULP_CLK_UPLL>, <&scg1 IMX7ULP_CLK_SOSC_BUS_CLK>, <&scg1 IMX7ULP_CLK_FIRC_BUS_CLK>, <&scg1 IMX7ULP_CLK_ROSC>, <&scg1 IMX7ULP_CLK_SPLL_BUS_CLK>; clock-names = "nic1_bus_clk", "nic1_clk", "ddr_clk", "apll_pfd2", "apll_pfd1", "apll_pfd0", "upll", "sosc_bus_clk", "firc_bus_clk", "rosc", "spll_bus_clk"; }; }; ahbbridge1: bus@40800000 { compatible = "simple-bus"; #address-cells = <1>; #size-cells = <1>; reg = <0x40800000 0x800000>; ranges; lpi2c6: i2c@40a40000 { compatible = "fsl,imx7ulp-lpi2c"; reg = <0x40a40000 0x10000>; interrupts = ; clocks = <&pcc3 IMX7ULP_CLK_LPI2C6>, <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>; clock-names = "per", "ipg"; assigned-clocks = <&pcc3 IMX7ULP_CLK_LPI2C6>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>; assigned-clock-rates = <48000000>; status = "disabled"; }; lpi2c7: i2c@40a50000 { compatible = "fsl,imx7ulp-lpi2c"; reg = <0x40a50000 0x10000>; interrupts = ; clocks = <&pcc3 IMX7ULP_CLK_LPI2C7>, <&scg1 IMX7ULP_CLK_NIC1_BUS_DIV>; clock-names = "per", "ipg"; assigned-clocks = <&pcc3 IMX7ULP_CLK_LPI2C7>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>; assigned-clock-rates = <48000000>; status = "disabled"; }; lpuart6: serial@40a60000 { compatible = "fsl,imx7ulp-lpuart"; reg = <0x40a60000 0x1000>; interrupts = ; clocks = <&pcc3 IMX7ULP_CLK_LPUART6>; clock-names = "ipg"; assigned-clocks = <&pcc3 IMX7ULP_CLK_LPUART6>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>; assigned-clock-rates = <48000000>; status = "disabled"; }; lpuart7: serial@40a70000 { compatible = "fsl,imx7ulp-lpuart"; reg = <0x40a70000 0x1000>; interrupts = ; clocks = <&pcc3 IMX7ULP_CLK_LPUART7>; clock-names = "ipg"; assigned-clocks = <&pcc3 IMX7ULP_CLK_LPUART7>; assigned-clock-parents = <&scg1 IMX7ULP_CLK_FIRC>; assigned-clock-rates = <48000000>; status = "disabled"; }; memory-controller@40ab0000 { compatible = "fsl,imx7ulp-mmdc", "fsl,imx6q-mmdc"; reg = <0x40ab0000 0x1000>; clocks = <&pcc3 IMX7ULP_CLK_MMDC>; }; iomuxc1: pinctrl@40ac0000 { compatible = "fsl,imx7ulp-iomuxc1"; reg = <0x40ac0000 0x1000>; }; gpio_ptc: gpio@40ae0000 { compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio"; reg = <0x40ae0000 0x1000 0x400f0000 0x40>; gpio-controller; #gpio-cells = <2>; interrupts = ; interrupt-controller; #interrupt-cells = <2>; clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>, <&pcc3 IMX7ULP_CLK_PCTLC>; clock-names = "gpio", "port"; gpio-ranges = <&iomuxc1 0 0 20>; }; gpio_ptd: gpio@40af0000 { compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio"; reg = <0x40af0000 0x1000 0x400f0040 0x40>; gpio-controller; #gpio-cells = <2>; interrupts = ; interrupt-controller; #interrupt-cells = <2>; clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>, <&pcc3 IMX7ULP_CLK_PCTLD>; clock-names = "gpio", "port"; gpio-ranges = <&iomuxc1 0 32 12>; }; gpio_pte: gpio@40b00000 { compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio"; reg = <0x40b00000 0x1000 0x400f0080 0x40>; gpio-controller; #gpio-cells = <2>; interrupts = ; interrupt-controller; #interrupt-cells = <2>; clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>, <&pcc3 IMX7ULP_CLK_PCTLE>; clock-names = "gpio", "port"; gpio-ranges = <&iomuxc1 0 64 16>; }; gpio_ptf: gpio@40b10000 { compatible = "fsl,imx7ulp-gpio", "fsl,vf610-gpio"; reg = <0x40b10000 0x1000 0x400f00c0 0x40>; gpio-controller; #gpio-cells = <2>; interrupts = ; interrupt-controller; #interrupt-cells = <2>; clocks = <&pcc2 IMX7ULP_CLK_RGPIO2P1>, <&pcc3 IMX7ULP_CLK_PCTLF>; clock-names = "gpio", "port"; gpio-ranges = <&iomuxc1 0 96 20>; }; }; m4aips1: bus@41080000 { compatible = "simple-bus"; #address-cells = <1>; #size-cells = <1>; reg = <0x41080000 0x80000>; ranges; sim: sim@410a3000 { compatible = "fsl,imx7ulp-sim", "syscon"; reg = <0x410a3000 0x1000>; }; ocotp: efuse@410a6000 { compatible = "fsl,imx7ulp-ocotp", "syscon"; reg = <0x410a6000 0x4000>; clocks = <&scg1 IMX7ULP_CLK_DUMMY>; #address-cells = <1>; #size-cells = <1>; }; }; };