// SPDX-License-Identifier: (GPL-2.0+ OR MIT) /* * Spreadtrum Whale2 platform peripherals * * Copyright (C) 2016, Spreadtrum Communications Inc. */ #include / { interrupt-parent = <&gic>; #address-cells = <2>; #size-cells = <2>; soc: soc { compatible = "simple-bus"; #address-cells = <2>; #size-cells = <2>; ranges; ap_ahb_regs: syscon@20210000 { compatible = "syscon"; reg = <0 0x20210000 0 0x10000>; }; pmu_regs: syscon@402b0000 { compatible = "syscon"; reg = <0 0x402b0000 0 0x10000>; }; aon_regs: syscon@402e0000 { compatible = "syscon"; reg = <0 0x402e0000 0 0x10000>; }; ana_regs: syscon@40400000 { compatible = "syscon"; reg = <0 0x40400000 0 0x10000>; }; agcp_regs: syscon@415e0000 { compatible = "syscon"; reg = <0 0x415e0000 0 0x1000000>; }; vsp_regs: syscon@61100000 { compatible = "syscon"; reg = <0 0x61100000 0 0x10000>; }; cam_regs: syscon@62100000 { compatible = "syscon"; reg = <0 0x62100000 0 0x10000>; }; disp_regs: syscon@63100000 { compatible = "syscon"; reg = <0 0x63100000 0 0x10000>; }; ap_apb_regs: syscon@70b00000 { compatible = "syscon"; reg = <0 0x70b00000 0 0x40000>; }; ap-apb@70000000 { compatible = "simple-bus"; #address-cells = <1>; #size-cells = <1>; ranges = <0 0x0 0x70000000 0x10000000>; uart0: serial@0 { compatible = "sprd,sc9860-uart", "sprd,sc9836-uart"; reg = <0x0 0x100>; interrupts = ; clocks = <&apapb_gate CLK_UART0_EB>, <&ap_clk CLK_UART0>, <&ext_26m>; clock-names = "enable", "uart", "source"; status = "disabled"; }; uart1: serial@100000 { compatible = "sprd,sc9860-uart", "sprd,sc9836-uart"; reg = <0x100000 0x100>; interrupts = ; clocks = <&apapb_gate CLK_UART1_EB>, <&ap_clk CLK_UART1>, <&ext_26m>; clock-names = "enable", "uart", "source"; status = "disabled"; }; uart2: serial@200000 { compatible = "sprd,sc9860-uart", "sprd,sc9836-uart"; reg = <0x200000 0x100>; interrupts = ; clocks = <&apapb_gate CLK_UART2_EB>, <&ap_clk CLK_UART2>, <&ext_26m>; clock-names = "enable", "uart", "source"; status = "disabled"; }; uart3: serial@300000 { compatible = "sprd,sc9860-uart", "sprd,sc9836-uart"; reg = <0x300000 0x100>; interrupts = ; clocks = <&apapb_gate CLK_UART3_EB>, <&ap_clk CLK_UART3>, <&ext_26m>; clock-names = "enable", "uart", "source"; status = "disabled"; }; }; ap-ahb { compatible = "simple-bus"; #address-cells = <2>; #size-cells = <2>; ranges; ap_dma: dma-controller@20100000 { compatible = "sprd,sc9860-dma"; reg = <0 0x20100000 0 0x4000>; interrupts = ; #dma-cells = <1>; /* For backwards compatibility: */ #dma-channels = <32>; dma-channels = <32>; clocks = <&apahb_gate CLK_DMA_EB>; clock-names = "enable"; }; sdio3: mmc@50430000 { compatible = "sprd,sdhci-r11"; reg = <0 0x50430000 0 0x1000>; interrupts = ; clocks = <&aon_prediv CLK_EMMC_2X>, <&apahb_gate CLK_EMMC_EB>, <&aon_gate CLK_EMMC_2X_EN>; clock-names = "sdio", "enable", "2x_enable"; assigned-clocks = <&aon_prediv CLK_EMMC_2X>; assigned-clock-parents = <&clk_l0_409m6>; sprd,phy-delay-mmc-hs400 = <0x44 0x7f 0x2e 0x2e>; sprd,phy-delay-mmc-hs200 = <0x0 0x8c 0x8c 0x8c>; sprd,phy-delay-mmc-ddr52 = <0x3f 0x75 0x14 0x14>; sprd,phy-delay-mmc-hs400es = <0x3f 0x3f 0x2e 0x2e>; vmmc-supply = <&vddemmccore>; bus-width = <8>; non-removable; no-sdio; no-sd; cap-mmc-hw-reset; mmc-hs400-enhanced-strobe; mmc-hs400-1_8v; mmc-hs200-1_8v; mmc-ddr-1_8v; }; }; aon { compatible = "simple-bus"; #address-cells = <2>; #size-cells = <2>; ranges; adi_bus: spi@40030000 { compatible = "sprd,sc9860-adi"; reg = <0 0x40030000 0 0x10000>; hwlocks = <&hwlock 0>; hwlock-names = "adi"; #address-cells = <1>; #size-cells = <0>; }; timer@40050000 { compatible = "sprd,sc9860-timer"; reg = <0 0x40050000 0 0x20>; interrupts = ; clocks = <&ext_32k>; }; timer@40050020 { compatible = "sprd,sc9860-suspend-timer"; reg = <0 0x40050020 0 0x20>; clocks = <&ext_32k>; }; hwlock: hwspinlock@40500000 { compatible = "sprd,hwspinlock-r3p0"; reg = <0 0x40500000 0 0x1000>; #hwlock-cells = <1>; clocks = <&aon_gate CLK_SPLK_EB>; clock-names = "enable"; }; eic_debounce: gpio@40210000 { compatible = "sprd,sc9860-eic-debounce"; reg = <0 0x40210000 0 0x80>; gpio-controller; #gpio-cells = <2>; interrupt-controller; #interrupt-cells = <2>; interrupts = ; }; eic_latch: gpio@40210080 { compatible = "sprd,sc9860-eic-latch"; reg = <0 0x40210080 0 0x20>; gpio-controller; #gpio-cells = <2>; interrupt-controller; #interrupt-cells = <2>; interrupts = ; }; eic_async: gpio@402100a0 { compatible = "sprd,sc9860-eic-async"; reg = <0 0x402100a0 0 0x20>; gpio-controller; #gpio-cells = <2>; interrupt-controller; #interrupt-cells = <2>; interrupts = ; }; eic_sync: gpio@402100c0 { compatible = "sprd,sc9860-eic-sync"; reg = <0 0x402100c0 0 0x20>; gpio-controller; #gpio-cells = <2>; interrupt-controller; #interrupt-cells = <2>; interrupts = ; }; ap_gpio: gpio@40280000 { compatible = "sprd,sc9860-gpio"; reg = <0 0x40280000 0 0x1000>; gpio-controller; #gpio-cells = <2>; interrupt-controller; #interrupt-cells = <2>; interrupts = ; }; pin_controller: pinctrl@402a0000 { compatible = "sprd,sc9860-pinctrl"; reg = <0 0x402a0000 0 0x10000>; }; watchdog@40310000 { compatible = "sprd,sp9860-wdt"; reg = <0 0x40310000 0 0x1000>; interrupts = ; timeout-sec = <12>; clocks = <&aon_gate CLK_APCPU_WDG_EB>, <&aon_gate CLK_AP_WDG_RTC_EB>; clock-names = "enable", "rtc_enable"; }; }; agcp { compatible = "simple-bus"; #address-cells = <2>; #size-cells = <2>; ranges; agcp_dma: dma-controller@41580000 { compatible = "sprd,sc9860-dma"; reg = <0 0x41580000 0 0x4000>; #dma-cells = <1>; /* For backwards compatibility: */ #dma-channels = <32>; dma-channels = <32>; clocks = <&agcp_gate CLK_AGCP_DMAAP_EB>, <&agcp_gate CLK_AGCP_AP_ASHB_EB>; clock-names = "enable", "ashb_eb"; }; }; }; ext_32k: ext_32k { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <32768>; clock-output-names = "ext-32k"; }; ext_26m: ext_26m { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <26000000>; clock-output-names = "ext-26m"; }; ext_rco_100m: ext_rco_100m { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <100000000>; clock-output-names = "ext-rco-100m"; }; clk_l0_409m6: clk_l0_409m6 { compatible = "fixed-clock"; #clock-cells = <0>; clock-frequency = <409600000>; clock-output-names = "ext-409m6"; }; };