1*4882a593Smuzhiyun* Marvell Armada 375 Ethernet Controller (PPv2.1) 2*4882a593Smuzhiyun Marvell Armada 7K/8K Ethernet Controller (PPv2.2) 3*4882a593Smuzhiyun 4*4882a593SmuzhiyunRequired properties: 5*4882a593Smuzhiyun 6*4882a593Smuzhiyun- compatible: should be one of: 7*4882a593Smuzhiyun "marvell,armada-375-pp2" 8*4882a593Smuzhiyun "marvell,armada-7k-pp2" 9*4882a593Smuzhiyun- reg: addresses and length of the register sets for the device. 10*4882a593Smuzhiyun For "marvell,armada-375-pp2", must contain the following register 11*4882a593Smuzhiyun sets: 12*4882a593Smuzhiyun - common controller registers 13*4882a593Smuzhiyun - LMS registers 14*4882a593Smuzhiyun - one register area per Ethernet port 15*4882a593Smuzhiyun For "marvell,armada-7k-pp2", must contain the following register 16*4882a593Smuzhiyun sets: 17*4882a593Smuzhiyun - packet processor registers 18*4882a593Smuzhiyun - networking interfaces registers 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun- clocks: pointers to the reference clocks for this device, consequently: 21*4882a593Smuzhiyun - main controller clock (for both armada-375-pp2 and armada-7k-pp2) 22*4882a593Smuzhiyun - GOP clock (for both armada-375-pp2 and armada-7k-pp2) 23*4882a593Smuzhiyun - MG clock (only for armada-7k-pp2) 24*4882a593Smuzhiyun - MG Core clock (only for armada-7k-pp2) 25*4882a593Smuzhiyun - AXI clock (only for armada-7k-pp2) 26*4882a593Smuzhiyun- clock-names: names of used clocks, must be "pp_clk", "gop_clk", "mg_clk", 27*4882a593Smuzhiyun "mg_core_clk" and "axi_clk" (the 3 latter only for armada-7k-pp2). 28*4882a593Smuzhiyun 29*4882a593SmuzhiyunThe ethernet ports are represented by subnodes. At least one port is 30*4882a593Smuzhiyunrequired. 31*4882a593Smuzhiyun 32*4882a593SmuzhiyunRequired properties (port): 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun- interrupts: interrupt(s) for the port 35*4882a593Smuzhiyun- port-id: ID of the port from the MAC point of view 36*4882a593Smuzhiyun- gop-port-id: only for marvell,armada-7k-pp2, ID of the port from the 37*4882a593Smuzhiyun GOP (Group Of Ports) point of view. This ID is used to index the 38*4882a593Smuzhiyun per-port registers in the second register area. 39*4882a593Smuzhiyun- phy-mode: See ethernet.txt file in the same directory 40*4882a593Smuzhiyun 41*4882a593SmuzhiyunOptional properties (port): 42*4882a593Smuzhiyun 43*4882a593Smuzhiyun- marvell,loopback: port is loopback mode 44*4882a593Smuzhiyun- phy: a phandle to a phy node defining the PHY address (as the reg 45*4882a593Smuzhiyun property, a single integer). 46*4882a593Smuzhiyun- interrupt-names: if more than a single interrupt for is given, must be the 47*4882a593Smuzhiyun name associated to the interrupts listed. Valid names are: 48*4882a593Smuzhiyun "hifX", with X in [0..8], and "link". The names "tx-cpu0", 49*4882a593Smuzhiyun "tx-cpu1", "tx-cpu2", "tx-cpu3" and "rx-shared" are supported 50*4882a593Smuzhiyun for backward compatibility but shouldn't be used for new 51*4882a593Smuzhiyun additions. 52*4882a593Smuzhiyun- marvell,system-controller: a phandle to the system controller. 53*4882a593Smuzhiyun 54*4882a593SmuzhiyunExample for marvell,armada-375-pp2: 55*4882a593Smuzhiyun 56*4882a593Smuzhiyunethernet@f0000 { 57*4882a593Smuzhiyun compatible = "marvell,armada-375-pp2"; 58*4882a593Smuzhiyun reg = <0xf0000 0xa000>, 59*4882a593Smuzhiyun <0xc0000 0x3060>, 60*4882a593Smuzhiyun <0xc4000 0x100>, 61*4882a593Smuzhiyun <0xc5000 0x100>; 62*4882a593Smuzhiyun clocks = <&gateclk 3>, <&gateclk 19>; 63*4882a593Smuzhiyun clock-names = "pp_clk", "gop_clk"; 64*4882a593Smuzhiyun 65*4882a593Smuzhiyun eth0: eth0@c4000 { 66*4882a593Smuzhiyun interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>; 67*4882a593Smuzhiyun port-id = <0>; 68*4882a593Smuzhiyun phy = <&phy0>; 69*4882a593Smuzhiyun phy-mode = "gmii"; 70*4882a593Smuzhiyun }; 71*4882a593Smuzhiyun 72*4882a593Smuzhiyun eth1: eth1@c5000 { 73*4882a593Smuzhiyun interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>; 74*4882a593Smuzhiyun port-id = <1>; 75*4882a593Smuzhiyun phy = <&phy3>; 76*4882a593Smuzhiyun phy-mode = "gmii"; 77*4882a593Smuzhiyun }; 78*4882a593Smuzhiyun}; 79*4882a593Smuzhiyun 80*4882a593SmuzhiyunExample for marvell,armada-7k-pp2: 81*4882a593Smuzhiyun 82*4882a593Smuzhiyuncpm_ethernet: ethernet@0 { 83*4882a593Smuzhiyun compatible = "marvell,armada-7k-pp22"; 84*4882a593Smuzhiyun reg = <0x0 0x100000>, <0x129000 0xb000>; 85*4882a593Smuzhiyun clocks = <&cpm_syscon0 1 3>, <&cpm_syscon0 1 9>, 86*4882a593Smuzhiyun <&cpm_syscon0 1 5>, <&cpm_syscon0 1 6>, <&cpm_syscon0 1 18>; 87*4882a593Smuzhiyun clock-names = "pp_clk", "gop_clk", "mg_clk", "mg_core_clk", "axi_clk"; 88*4882a593Smuzhiyun 89*4882a593Smuzhiyun eth0: eth0 { 90*4882a593Smuzhiyun interrupts = <ICU_GRP_NSR 39 IRQ_TYPE_LEVEL_HIGH>, 91*4882a593Smuzhiyun <ICU_GRP_NSR 43 IRQ_TYPE_LEVEL_HIGH>, 92*4882a593Smuzhiyun <ICU_GRP_NSR 47 IRQ_TYPE_LEVEL_HIGH>, 93*4882a593Smuzhiyun <ICU_GRP_NSR 51 IRQ_TYPE_LEVEL_HIGH>, 94*4882a593Smuzhiyun <ICU_GRP_NSR 55 IRQ_TYPE_LEVEL_HIGH>, 95*4882a593Smuzhiyun <ICU_GRP_NSR 59 IRQ_TYPE_LEVEL_HIGH>, 96*4882a593Smuzhiyun <ICU_GRP_NSR 63 IRQ_TYPE_LEVEL_HIGH>, 97*4882a593Smuzhiyun <ICU_GRP_NSR 67 IRQ_TYPE_LEVEL_HIGH>, 98*4882a593Smuzhiyun <ICU_GRP_NSR 71 IRQ_TYPE_LEVEL_HIGH>, 99*4882a593Smuzhiyun <ICU_GRP_NSR 129 IRQ_TYPE_LEVEL_HIGH>; 100*4882a593Smuzhiyun interrupt-names = "hif0", "hif1", "hif2", "hif3", "hif4", 101*4882a593Smuzhiyun "hif5", "hif6", "hif7", "hif8", "link"; 102*4882a593Smuzhiyun port-id = <0>; 103*4882a593Smuzhiyun gop-port-id = <0>; 104*4882a593Smuzhiyun }; 105*4882a593Smuzhiyun 106*4882a593Smuzhiyun eth1: eth1 { 107*4882a593Smuzhiyun interrupts = <ICU_GRP_NSR 40 IRQ_TYPE_LEVEL_HIGH>, 108*4882a593Smuzhiyun <ICU_GRP_NSR 44 IRQ_TYPE_LEVEL_HIGH>, 109*4882a593Smuzhiyun <ICU_GRP_NSR 48 IRQ_TYPE_LEVEL_HIGH>, 110*4882a593Smuzhiyun <ICU_GRP_NSR 52 IRQ_TYPE_LEVEL_HIGH>, 111*4882a593Smuzhiyun <ICU_GRP_NSR 56 IRQ_TYPE_LEVEL_HIGH>, 112*4882a593Smuzhiyun <ICU_GRP_NSR 60 IRQ_TYPE_LEVEL_HIGH>, 113*4882a593Smuzhiyun <ICU_GRP_NSR 64 IRQ_TYPE_LEVEL_HIGH>, 114*4882a593Smuzhiyun <ICU_GRP_NSR 68 IRQ_TYPE_LEVEL_HIGH>, 115*4882a593Smuzhiyun <ICU_GRP_NSR 72 IRQ_TYPE_LEVEL_HIGH>, 116*4882a593Smuzhiyun <ICU_GRP_NSR 128 IRQ_TYPE_LEVEL_HIGH>; 117*4882a593Smuzhiyun interrupt-names = "hif0", "hif1", "hif2", "hif3", "hif4", 118*4882a593Smuzhiyun "hif5", "hif6", "hif7", "hif8", "link"; 119*4882a593Smuzhiyun port-id = <1>; 120*4882a593Smuzhiyun gop-port-id = <2>; 121*4882a593Smuzhiyun }; 122*4882a593Smuzhiyun 123*4882a593Smuzhiyun eth2: eth2 { 124*4882a593Smuzhiyun interrupts = <ICU_GRP_NSR 41 IRQ_TYPE_LEVEL_HIGH>, 125*4882a593Smuzhiyun <ICU_GRP_NSR 45 IRQ_TYPE_LEVEL_HIGH>, 126*4882a593Smuzhiyun <ICU_GRP_NSR 49 IRQ_TYPE_LEVEL_HIGH>, 127*4882a593Smuzhiyun <ICU_GRP_NSR 53 IRQ_TYPE_LEVEL_HIGH>, 128*4882a593Smuzhiyun <ICU_GRP_NSR 57 IRQ_TYPE_LEVEL_HIGH>, 129*4882a593Smuzhiyun <ICU_GRP_NSR 61 IRQ_TYPE_LEVEL_HIGH>, 130*4882a593Smuzhiyun <ICU_GRP_NSR 65 IRQ_TYPE_LEVEL_HIGH>, 131*4882a593Smuzhiyun <ICU_GRP_NSR 69 IRQ_TYPE_LEVEL_HIGH>, 132*4882a593Smuzhiyun <ICU_GRP_NSR 73 IRQ_TYPE_LEVEL_HIGH>, 133*4882a593Smuzhiyun <ICU_GRP_NSR 127 IRQ_TYPE_LEVEL_HIGH>; 134*4882a593Smuzhiyun interrupt-names = "hif0", "hif1", "hif2", "hif3", "hif4", 135*4882a593Smuzhiyun "hif5", "hif6", "hif7", "hif8", "link"; 136*4882a593Smuzhiyun port-id = <2>; 137*4882a593Smuzhiyun gop-port-id = <3>; 138*4882a593Smuzhiyun }; 139*4882a593Smuzhiyun}; 140