13c0e3abdSOrson Zhai/* 23c0e3abdSOrson Zhai * Spreadtrum Whale2 platform peripherals 33c0e3abdSOrson Zhai * 43c0e3abdSOrson Zhai * Copyright (C) 2016, Spreadtrum Communications Inc. 53c0e3abdSOrson Zhai * 63c0e3abdSOrson Zhai * SPDX-License-Identifier: (GPL-2.0+ OR MIT) 73c0e3abdSOrson Zhai */ 83c0e3abdSOrson Zhai 96c6fbbd1SBaolin Wang#include <dt-bindings/clock/sprd,sc9860-clk.h> 106c6fbbd1SBaolin Wang 113c0e3abdSOrson Zhai/ { 123c0e3abdSOrson Zhai interrupt-parent = <&gic>; 133c0e3abdSOrson Zhai #address-cells = <2>; 143c0e3abdSOrson Zhai #size-cells = <2>; 153c0e3abdSOrson Zhai 163c0e3abdSOrson Zhai soc: soc { 173c0e3abdSOrson Zhai compatible = "simple-bus"; 183c0e3abdSOrson Zhai #address-cells = <2>; 193c0e3abdSOrson Zhai #size-cells = <2>; 203c0e3abdSOrson Zhai ranges; 213c0e3abdSOrson Zhai 2233d3ebd4SChunyan Zhang ap_ahb_regs: syscon@20210000 { 2333d3ebd4SChunyan Zhang compatible = "syscon"; 2433d3ebd4SChunyan Zhang reg = <0 0x20210000 0 0x10000>; 2533d3ebd4SChunyan Zhang }; 2633d3ebd4SChunyan Zhang 2733d3ebd4SChunyan Zhang pmu_regs: syscon@402b0000 { 2833d3ebd4SChunyan Zhang compatible = "syscon"; 2933d3ebd4SChunyan Zhang reg = <0 0x402b0000 0 0x10000>; 3033d3ebd4SChunyan Zhang }; 3133d3ebd4SChunyan Zhang 3233d3ebd4SChunyan Zhang aon_regs: syscon@402e0000 { 3333d3ebd4SChunyan Zhang compatible = "syscon"; 3433d3ebd4SChunyan Zhang reg = <0 0x402e0000 0 0x10000>; 3533d3ebd4SChunyan Zhang }; 3633d3ebd4SChunyan Zhang 3733d3ebd4SChunyan Zhang ana_regs: syscon@40400000 { 3833d3ebd4SChunyan Zhang compatible = "syscon"; 3933d3ebd4SChunyan Zhang reg = <0 0x40400000 0 0x10000>; 4033d3ebd4SChunyan Zhang }; 4133d3ebd4SChunyan Zhang 4233d3ebd4SChunyan Zhang agcp_regs: syscon@415e0000 { 4333d3ebd4SChunyan Zhang compatible = "syscon"; 4433d3ebd4SChunyan Zhang reg = <0 0x415e0000 0 0x1000000>; 4533d3ebd4SChunyan Zhang }; 4633d3ebd4SChunyan Zhang 4733d3ebd4SChunyan Zhang vsp_regs: syscon@61100000 { 4833d3ebd4SChunyan Zhang compatible = "syscon"; 4933d3ebd4SChunyan Zhang reg = <0 0x61100000 0 0x10000>; 5033d3ebd4SChunyan Zhang }; 5133d3ebd4SChunyan Zhang 5233d3ebd4SChunyan Zhang cam_regs: syscon@62100000 { 5333d3ebd4SChunyan Zhang compatible = "syscon"; 5433d3ebd4SChunyan Zhang reg = <0 0x62100000 0 0x10000>; 5533d3ebd4SChunyan Zhang }; 5633d3ebd4SChunyan Zhang 5733d3ebd4SChunyan Zhang disp_regs: syscon@63100000 { 5833d3ebd4SChunyan Zhang compatible = "syscon"; 5933d3ebd4SChunyan Zhang reg = <0 0x63100000 0 0x10000>; 6033d3ebd4SChunyan Zhang }; 6133d3ebd4SChunyan Zhang 6233d3ebd4SChunyan Zhang ap_apb_regs: syscon@70b00000 { 6333d3ebd4SChunyan Zhang compatible = "syscon"; 6433d3ebd4SChunyan Zhang reg = <0 0x70b00000 0 0x40000>; 6533d3ebd4SChunyan Zhang }; 6633d3ebd4SChunyan Zhang 673c0e3abdSOrson Zhai ap-apb { 683c0e3abdSOrson Zhai compatible = "simple-bus"; 693c0e3abdSOrson Zhai #address-cells = <1>; 703c0e3abdSOrson Zhai #size-cells = <1>; 713c0e3abdSOrson Zhai ranges = <0 0x0 0x70000000 0x10000000>; 723c0e3abdSOrson Zhai 733c0e3abdSOrson Zhai uart0: serial@0 { 743c0e3abdSOrson Zhai compatible = "sprd,sc9860-uart", 753c0e3abdSOrson Zhai "sprd,sc9836-uart"; 763c0e3abdSOrson Zhai reg = <0x0 0x100>; 773c0e3abdSOrson Zhai interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; 7815d574fbSBaolin Wang clock-names = "enable", "uart", "source"; 7915d574fbSBaolin Wang clocks = <&apapb_gate CLK_UART0_EB>, 8015d574fbSBaolin Wang <&ap_clk CLK_UART0>, <&ext_26m>; 813c0e3abdSOrson Zhai status = "disabled"; 823c0e3abdSOrson Zhai }; 833c0e3abdSOrson Zhai 843c0e3abdSOrson Zhai uart1: serial@100000 { 853c0e3abdSOrson Zhai compatible = "sprd,sc9860-uart", 863c0e3abdSOrson Zhai "sprd,sc9836-uart"; 873c0e3abdSOrson Zhai reg = <0x100000 0x100>; 883c0e3abdSOrson Zhai interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>; 8915d574fbSBaolin Wang clock-names = "enable", "uart", "source"; 9015d574fbSBaolin Wang clocks = <&apapb_gate CLK_UART1_EB>, 9115d574fbSBaolin Wang <&ap_clk CLK_UART1>, <&ext_26m>; 923c0e3abdSOrson Zhai status = "disabled"; 933c0e3abdSOrson Zhai }; 943c0e3abdSOrson Zhai 953c0e3abdSOrson Zhai uart2: serial@200000 { 963c0e3abdSOrson Zhai compatible = "sprd,sc9860-uart", 973c0e3abdSOrson Zhai "sprd,sc9836-uart"; 983c0e3abdSOrson Zhai reg = <0x200000 0x100>; 993c0e3abdSOrson Zhai interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>; 10015d574fbSBaolin Wang clock-names = "enable", "uart", "source"; 10115d574fbSBaolin Wang clocks = <&apapb_gate CLK_UART2_EB>, 10215d574fbSBaolin Wang <&ap_clk CLK_UART2>, <&ext_26m>; 1033c0e3abdSOrson Zhai status = "disabled"; 1043c0e3abdSOrson Zhai }; 1053c0e3abdSOrson Zhai 1063c0e3abdSOrson Zhai uart3: serial@300000 { 1073c0e3abdSOrson Zhai compatible = "sprd,sc9860-uart", 1083c0e3abdSOrson Zhai "sprd,sc9836-uart"; 1093c0e3abdSOrson Zhai reg = <0x300000 0x100>; 1103c0e3abdSOrson Zhai interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>; 11115d574fbSBaolin Wang clock-names = "enable", "uart", "source"; 11215d574fbSBaolin Wang clocks = <&apapb_gate CLK_UART3_EB>, 11315d574fbSBaolin Wang <&ap_clk CLK_UART3>, <&ext_26m>; 1143c0e3abdSOrson Zhai status = "disabled"; 1153c0e3abdSOrson Zhai }; 1163c0e3abdSOrson Zhai }; 1176c6fbbd1SBaolin Wang 118258e1ae6SBaolin Wang ap-ahb { 119258e1ae6SBaolin Wang compatible = "simple-bus"; 120258e1ae6SBaolin Wang #address-cells = <2>; 121258e1ae6SBaolin Wang #size-cells = <2>; 122258e1ae6SBaolin Wang ranges; 123258e1ae6SBaolin Wang 124258e1ae6SBaolin Wang ap_dma: dma-controller@20100000 { 125258e1ae6SBaolin Wang compatible = "sprd,sc9860-dma"; 126258e1ae6SBaolin Wang reg = <0 0x20100000 0 0x4000>; 127258e1ae6SBaolin Wang interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>; 128258e1ae6SBaolin Wang #dma-cells = <1>; 129258e1ae6SBaolin Wang #dma-channels = <32>; 130258e1ae6SBaolin Wang clock-names = "enable"; 131258e1ae6SBaolin Wang clocks = <&apahb_gate CLK_DMA_EB>; 132258e1ae6SBaolin Wang }; 133258e1ae6SBaolin Wang }; 134258e1ae6SBaolin Wang 1356c6fbbd1SBaolin Wang aon { 1366c6fbbd1SBaolin Wang compatible = "simple-bus"; 1376c6fbbd1SBaolin Wang #address-cells = <2>; 1386c6fbbd1SBaolin Wang #size-cells = <2>; 1396c6fbbd1SBaolin Wang ranges; 1406c6fbbd1SBaolin Wang 141e254460aSBaolin Wang adi_bus: spi@40030000 { 142e254460aSBaolin Wang compatible = "sprd,sc9860-adi"; 143e254460aSBaolin Wang reg = <0 0x40030000 0 0x10000>; 144e254460aSBaolin Wang hwlocks = <&hwlock 0>; 145e254460aSBaolin Wang hwlock-names = "adi"; 146e254460aSBaolin Wang #address-cells = <1>; 147e254460aSBaolin Wang #size-cells = <0>; 148e254460aSBaolin Wang }; 149e254460aSBaolin Wang 1500cb3dad0SBaolin Wang timer@40050000 { 1510cb3dad0SBaolin Wang compatible = "sprd,sc9860-timer"; 1520cb3dad0SBaolin Wang reg = <0 0x40050000 0 0x20>; 1530cb3dad0SBaolin Wang interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>; 1540cb3dad0SBaolin Wang clocks = <&ext_32k>; 1550cb3dad0SBaolin Wang }; 1560cb3dad0SBaolin Wang 157b2d94b3fSBaolin Wang timer@40050020 { 158b2d94b3fSBaolin Wang compatible = "sprd,sc9860-suspend-timer"; 159b2d94b3fSBaolin Wang reg = <0 0x40050020 0 0x20>; 160b2d94b3fSBaolin Wang clocks = <&ext_32k>; 161b2d94b3fSBaolin Wang }; 162b2d94b3fSBaolin Wang 1636c6fbbd1SBaolin Wang hwlock: hwspinlock@40500000 { 1646c6fbbd1SBaolin Wang compatible = "sprd,hwspinlock-r3p0"; 1656c6fbbd1SBaolin Wang reg = <0 0x40500000 0 0x1000>; 1666c6fbbd1SBaolin Wang #hwlock-cells = <1>; 1676c6fbbd1SBaolin Wang clock-names = "enable"; 1686c6fbbd1SBaolin Wang clocks = <&aon_gate CLK_SPLK_EB>; 1696c6fbbd1SBaolin Wang }; 170d85bcd9cSBaolin Wang 1711cea2c22SBaolin Wang eic_debounce: gpio@40210000 { 1721cea2c22SBaolin Wang compatible = "sprd,sc9860-eic-debounce"; 1731cea2c22SBaolin Wang reg = <0 0x40210000 0 0x80>; 1741cea2c22SBaolin Wang gpio-controller; 1751cea2c22SBaolin Wang #gpio-cells = <2>; 1761cea2c22SBaolin Wang interrupt-controller; 1771cea2c22SBaolin Wang #interrupt-cells = <2>; 1781cea2c22SBaolin Wang interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>; 1791cea2c22SBaolin Wang }; 1801cea2c22SBaolin Wang 1811cea2c22SBaolin Wang eic_latch: gpio@40210080 { 1821cea2c22SBaolin Wang compatible = "sprd,sc9860-eic-latch"; 1831cea2c22SBaolin Wang reg = <0 0x40210080 0 0x20>; 1841cea2c22SBaolin Wang gpio-controller; 1851cea2c22SBaolin Wang #gpio-cells = <2>; 1861cea2c22SBaolin Wang interrupt-controller; 1871cea2c22SBaolin Wang #interrupt-cells = <2>; 1881cea2c22SBaolin Wang interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>; 1891cea2c22SBaolin Wang }; 1901cea2c22SBaolin Wang 1911cea2c22SBaolin Wang eic_async: gpio@402100a0 { 1921cea2c22SBaolin Wang compatible = "sprd,sc9860-eic-async"; 1931cea2c22SBaolin Wang reg = <0 0x402100a0 0 0x20>; 1941cea2c22SBaolin Wang gpio-controller; 1951cea2c22SBaolin Wang #gpio-cells = <2>; 1961cea2c22SBaolin Wang interrupt-controller; 1971cea2c22SBaolin Wang #interrupt-cells = <2>; 1981cea2c22SBaolin Wang interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>; 1991cea2c22SBaolin Wang }; 2001cea2c22SBaolin Wang 2011cea2c22SBaolin Wang eic_sync: gpio@402100c0 { 2021cea2c22SBaolin Wang compatible = "sprd,sc9860-eic-sync"; 2031cea2c22SBaolin Wang reg = <0 0x402100c0 0 0x20>; 2041cea2c22SBaolin Wang gpio-controller; 2051cea2c22SBaolin Wang #gpio-cells = <2>; 2061cea2c22SBaolin Wang interrupt-controller; 2071cea2c22SBaolin Wang #interrupt-cells = <2>; 2081cea2c22SBaolin Wang interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>; 2091cea2c22SBaolin Wang }; 2101cea2c22SBaolin Wang 2111cea2c22SBaolin Wang ap_gpio: gpio@40280000 { 2121cea2c22SBaolin Wang compatible = "sprd,sc9860-gpio"; 2131cea2c22SBaolin Wang reg = <0 0x40280000 0 0x1000>; 2141cea2c22SBaolin Wang gpio-controller; 2151cea2c22SBaolin Wang #gpio-cells = <2>; 2161cea2c22SBaolin Wang interrupt-controller; 2171cea2c22SBaolin Wang #interrupt-cells = <2>; 2181cea2c22SBaolin Wang interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>; 2191cea2c22SBaolin Wang }; 2201cea2c22SBaolin Wang 221d85bcd9cSBaolin Wang pin_controller: pinctrl@402a0000 { 222d85bcd9cSBaolin Wang compatible = "sprd,sc9860-pinctrl"; 223d85bcd9cSBaolin Wang reg = <0 0x402a0000 0 0x10000>; 224d85bcd9cSBaolin Wang }; 2254f681369SBaolin Wang 2264f681369SBaolin Wang watchdog@40310000 { 2274f681369SBaolin Wang compatible = "sprd,sp9860-wdt"; 2284f681369SBaolin Wang reg = <0 0x40310000 0 0x1000>; 2294f681369SBaolin Wang interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>; 2304f681369SBaolin Wang timeout-sec = <12>; 23121a9883fSBaolin Wang clock-names = "enable", "rtc_enable"; 23221a9883fSBaolin Wang clocks = <&aon_gate CLK_APCPU_WDG_EB>, 23321a9883fSBaolin Wang <&aon_gate CLK_AP_WDG_RTC_EB>; 2344f681369SBaolin Wang }; 2356c6fbbd1SBaolin Wang }; 236258e1ae6SBaolin Wang 237258e1ae6SBaolin Wang agcp { 238258e1ae6SBaolin Wang compatible = "simple-bus"; 239258e1ae6SBaolin Wang #address-cells = <2>; 240258e1ae6SBaolin Wang #size-cells = <2>; 241258e1ae6SBaolin Wang ranges; 242258e1ae6SBaolin Wang 243258e1ae6SBaolin Wang agcp_dma: dma-controller@41580000 { 244258e1ae6SBaolin Wang compatible = "sprd,sc9860-dma"; 245258e1ae6SBaolin Wang reg = <0 0x41580000 0 0x4000>; 246258e1ae6SBaolin Wang #dma-cells = <1>; 247258e1ae6SBaolin Wang #dma-channels = <32>; 248258e1ae6SBaolin Wang clock-names = "enable", "ashb_eb"; 249258e1ae6SBaolin Wang clocks = <&agcp_gate CLK_AGCP_DMAAP_EB>, 250258e1ae6SBaolin Wang <&agcp_gate CLK_AGCP_AP_ASHB_EB>; 251258e1ae6SBaolin Wang }; 252258e1ae6SBaolin Wang }; 2533c0e3abdSOrson Zhai }; 2543c0e3abdSOrson Zhai 25522f37a24SChunyan Zhang ext_32k: ext_32k { 25622f37a24SChunyan Zhang compatible = "fixed-clock"; 25722f37a24SChunyan Zhang #clock-cells = <0>; 25822f37a24SChunyan Zhang clock-frequency = <32768>; 25922f37a24SChunyan Zhang clock-output-names = "ext-32k"; 26022f37a24SChunyan Zhang }; 26122f37a24SChunyan Zhang 26222f37a24SChunyan Zhang ext_26m: ext_26m { 2633c0e3abdSOrson Zhai compatible = "fixed-clock"; 2643c0e3abdSOrson Zhai #clock-cells = <0>; 2653c0e3abdSOrson Zhai clock-frequency = <26000000>; 26622f37a24SChunyan Zhang clock-output-names = "ext-26m"; 26722f37a24SChunyan Zhang }; 26822f37a24SChunyan Zhang 26922f37a24SChunyan Zhang ext_rco_100m: ext_rco_100m { 27022f37a24SChunyan Zhang compatible = "fixed-clock"; 27122f37a24SChunyan Zhang #clock-cells = <0>; 27222f37a24SChunyan Zhang clock-frequency = <100000000>; 27322f37a24SChunyan Zhang clock-output-names = "ext-rco-100m"; 2743c0e3abdSOrson Zhai }; 2753c0e3abdSOrson Zhai}; 276