mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-11-01 00:48:50 +00:00
5e63c5ef7a
Xilinx 1G/2.5G Ethernet Subsystem provides 32-bit AXI4-Stream buses to move transmit and receive Ethernet data to and from the subsystem. These buses are designed to be used with an AXI Direct Memory Access(DMA) IP or AXI Multichannel Direct Memory Access (MCDMA) IP core, AXI4-Stream Data FIFO, or any other custom logic in any supported device. Primary high-speed DMA data movement between system memory and stream target is through the AXI4 Read Master to AXI4 memory-mapped to stream (MM2S) Master, and AXI stream to memory-mapped (S2MM) Slave to AXI4 Write Master. AXI DMA/MCDMA enables channel of data movement on both MM2S and S2MM paths in scatter/gather mode. AXI DMA has two channels where as MCDMA has 16 Tx and 16 Rx channels. To uniquely identify each channel use 'chan' suffix. Depending on the usecase AXI ethernet driver can request any combination of multichannel DMA channels using generic dmas, dma-names properties. Example: dma-names = tx_chan0, rx_chan0, tx_chan1, rx_chan1; Signed-off-by: Radhey Shyam Pandey <radhey.shyam.pandey@amd.com> Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://lore.kernel.org/r/1700074613-1977070-2-git-send-email-radhey.shyam.pandey@amd.com Signed-off-by: Jakub Kicinski <kuba@kernel.org>
199 lines
6 KiB
YAML
199 lines
6 KiB
YAML
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
|
|
%YAML 1.2
|
|
---
|
|
$id: http://devicetree.org/schemas/net/xlnx,axi-ethernet.yaml#
|
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
|
|
|
title: AXI 1G/2.5G Ethernet Subsystem
|
|
|
|
description: |
|
|
Also called AXI 1G/2.5G Ethernet Subsystem, the xilinx axi ethernet IP core
|
|
provides connectivity to an external ethernet PHY supporting different
|
|
interfaces: MII, GMII, RGMII, SGMII, 1000BaseX. It also includes two
|
|
segments of memory for buffering TX and RX, as well as the capability of
|
|
offloading TX/RX checksum calculation off the processor.
|
|
|
|
Management configuration is done through the AXI interface, while payload is
|
|
sent and received through means of an AXI DMA controller. This driver
|
|
includes the DMA driver code, so this driver is incompatible with AXI DMA
|
|
driver.
|
|
|
|
maintainers:
|
|
- Radhey Shyam Pandey <radhey.shyam.pandey@xilinx.com>
|
|
|
|
properties:
|
|
compatible:
|
|
enum:
|
|
- xlnx,axi-ethernet-1.00.a
|
|
- xlnx,axi-ethernet-1.01.a
|
|
- xlnx,axi-ethernet-2.01.a
|
|
|
|
reg:
|
|
description:
|
|
Address and length of the IO space, as well as the address
|
|
and length of the AXI DMA controller IO space, unless
|
|
axistream-connected is specified, in which case the reg
|
|
attribute of the node referenced by it is used.
|
|
maxItems: 2
|
|
|
|
interrupts:
|
|
items:
|
|
- description: Ethernet core interrupt
|
|
- description: Tx DMA interrupt
|
|
- description: Rx DMA interrupt
|
|
description:
|
|
Ethernet core interrupt is optional. If axistream-connected property is
|
|
present DMA node should contains TX/RX DMA interrupts else DMA interrupt
|
|
resources are mentioned on ethernet node.
|
|
minItems: 1
|
|
|
|
phy-handle: true
|
|
|
|
xlnx,rxmem:
|
|
description:
|
|
Set to allocated memory buffer for Rx/Tx in the hardware.
|
|
$ref: /schemas/types.yaml#/definitions/uint32
|
|
|
|
phy-mode:
|
|
enum:
|
|
- mii
|
|
- gmii
|
|
- rgmii
|
|
- sgmii
|
|
- 1000BaseX
|
|
|
|
xlnx,phy-type:
|
|
description:
|
|
Do not use, but still accepted in preference to phy-mode.
|
|
deprecated: true
|
|
$ref: /schemas/types.yaml#/definitions/uint32
|
|
|
|
xlnx,txcsum:
|
|
description:
|
|
TX checksum offload. 0 or empty for disabling TX checksum offload,
|
|
1 to enable partial TX checksum offload and 2 to enable full TX
|
|
checksum offload.
|
|
$ref: /schemas/types.yaml#/definitions/uint32
|
|
enum: [0, 1, 2]
|
|
|
|
xlnx,rxcsum:
|
|
description:
|
|
RX checksum offload. 0 or empty for disabling RX checksum offload,
|
|
1 to enable partial RX checksum offload and 2 to enable full RX
|
|
checksum offload.
|
|
$ref: /schemas/types.yaml#/definitions/uint32
|
|
enum: [0, 1, 2]
|
|
|
|
xlnx,switch-x-sgmii:
|
|
type: boolean
|
|
description:
|
|
Indicate the Ethernet core is configured to support both 1000BaseX and
|
|
SGMII modes. If set, the phy-mode should be set to match the mode
|
|
selected on core reset (i.e. by the basex_or_sgmii core input line).
|
|
|
|
clocks:
|
|
items:
|
|
- description: Clock for AXI register slave interface.
|
|
- description: AXI4-Stream clock for TXD RXD TXC and RXS interfaces.
|
|
- description: Ethernet reference clock, used by signal delay primitives
|
|
and transceivers.
|
|
- description: MGT reference clock (used by optional internal PCS/PMA PHY)
|
|
|
|
clock-names:
|
|
items:
|
|
- const: s_axi_lite_clk
|
|
- const: axis_clk
|
|
- const: ref_clk
|
|
- const: mgt_clk
|
|
|
|
axistream-connected:
|
|
$ref: /schemas/types.yaml#/definitions/phandle
|
|
description: Phandle of AXI DMA controller which contains the resources
|
|
used by this device. If this is specified, the DMA-related resources
|
|
from that device (DMA registers and DMA TX/RX interrupts) rather than
|
|
this one will be used.
|
|
|
|
mdio:
|
|
type: object
|
|
|
|
pcs-handle:
|
|
description: Phandle to the internal PCS/PMA PHY in SGMII or 1000Base-X
|
|
modes, where "pcs-handle" should be used to point to the PCS/PMA PHY,
|
|
and "phy-handle" should point to an external PHY if exists.
|
|
maxItems: 1
|
|
|
|
dmas:
|
|
minItems: 2
|
|
maxItems: 32
|
|
description: TX and RX DMA channel phandle
|
|
|
|
dma-names:
|
|
items:
|
|
pattern: "^[tr]x_chan([0-9]|1[0-5])$"
|
|
description:
|
|
Should be "tx_chan0", "tx_chan1" ... "tx_chan15" for DMA Tx channel
|
|
Should be "rx_chan0", "rx_chan1" ... "rx_chan15" for DMA Rx channel
|
|
minItems: 2
|
|
maxItems: 32
|
|
|
|
required:
|
|
- compatible
|
|
- interrupts
|
|
- reg
|
|
- xlnx,rxmem
|
|
- phy-handle
|
|
|
|
allOf:
|
|
- $ref: /schemas/net/ethernet-controller.yaml#
|
|
|
|
additionalProperties: false
|
|
|
|
examples:
|
|
- |
|
|
axi_ethernet_eth: ethernet@40c00000 {
|
|
compatible = "xlnx,axi-ethernet-1.00.a";
|
|
interrupts = <2 0 1>;
|
|
clock-names = "s_axi_lite_clk", "axis_clk", "ref_clk", "mgt_clk";
|
|
clocks = <&axi_clk>, <&axi_clk>, <&pl_enet_ref_clk>, <&mgt_clk>;
|
|
phy-mode = "mii";
|
|
reg = <0x40c00000 0x40000>,<0x50c00000 0x40000>;
|
|
dmas = <&xilinx_dma 0>, <&xilinx_dma 1>;
|
|
dma-names = "tx_chan0", "rx_chan0";
|
|
xlnx,rxcsum = <0x2>;
|
|
xlnx,rxmem = <0x800>;
|
|
xlnx,txcsum = <0x2>;
|
|
phy-handle = <&phy0>;
|
|
|
|
mdio {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
phy0: ethernet-phy@1 {
|
|
device_type = "ethernet-phy";
|
|
reg = <1>;
|
|
};
|
|
};
|
|
};
|
|
|
|
- |
|
|
axi_ethernet_eth1: ethernet@40000000 {
|
|
compatible = "xlnx,axi-ethernet-1.00.a";
|
|
interrupts = <0>;
|
|
clock-names = "s_axi_lite_clk", "axis_clk", "ref_clk", "mgt_clk";
|
|
clocks = <&axi_clk>, <&axi_clk>, <&pl_enet_ref_clk>, <&mgt_clk>;
|
|
phy-mode = "mii";
|
|
reg = <0x00 0x40000000 0x00 0x40000>;
|
|
xlnx,rxcsum = <0x2>;
|
|
xlnx,rxmem = <0x800>;
|
|
xlnx,txcsum = <0x2>;
|
|
phy-handle = <&phy1>;
|
|
axistream-connected = <&dma>;
|
|
|
|
mdio {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
phy1: ethernet-phy@1 {
|
|
device_type = "ethernet-phy";
|
|
reg = <1>;
|
|
};
|
|
};
|
|
};
|