123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279 |
- // SPDX-License-Identifier: (GPL-2.0 OR MIT)
- /* Copyright (c) 2017 Microsemi Corporation */
- / {
- #address-cells = <1>;
- #size-cells = <1>;
- compatible = "mscc,ocelot";
- cpus {
- #address-cells = <1>;
- #size-cells = <0>;
- cpu@0 {
- compatible = "mips,mips24KEc";
- device_type = "cpu";
- clocks = <&cpu_clk>;
- reg = <0>;
- };
- };
- aliases {
- serial0 = &uart0;
- };
- cpuintc: interrupt-controller {
- #address-cells = <0>;
- #interrupt-cells = <1>;
- interrupt-controller;
- compatible = "mti,cpu-interrupt-controller";
- };
- cpu_clk: cpu-clock {
- compatible = "fixed-clock";
- #clock-cells = <0>;
- clock-frequency = <500000000>;
- };
- ahb_clk: ahb-clk {
- compatible = "fixed-factor-clock";
- #clock-cells = <0>;
- clocks = <&cpu_clk>;
- clock-div = <2>;
- clock-mult = <1>;
- };
- ahb@70000000 {
- compatible = "simple-bus";
- #address-cells = <1>;
- #size-cells = <1>;
- ranges = <0 0x70000000 0x2000000>;
- interrupt-parent = <&intc>;
- cpu_ctrl: syscon@0 {
- compatible = "mscc,ocelot-cpu-syscon", "syscon";
- reg = <0x0 0x2c>;
- };
- intc: interrupt-controller@70 {
- compatible = "mscc,ocelot-icpu-intr";
- reg = <0x70 0x70>;
- #interrupt-cells = <1>;
- interrupt-controller;
- interrupt-parent = <&cpuintc>;
- interrupts = <2>;
- };
- uart0: serial@100000 {
- pinctrl-0 = <&uart_pins>;
- pinctrl-names = "default";
- compatible = "ns16550a";
- reg = <0x100000 0x20>;
- interrupts = <6>;
- clocks = <&ahb_clk>;
- reg-io-width = <4>;
- reg-shift = <2>;
- status = "disabled";
- };
- i2c: i2c@100400 {
- compatible = "mscc,ocelot-i2c", "snps,designware-i2c";
- pinctrl-0 = <&i2c_pins>;
- pinctrl-names = "default";
- reg = <0x100400 0x100>, <0x198 0x8>;
- #address-cells = <1>;
- #size-cells = <0>;
- interrupts = <8>;
- clocks = <&ahb_clk>;
- status = "disabled";
- };
- uart2: serial@100800 {
- pinctrl-0 = <&uart2_pins>;
- pinctrl-names = "default";
- compatible = "ns16550a";
- reg = <0x100800 0x20>;
- interrupts = <7>;
- clocks = <&ahb_clk>;
- reg-io-width = <4>;
- reg-shift = <2>;
- status = "disabled";
- };
- spi: spi@101000 {
- compatible = "mscc,ocelot-spi", "snps,dw-apb-ssi";
- #address-cells = <1>;
- #size-cells = <0>;
- reg = <0x101000 0x100>, <0x3c 0x18>;
- interrupts = <9>;
- clocks = <&ahb_clk>;
- status = "disabled";
- };
- switch@1010000 {
- compatible = "mscc,vsc7514-switch";
- reg = <0x1010000 0x10000>,
- <0x1030000 0x10000>,
- <0x1080000 0x100>,
- <0x10e0000 0x10000>,
- <0x11e0000 0x100>,
- <0x11f0000 0x100>,
- <0x1200000 0x100>,
- <0x1210000 0x100>,
- <0x1220000 0x100>,
- <0x1230000 0x100>,
- <0x1240000 0x100>,
- <0x1250000 0x100>,
- <0x1260000 0x100>,
- <0x1270000 0x100>,
- <0x1280000 0x100>,
- <0x1800000 0x80000>,
- <0x1880000 0x10000>,
- <0x1040000 0x10000>,
- <0x1050000 0x10000>,
- <0x1060000 0x10000>,
- <0x1a0 0x1c4>;
- reg-names = "sys", "rew", "qs", "ptp", "port0", "port1",
- "port2", "port3", "port4", "port5", "port6",
- "port7", "port8", "port9", "port10", "qsys",
- "ana", "s0", "s1", "s2", "fdma";
- interrupts = <18 21 22 16>;
- interrupt-names = "ptp_rdy", "xtr", "inj", "fdma";
- ethernet-ports {
- #address-cells = <1>;
- #size-cells = <0>;
- port0: port@0 {
- reg = <0>;
- status = "disabled";
- };
- port1: port@1 {
- reg = <1>;
- status = "disabled";
- };
- port2: port@2 {
- reg = <2>;
- status = "disabled";
- };
- port3: port@3 {
- reg = <3>;
- status = "disabled";
- };
- port4: port@4 {
- reg = <4>;
- status = "disabled";
- };
- port5: port@5 {
- reg = <5>;
- status = "disabled";
- };
- port6: port@6 {
- reg = <6>;
- status = "disabled";
- };
- port7: port@7 {
- reg = <7>;
- status = "disabled";
- };
- port8: port@8 {
- reg = <8>;
- status = "disabled";
- };
- port9: port@9 {
- reg = <9>;
- status = "disabled";
- };
- port10: port@10 {
- reg = <10>;
- status = "disabled";
- };
- };
- };
- reset@1070008 {
- compatible = "mscc,ocelot-chip-reset";
- reg = <0x1070008 0x4>;
- };
- gpio: pinctrl@1070034 {
- compatible = "mscc,ocelot-pinctrl";
- reg = <0x1070034 0x68>;
- gpio-controller;
- #gpio-cells = <2>;
- gpio-ranges = <&gpio 0 0 22>;
- interrupt-controller;
- interrupts = <13>;
- #interrupt-cells = <2>;
- i2c_pins: i2c-pins {
- pins = "GPIO_16", "GPIO_17";
- function = "twi";
- };
- uart_pins: uart-pins {
- pins = "GPIO_6", "GPIO_7";
- function = "uart";
- };
- uart2_pins: uart2-pins {
- pins = "GPIO_12", "GPIO_13";
- function = "uart2";
- };
- miim1_pins: miim1-pins {
- pins = "GPIO_14", "GPIO_15";
- function = "miim";
- };
- };
- mdio0: mdio@107009c {
- #address-cells = <1>;
- #size-cells = <0>;
- compatible = "mscc,ocelot-miim";
- reg = <0x107009c 0x24>, <0x10700f0 0x8>;
- interrupts = <14>;
- status = "disabled";
- phy0: ethernet-phy@0 {
- reg = <0>;
- };
- phy1: ethernet-phy@1 {
- reg = <1>;
- };
- phy2: ethernet-phy@2 {
- reg = <2>;
- };
- phy3: ethernet-phy@3 {
- reg = <3>;
- };
- };
- mdio1: mdio@10700c0 {
- #address-cells = <1>;
- #size-cells = <0>;
- compatible = "mscc,ocelot-miim";
- reg = <0x10700c0 0x24>;
- interrupts = <15>;
- pinctrl-names = "default";
- pinctrl-0 = <&miim1_pins>;
- status = "disabled";
- };
- hsio: syscon@10d0000 {
- compatible = "mscc,ocelot-hsio", "syscon", "simple-mfd";
- reg = <0x10d0000 0x10000>;
- serdes: serdes {
- compatible = "mscc,vsc7514-serdes";
- #phy-cells = <2>;
- };
- };
- };
- };
|