1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 2%YAML 1.2 3--- 4$id: http://devicetree.org/schemas/net/xlnx,axi-ethernet.yaml# 5$schema: http://devicetree.org/meta-schemas/core.yaml# 6 7title: AXI 1G/2.5G Ethernet Subsystem 8 9description: | 10 Also called AXI 1G/2.5G Ethernet Subsystem, the xilinx axi ethernet IP core 11 provides connectivity to an external ethernet PHY supporting different 12 interfaces: MII, GMII, RGMII, SGMII, 1000BaseX. It also includes two 13 segments of memory for buffering TX and RX, as well as the capability of 14 offloading TX/RX checksum calculation off the processor. 15 16 Management configuration is done through the AXI interface, while payload is 17 sent and received through means of an AXI DMA controller. This driver 18 includes the DMA driver code, so this driver is incompatible with AXI DMA 19 driver. 20 21maintainers: 22 - Radhey Shyam Pandey <radhey.shyam.pandey@xilinx.com> 23 24properties: 25 compatible: 26 enum: 27 - xlnx,axi-ethernet-1.00.a 28 - xlnx,axi-ethernet-1.01.a 29 - xlnx,axi-ethernet-2.01.a 30 31 reg: 32 description: 33 Address and length of the IO space, as well as the address 34 and length of the AXI DMA controller IO space, unless 35 axistream-connected is specified, in which case the reg 36 attribute of the node referenced by it is used. 37 minItems: 1 38 maxItems: 2 39 40 interrupts: 41 items: 42 - description: Ethernet core interrupt 43 - description: Tx DMA interrupt 44 - description: Rx DMA interrupt 45 description: 46 Ethernet core interrupt is optional. If axistream-connected property is 47 present DMA node should contains TX/RX DMA interrupts else DMA interrupt 48 resources are mentioned on ethernet node. 49 minItems: 1 50 51 phy-handle: true 52 53 xlnx,rxmem: 54 description: 55 Set to allocated memory buffer for Rx/Tx in the hardware. 56 $ref: /schemas/types.yaml#/definitions/uint32 57 58 phy-mode: 59 enum: 60 - mii 61 - gmii 62 - rgmii 63 - sgmii 64 - 1000BaseX 65 66 xlnx,phy-type: 67 description: 68 Do not use, but still accepted in preference to phy-mode. 69 deprecated: true 70 $ref: /schemas/types.yaml#/definitions/uint32 71 72 xlnx,txcsum: 73 description: 74 TX checksum offload. 0 or empty for disabling TX checksum offload, 75 1 to enable partial TX checksum offload and 2 to enable full TX 76 checksum offload. 77 $ref: /schemas/types.yaml#/definitions/uint32 78 enum: [0, 1, 2] 79 80 xlnx,rxcsum: 81 description: 82 RX checksum offload. 0 or empty for disabling RX checksum offload, 83 1 to enable partial RX checksum offload and 2 to enable full RX 84 checksum offload. 85 $ref: /schemas/types.yaml#/definitions/uint32 86 enum: [0, 1, 2] 87 88 xlnx,switch-x-sgmii: 89 type: boolean 90 description: 91 Indicate the Ethernet core is configured to support both 1000BaseX and 92 SGMII modes. If set, the phy-mode should be set to match the mode 93 selected on core reset (i.e. by the basex_or_sgmii core input line). 94 95 clocks: 96 items: 97 - description: Clock for AXI register slave interface. 98 - description: AXI4-Stream clock for TXD RXD TXC and RXS interfaces. 99 - description: Ethernet reference clock, used by signal delay primitives 100 and transceivers. 101 - description: MGT reference clock (used by optional internal PCS/PMA PHY) 102 103 clock-names: 104 items: 105 - const: s_axi_lite_clk 106 - const: axis_clk 107 - const: ref_clk 108 - const: mgt_clk 109 110 axistream-connected: 111 $ref: /schemas/types.yaml#/definitions/phandle 112 description: Phandle of AXI DMA controller which contains the resources 113 used by this device. If this is specified, the DMA-related resources 114 from that device (DMA registers and DMA TX/RX interrupts) rather than 115 this one will be used. 116 117 mdio: 118 type: object 119 120 pcs-handle: 121 description: Phandle to the internal PCS/PMA PHY in SGMII or 1000Base-X 122 modes, where "pcs-handle" should be used to point to the PCS/PMA PHY, 123 and "phy-handle" should point to an external PHY if exists. 124 maxItems: 1 125 126required: 127 - compatible 128 - interrupts 129 - reg 130 - xlnx,rxmem 131 - phy-handle 132 133allOf: 134 - $ref: /schemas/net/ethernet-controller.yaml# 135 136additionalProperties: false 137 138examples: 139 - | 140 axi_ethernet_eth: ethernet@40c00000 { 141 compatible = "xlnx,axi-ethernet-1.00.a"; 142 interrupts = <2 0 1>; 143 clock-names = "s_axi_lite_clk", "axis_clk", "ref_clk", "mgt_clk"; 144 clocks = <&axi_clk>, <&axi_clk>, <&pl_enet_ref_clk>, <&mgt_clk>; 145 phy-mode = "mii"; 146 reg = <0x40c00000 0x40000>,<0x50c00000 0x40000>; 147 xlnx,rxcsum = <0x2>; 148 xlnx,rxmem = <0x800>; 149 xlnx,txcsum = <0x2>; 150 phy-handle = <&phy0>; 151 152 mdio { 153 #address-cells = <1>; 154 #size-cells = <0>; 155 phy0: ethernet-phy@1 { 156 device_type = "ethernet-phy"; 157 reg = <1>; 158 }; 159 }; 160 }; 161 162 - | 163 axi_ethernet_eth1: ethernet@40000000 { 164 compatible = "xlnx,axi-ethernet-1.00.a"; 165 interrupts = <0>; 166 clock-names = "s_axi_lite_clk", "axis_clk", "ref_clk", "mgt_clk"; 167 clocks = <&axi_clk>, <&axi_clk>, <&pl_enet_ref_clk>, <&mgt_clk>; 168 phy-mode = "mii"; 169 reg = <0x40000000 0x40000>; 170 xlnx,rxcsum = <0x2>; 171 xlnx,rxmem = <0x800>; 172 xlnx,txcsum = <0x2>; 173 phy-handle = <&phy1>; 174 axistream-connected = <&dma>; 175 176 mdio { 177 #address-cells = <1>; 178 #size-cells = <0>; 179 phy1: ethernet-phy@1 { 180 device_type = "ethernet-phy"; 181 reg = <1>; 182 }; 183 }; 184 }; 185