1// SPDX-License-Identifier: (GPL-2.0 OR MIT) 2/* Copyright (c) 2017 Microsemi Corporation */ 3 4/ { 5 #address-cells = <1>; 6 #size-cells = <1>; 7 compatible = "mscc,ocelot"; 8 9 cpus { 10 #address-cells = <1>; 11 #size-cells = <0>; 12 13 cpu@0 { 14 compatible = "mips,mips24KEc"; 15 device_type = "cpu"; 16 clocks = <&cpu_clk>; 17 reg = <0>; 18 }; 19 }; 20 21 aliases { 22 serial0 = &uart0; 23 }; 24 25 cpuintc: interrupt-controller { 26 #address-cells = <0>; 27 #interrupt-cells = <1>; 28 interrupt-controller; 29 compatible = "mti,cpu-interrupt-controller"; 30 }; 31 32 cpu_clk: cpu-clock { 33 compatible = "fixed-clock"; 34 #clock-cells = <0>; 35 clock-frequency = <500000000>; 36 }; 37 38 ahb_clk: ahb-clk { 39 compatible = "fixed-factor-clock"; 40 #clock-cells = <0>; 41 clocks = <&cpu_clk>; 42 clock-div = <2>; 43 clock-mult = <1>; 44 }; 45 46 ahb@70000000 { 47 compatible = "simple-bus"; 48 #address-cells = <1>; 49 #size-cells = <1>; 50 ranges = <0 0x70000000 0x2000000>; 51 52 interrupt-parent = <&intc>; 53 54 cpu_ctrl: syscon@0 { 55 compatible = "mscc,ocelot-cpu-syscon", "syscon"; 56 reg = <0x0 0x2c>; 57 }; 58 59 intc: interrupt-controller@70 { 60 compatible = "mscc,ocelot-icpu-intr"; 61 reg = <0x70 0x70>; 62 #interrupt-cells = <1>; 63 interrupt-controller; 64 interrupt-parent = <&cpuintc>; 65 interrupts = <2>; 66 }; 67 68 uart0: serial@100000 { 69 pinctrl-0 = <&uart_pins>; 70 pinctrl-names = "default"; 71 compatible = "ns16550a"; 72 reg = <0x100000 0x20>; 73 interrupts = <6>; 74 clocks = <&ahb_clk>; 75 reg-io-width = <4>; 76 reg-shift = <2>; 77 78 status = "disabled"; 79 }; 80 81 i2c: i2c@100400 { 82 compatible = "mscc,ocelot-i2c", "snps,designware-i2c"; 83 pinctrl-0 = <&i2c_pins>; 84 pinctrl-names = "default"; 85 reg = <0x100400 0x100>, <0x198 0x8>; 86 #address-cells = <1>; 87 #size-cells = <0>; 88 interrupts = <8>; 89 clocks = <&ahb_clk>; 90 91 status = "disabled"; 92 }; 93 94 uart2: serial@100800 { 95 pinctrl-0 = <&uart2_pins>; 96 pinctrl-names = "default"; 97 compatible = "ns16550a"; 98 reg = <0x100800 0x20>; 99 interrupts = <7>; 100 clocks = <&ahb_clk>; 101 reg-io-width = <4>; 102 reg-shift = <2>; 103 104 status = "disabled"; 105 }; 106 107 spi: spi@101000 { 108 compatible = "mscc,ocelot-spi", "snps,dw-apb-ssi"; 109 #address-cells = <1>; 110 #size-cells = <0>; 111 reg = <0x101000 0x100>, <0x3c 0x18>; 112 interrupts = <9>; 113 clocks = <&ahb_clk>; 114 115 status = "disabled"; 116 }; 117 118 switch@1010000 { 119 compatible = "mscc,vsc7514-switch"; 120 reg = <0x1010000 0x10000>, 121 <0x1030000 0x10000>, 122 <0x1080000 0x100>, 123 <0x10e0000 0x10000>, 124 <0x11e0000 0x100>, 125 <0x11f0000 0x100>, 126 <0x1200000 0x100>, 127 <0x1210000 0x100>, 128 <0x1220000 0x100>, 129 <0x1230000 0x100>, 130 <0x1240000 0x100>, 131 <0x1250000 0x100>, 132 <0x1260000 0x100>, 133 <0x1270000 0x100>, 134 <0x1280000 0x100>, 135 <0x1800000 0x80000>, 136 <0x1880000 0x10000>, 137 <0x1040000 0x10000>, 138 <0x1050000 0x10000>, 139 <0x1060000 0x10000>; 140 reg-names = "sys", "rew", "qs", "ptp", "port0", "port1", 141 "port2", "port3", "port4", "port5", "port6", 142 "port7", "port8", "port9", "port10", "qsys", 143 "ana", "s0", "s1", "s2"; 144 interrupts = <18 21 22>; 145 interrupt-names = "ptp_rdy", "xtr", "inj"; 146 147 ethernet-ports { 148 #address-cells = <1>; 149 #size-cells = <0>; 150 151 port0: port@0 { 152 reg = <0>; 153 status = "disabled"; 154 }; 155 port1: port@1 { 156 reg = <1>; 157 status = "disabled"; 158 }; 159 port2: port@2 { 160 reg = <2>; 161 status = "disabled"; 162 }; 163 port3: port@3 { 164 reg = <3>; 165 status = "disabled"; 166 }; 167 port4: port@4 { 168 reg = <4>; 169 status = "disabled"; 170 }; 171 port5: port@5 { 172 reg = <5>; 173 status = "disabled"; 174 }; 175 port6: port@6 { 176 reg = <6>; 177 status = "disabled"; 178 }; 179 port7: port@7 { 180 reg = <7>; 181 status = "disabled"; 182 }; 183 port8: port@8 { 184 reg = <8>; 185 status = "disabled"; 186 }; 187 port9: port@9 { 188 reg = <9>; 189 status = "disabled"; 190 }; 191 port10: port@10 { 192 reg = <10>; 193 status = "disabled"; 194 }; 195 }; 196 }; 197 198 reset@1070008 { 199 compatible = "mscc,ocelot-chip-reset"; 200 reg = <0x1070008 0x4>; 201 }; 202 203 gpio: pinctrl@1070034 { 204 compatible = "mscc,ocelot-pinctrl"; 205 reg = <0x1070034 0x68>; 206 gpio-controller; 207 #gpio-cells = <2>; 208 gpio-ranges = <&gpio 0 0 22>; 209 interrupt-controller; 210 interrupts = <13>; 211 #interrupt-cells = <2>; 212 213 i2c_pins: i2c-pins { 214 pins = "GPIO_16", "GPIO_17"; 215 function = "twi"; 216 }; 217 218 uart_pins: uart-pins { 219 pins = "GPIO_6", "GPIO_7"; 220 function = "uart"; 221 }; 222 223 uart2_pins: uart2-pins { 224 pins = "GPIO_12", "GPIO_13"; 225 function = "uart2"; 226 }; 227 228 miim1_pins: miim1-pins { 229 pins = "GPIO_14", "GPIO_15"; 230 function = "miim"; 231 }; 232 233 }; 234 235 mdio0: mdio@107009c { 236 #address-cells = <1>; 237 #size-cells = <0>; 238 compatible = "mscc,ocelot-miim"; 239 reg = <0x107009c 0x24>, <0x10700f0 0x8>; 240 interrupts = <14>; 241 status = "disabled"; 242 243 phy0: ethernet-phy@0 { 244 reg = <0>; 245 }; 246 phy1: ethernet-phy@1 { 247 reg = <1>; 248 }; 249 phy2: ethernet-phy@2 { 250 reg = <2>; 251 }; 252 phy3: ethernet-phy@3 { 253 reg = <3>; 254 }; 255 }; 256 257 mdio1: mdio@10700c0 { 258 #address-cells = <1>; 259 #size-cells = <0>; 260 compatible = "mscc,ocelot-miim"; 261 reg = <0x10700c0 0x24>; 262 interrupts = <15>; 263 pinctrl-names = "default"; 264 pinctrl-0 = <&miim1_pins>; 265 status = "disabled"; 266 }; 267 268 hsio: syscon@10d0000 { 269 compatible = "mscc,ocelot-hsio", "syscon", "simple-mfd"; 270 reg = <0x10d0000 0x10000>; 271 272 serdes: serdes { 273 compatible = "mscc,vsc7514-serdes"; 274 #phy-cells = <2>; 275 }; 276 }; 277 }; 278}; 279