2 * Spreadtrum Whale2 platform peripherals
4 * Copyright (C) 2016, Spreadtrum Communications Inc.
6 * SPDX-License-Identifier: (GPL-2.0+ OR MIT)
9 #include <dt-bindings/clock/sprd,sc9860-clk.h>
12 interrupt-parent = <&gic>;
17 compatible = "simple-bus";
22 ap_ahb_regs: syscon@20210000 {
23 compatible = "syscon";
24 reg = <0 0x20210000 0 0x10000>;
27 pmu_regs: syscon@402b0000 {
28 compatible = "syscon";
29 reg = <0 0x402b0000 0 0x10000>;
32 aon_regs: syscon@402e0000 {
33 compatible = "syscon";
34 reg = <0 0x402e0000 0 0x10000>;
37 ana_regs: syscon@40400000 {
38 compatible = "syscon";
39 reg = <0 0x40400000 0 0x10000>;
42 agcp_regs: syscon@415e0000 {
43 compatible = "syscon";
44 reg = <0 0x415e0000 0 0x1000000>;
47 vsp_regs: syscon@61100000 {
48 compatible = "syscon";
49 reg = <0 0x61100000 0 0x10000>;
52 cam_regs: syscon@62100000 {
53 compatible = "syscon";
54 reg = <0 0x62100000 0 0x10000>;
57 disp_regs: syscon@63100000 {
58 compatible = "syscon";
59 reg = <0 0x63100000 0 0x10000>;
62 ap_apb_regs: syscon@70b00000 {
63 compatible = "syscon";
64 reg = <0 0x70b00000 0 0x40000>;
68 compatible = "simple-bus";
71 ranges = <0 0x0 0x70000000 0x10000000>;
74 compatible = "sprd,sc9860-uart",
77 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
78 clock-names = "enable", "uart", "source";
79 clocks = <&apapb_gate CLK_UART0_EB>,
80 <&ap_clk CLK_UART0>, <&ext_26m>;
84 uart1: serial@100000 {
85 compatible = "sprd,sc9860-uart",
87 reg = <0x100000 0x100>;
88 interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
89 clock-names = "enable", "uart", "source";
90 clocks = <&apapb_gate CLK_UART1_EB>,
91 <&ap_clk CLK_UART1>, <&ext_26m>;
95 uart2: serial@200000 {
96 compatible = "sprd,sc9860-uart",
98 reg = <0x200000 0x100>;
99 interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
100 clock-names = "enable", "uart", "source";
101 clocks = <&apapb_gate CLK_UART2_EB>,
102 <&ap_clk CLK_UART2>, <&ext_26m>;
106 uart3: serial@300000 {
107 compatible = "sprd,sc9860-uart",
109 reg = <0x300000 0x100>;
110 interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
111 clock-names = "enable", "uart", "source";
112 clocks = <&apapb_gate CLK_UART3_EB>,
113 <&ap_clk CLK_UART3>, <&ext_26m>;
119 compatible = "simple-bus";
120 #address-cells = <2>;
124 ap_dma: dma-controller@20100000 {
125 compatible = "sprd,sc9860-dma";
126 reg = <0 0x20100000 0 0x4000>;
127 interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
129 #dma-channels = <32>;
130 clock-names = "enable";
131 clocks = <&apahb_gate CLK_DMA_EB>;
136 compatible = "simple-bus";
137 #address-cells = <2>;
141 adi_bus: spi@40030000 {
142 compatible = "sprd,sc9860-adi";
143 reg = <0 0x40030000 0 0x10000>;
144 hwlocks = <&hwlock 0>;
145 hwlock-names = "adi";
146 #address-cells = <1>;
151 compatible = "sprd,sc9860-timer";
152 reg = <0 0x40050000 0 0x20>;
153 interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
158 compatible = "sprd,sc9860-suspend-timer";
159 reg = <0 0x40050020 0 0x20>;
163 hwlock: hwspinlock@40500000 {
164 compatible = "sprd,hwspinlock-r3p0";
165 reg = <0 0x40500000 0 0x1000>;
167 clock-names = "enable";
168 clocks = <&aon_gate CLK_SPLK_EB>;
171 eic_debounce: gpio@40210000 {
172 compatible = "sprd,sc9860-eic-debounce";
173 reg = <0 0x40210000 0 0x80>;
176 interrupt-controller;
177 #interrupt-cells = <2>;
178 interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
181 eic_latch: gpio@40210080 {
182 compatible = "sprd,sc9860-eic-latch";
183 reg = <0 0x40210080 0 0x20>;
186 interrupt-controller;
187 #interrupt-cells = <2>;
188 interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
191 eic_async: gpio@402100a0 {
192 compatible = "sprd,sc9860-eic-async";
193 reg = <0 0x402100a0 0 0x20>;
196 interrupt-controller;
197 #interrupt-cells = <2>;
198 interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
201 eic_sync: gpio@402100c0 {
202 compatible = "sprd,sc9860-eic-sync";
203 reg = <0 0x402100c0 0 0x20>;
206 interrupt-controller;
207 #interrupt-cells = <2>;
208 interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
211 ap_gpio: gpio@40280000 {
212 compatible = "sprd,sc9860-gpio";
213 reg = <0 0x40280000 0 0x1000>;
216 interrupt-controller;
217 #interrupt-cells = <2>;
218 interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
221 pin_controller: pinctrl@402a0000 {
222 compatible = "sprd,sc9860-pinctrl";
223 reg = <0 0x402a0000 0 0x10000>;
227 compatible = "sprd,sp9860-wdt";
228 reg = <0 0x40310000 0 0x1000>;
229 interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
231 clock-names = "enable", "rtc_enable";
232 clocks = <&aon_gate CLK_APCPU_WDG_EB>,
233 <&aon_gate CLK_AP_WDG_RTC_EB>;
238 compatible = "simple-bus";
239 #address-cells = <2>;
243 agcp_dma: dma-controller@41580000 {
244 compatible = "sprd,sc9860-dma";
245 reg = <0 0x41580000 0 0x4000>;
247 #dma-channels = <32>;
248 clock-names = "enable", "ashb_eb";
249 clocks = <&agcp_gate CLK_AGCP_DMAAP_EB>,
250 <&agcp_gate CLK_AGCP_AP_ASHB_EB>;
256 compatible = "fixed-clock";
258 clock-frequency = <32768>;
259 clock-output-names = "ext-32k";
263 compatible = "fixed-clock";
265 clock-frequency = <26000000>;
266 clock-output-names = "ext-26m";
269 ext_rco_100m: ext_rco_100m {
270 compatible = "fixed-clock";
272 clock-frequency = <100000000>;
273 clock-output-names = "ext-rco-100m";