cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

ocelot.dtsi (5617B)


      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};