1/* 2 * Copyright (C) 2016 Icenowy Zheng <icenowy@aosc.xyz> 3 * 4 * This file is dual-licensed: you can use it either under the terms 5 * of the GPL or the X11 license, at your option. Note that this dual 6 * licensing only applies to this file, and not this project as a 7 * whole. 8 * 9 * a) This file is free software; you can redistribute it and/or 10 * modify it under the terms of the GNU General Public License as 11 * published by the Free Software Foundation; either version 2 of the 12 * License, or (at your option) any later version. 13 * 14 * This file is distributed in the hope that it will be useful, 15 * but WITHOUT ANY WARRANTY; without even the implied warranty of 16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 17 * GNU General Public License for more details. 18 * 19 * Or, alternatively, 20 * 21 * b) Permission is hereby granted, free of charge, to any person 22 * obtaining a copy of this software and associated documentation 23 * files (the "Software"), to deal in the Software without 24 * restriction, including without limitation the rights to use, 25 * copy, modify, merge, publish, distribute, sublicense, and/or 26 * sell copies of the Software, and to permit persons to whom the 27 * Software is furnished to do so, subject to the following 28 * conditions: 29 * 30 * The above copyright notice and this permission notice shall be 31 * included in all copies or substantial portions of the Software. 32 * 33 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 34 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 35 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 36 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT 37 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, 38 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 39 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 40 * OTHER DEALINGS IN THE SOFTWARE. 41 */ 42 43#include <dt-bindings/clock/sun8i-v3s-ccu.h> 44#include <dt-bindings/reset/sun8i-v3s-ccu.h> 45#include <dt-bindings/interrupt-controller/arm-gic.h> 46#include <dt-bindings/pinctrl/sun4i-a10.h> 47 48/ { 49 #address-cells = <1>; 50 #size-cells = <1>; 51 interrupt-parent = <&gic>; 52 53 cpus { 54 #address-cells = <1>; 55 #size-cells = <0>; 56 57 cpu@0 { 58 compatible = "arm,cortex-a7"; 59 device_type = "cpu"; 60 reg = <0>; 61 clocks = <&ccu CLK_CPU>; 62 }; 63 }; 64 65 timer { 66 compatible = "arm,armv7-timer"; 67 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 68 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 69 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>, 70 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>; 71 }; 72 73 clocks { 74 #address-cells = <1>; 75 #size-cells = <1>; 76 ranges; 77 78 osc24M: osc24M_clk { 79 #clock-cells = <0>; 80 compatible = "fixed-clock"; 81 clock-frequency = <24000000>; 82 clock-output-names = "osc24M"; 83 }; 84 85 osc32k: osc32k_clk { 86 #clock-cells = <0>; 87 compatible = "fixed-clock"; 88 clock-frequency = <32768>; 89 clock-output-names = "osc32k"; 90 }; 91 }; 92 93 soc { 94 compatible = "simple-bus"; 95 #address-cells = <1>; 96 #size-cells = <1>; 97 ranges; 98 99 mmc0: mmc@01c0f000 { 100 compatible = "allwinner,sun7i-a20-mmc"; 101 reg = <0x01c0f000 0x1000>; 102 clocks = <&ccu CLK_BUS_MMC0>, 103 <&ccu CLK_MMC0>, 104 <&ccu CLK_MMC0_OUTPUT>, 105 <&ccu CLK_MMC0_SAMPLE>; 106 clock-names = "ahb", 107 "mmc", 108 "output", 109 "sample"; 110 resets = <&ccu RST_BUS_MMC0>; 111 reset-names = "ahb"; 112 interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>; 113 status = "disabled"; 114 #address-cells = <1>; 115 #size-cells = <0>; 116 }; 117 118 mmc1: mmc@01c10000 { 119 compatible = "allwinner,sun7i-a20-mmc"; 120 reg = <0x01c10000 0x1000>; 121 clocks = <&ccu CLK_BUS_MMC1>, 122 <&ccu CLK_MMC1>, 123 <&ccu CLK_MMC1_OUTPUT>, 124 <&ccu CLK_MMC1_SAMPLE>; 125 clock-names = "ahb", 126 "mmc", 127 "output", 128 "sample"; 129 resets = <&ccu RST_BUS_MMC1>; 130 reset-names = "ahb"; 131 interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>; 132 status = "disabled"; 133 #address-cells = <1>; 134 #size-cells = <0>; 135 }; 136 137 mmc2: mmc@01c11000 { 138 compatible = "allwinner,sun7i-a20-mmc"; 139 reg = <0x01c11000 0x1000>; 140 clocks = <&ccu CLK_BUS_MMC2>, 141 <&ccu CLK_MMC2>, 142 <&ccu CLK_MMC2_OUTPUT>, 143 <&ccu CLK_MMC2_SAMPLE>; 144 clock-names = "ahb", 145 "mmc", 146 "output", 147 "sample"; 148 resets = <&ccu RST_BUS_MMC2>; 149 reset-names = "ahb"; 150 interrupts = <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>; 151 status = "disabled"; 152 #address-cells = <1>; 153 #size-cells = <0>; 154 }; 155 156 usb_otg: usb@01c19000 { 157 compatible = "allwinner,sun8i-h3-musb"; 158 reg = <0x01c19000 0x0400>; 159 clocks = <&ccu CLK_BUS_OTG>; 160 resets = <&ccu RST_BUS_OTG>; 161 interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>; 162 interrupt-names = "mc"; 163 phys = <&usbphy 0>; 164 phy-names = "usb"; 165 extcon = <&usbphy 0>; 166 status = "disabled"; 167 }; 168 169 usbphy: phy@01c19400 { 170 compatible = "allwinner,sun8i-v3s-usb-phy"; 171 reg = <0x01c19400 0x2c>, 172 <0x01c1a800 0x4>; 173 reg-names = "phy_ctrl", 174 "pmu0"; 175 clocks = <&ccu CLK_USB_PHY0>; 176 clock-names = "usb0_phy"; 177 resets = <&ccu RST_USB_PHY0>; 178 reset-names = "usb0_reset"; 179 status = "disabled"; 180 #phy-cells = <1>; 181 }; 182 183 ccu: clock@01c20000 { 184 compatible = "allwinner,sun8i-v3s-ccu"; 185 reg = <0x01c20000 0x400>; 186 clocks = <&osc24M>, <&osc32k>; 187 clock-names = "hosc", "losc"; 188 #clock-cells = <1>; 189 #reset-cells = <1>; 190 }; 191 192 rtc: rtc@01c20400 { 193 compatible = "allwinner,sun6i-a31-rtc"; 194 reg = <0x01c20400 0x54>; 195 interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>, 196 <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>; 197 }; 198 199 pio: pinctrl@01c20800 { 200 compatible = "allwinner,sun8i-v3s-pinctrl"; 201 reg = <0x01c20800 0x400>; 202 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>, 203 <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>; 204 clocks = <&ccu CLK_BUS_PIO>, <&osc24M>, <&osc32k>; 205 clock-names = "apb", "hosc", "losc"; 206 gpio-controller; 207 #gpio-cells = <3>; 208 interrupt-controller; 209 #interrupt-cells = <3>; 210 211 uart0_pins_a: uart0@0 { 212 pins = "PB8", "PB9"; 213 function = "uart0"; 214 bias-pull-up; 215 }; 216 217 mmc0_pins_a: mmc0@0 { 218 pins = "PF0", "PF1", "PF2", "PF3", 219 "PF4", "PF5"; 220 function = "mmc0"; 221 drive-strength = <30>; 222 bias-pull-up; 223 }; 224 }; 225 226 timer@01c20c00 { 227 compatible = "allwinner,sun4i-a10-timer"; 228 reg = <0x01c20c00 0xa0>; 229 interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>, 230 <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>; 231 clocks = <&osc24M>; 232 }; 233 234 wdt0: watchdog@01c20ca0 { 235 compatible = "allwinner,sun6i-a31-wdt"; 236 reg = <0x01c20ca0 0x20>; 237 interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>; 238 }; 239 240 uart0: serial@01c28000 { 241 compatible = "snps,dw-apb-uart"; 242 reg = <0x01c28000 0x400>; 243 interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>; 244 reg-shift = <2>; 245 reg-io-width = <4>; 246 clocks = <&ccu CLK_BUS_UART0>; 247 resets = <&ccu RST_BUS_UART0>; 248 status = "disabled"; 249 }; 250 251 uart1: serial@01c28400 { 252 compatible = "snps,dw-apb-uart"; 253 reg = <0x01c28400 0x400>; 254 interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>; 255 reg-shift = <2>; 256 reg-io-width = <4>; 257 clocks = <&ccu CLK_BUS_UART1>; 258 resets = <&ccu RST_BUS_UART1>; 259 status = "disabled"; 260 }; 261 262 uart2: serial@01c28800 { 263 compatible = "snps,dw-apb-uart"; 264 reg = <0x01c28800 0x400>; 265 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; 266 reg-shift = <2>; 267 reg-io-width = <4>; 268 clocks = <&ccu CLK_BUS_UART2>; 269 resets = <&ccu RST_BUS_UART2>; 270 status = "disabled"; 271 }; 272 273 gic: interrupt-controller@01c81000 { 274 compatible = "arm,cortex-a7-gic", "arm,cortex-a15-gic"; 275 reg = <0x01c81000 0x1000>, 276 <0x01c82000 0x1000>, 277 <0x01c84000 0x2000>, 278 <0x01c86000 0x2000>; 279 interrupt-controller; 280 #interrupt-cells = <3>; 281 interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>; 282 }; 283 }; 284}; 285