mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-06-28 17:41:50 +00:00
docs: networking: dpaa2: add documentation for the switch driver
Add a documentation entry for the DPAA2 switch listing its requirements, features and some examples to go along them. Signed-off-by: Ioana Ciornei <ioana.ciornei@nxp.com> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
453a343c5a
commit
d4b996f9ef
3 changed files with 176 additions and 0 deletions
|
@ -9,3 +9,4 @@ DPAA2 Documentation
|
||||||
dpio-driver
|
dpio-driver
|
||||||
ethernet-driver
|
ethernet-driver
|
||||||
mac-phy-support
|
mac-phy-support
|
||||||
|
switch-driver
|
||||||
|
|
|
@ -0,0 +1,174 @@
|
||||||
|
.. SPDX-License-Identifier: GPL-2.0
|
||||||
|
.. include:: <isonum.txt>
|
||||||
|
|
||||||
|
===================
|
||||||
|
DPAA2 Switch driver
|
||||||
|
===================
|
||||||
|
|
||||||
|
:Copyright: |copy| 2021 NXP
|
||||||
|
|
||||||
|
The DPAA2 Switch driver probes on the Datapath Switch (DPSW) object which can
|
||||||
|
be instantiated on the following DPAA2 SoCs and their variants: LS2088A and
|
||||||
|
LX2160A.
|
||||||
|
|
||||||
|
The driver uses the switch device driver model and exposes each switch port as
|
||||||
|
a network interface, which can be included in a bridge or used as a standalone
|
||||||
|
interface. Traffic switched between ports is offloaded into the hardware.
|
||||||
|
|
||||||
|
The DPSW can have ports connected to DPNIs or to DPMACs for external access.
|
||||||
|
::
|
||||||
|
|
||||||
|
[ethA] [ethB] [ethC] [ethD] [ethE] [ethF]
|
||||||
|
: : : : : :
|
||||||
|
: : : : : :
|
||||||
|
[dpaa2-eth] [dpaa2-eth] [ dpaa2-switch ]
|
||||||
|
: : : : : : kernel
|
||||||
|
=============================================================================
|
||||||
|
: : : : : : hardware
|
||||||
|
[DPNI] [DPNI] [============= DPSW =================]
|
||||||
|
| | | | | |
|
||||||
|
| ---------- | [DPMAC] [DPMAC]
|
||||||
|
------------------------------- | |
|
||||||
|
| |
|
||||||
|
[PHY] [PHY]
|
||||||
|
|
||||||
|
Creating an Ethernet Switch
|
||||||
|
===========================
|
||||||
|
|
||||||
|
The dpaa2-switch driver probes on DPSW devices found on the fsl-mc bus. These
|
||||||
|
devices can be either created statically through the boot time configuration
|
||||||
|
file - DataPath Layout (DPL) - or at runtime using the DPAA2 object APIs
|
||||||
|
(incorporated already into the restool userspace tool).
|
||||||
|
|
||||||
|
At the moment, the dpaa2-switch driver imposes the following restrictions on
|
||||||
|
the DPSW object that it will probe:
|
||||||
|
|
||||||
|
* The minimum number of FDBs should be at least equal to the number of switch
|
||||||
|
interfaces. This is necessary so that separation of switch ports can be
|
||||||
|
done, ie when not under a bridge, each switch port will have its own FDB.
|
||||||
|
::
|
||||||
|
|
||||||
|
fsl_dpaa2_switch dpsw.0: The number of FDBs is lower than the number of ports, cannot probe
|
||||||
|
|
||||||
|
* Both the broadcast and flooding configuration should be per FDB. This
|
||||||
|
enables the driver to restrict the broadcast and flooding domains of each
|
||||||
|
FDB depending on the switch ports that are sharing it (aka are under the
|
||||||
|
same bridge).
|
||||||
|
::
|
||||||
|
|
||||||
|
fsl_dpaa2_switch dpsw.0: Flooding domain is not per FDB, cannot probe
|
||||||
|
fsl_dpaa2_switch dpsw.0: Broadcast domain is not per FDB, cannot probe
|
||||||
|
|
||||||
|
* The control interface of the switch should not be disabled
|
||||||
|
(DPSW_OPT_CTRL_IF_DIS not passed as a create time option). Without the
|
||||||
|
control interface, the driver is not capable to provide proper Rx/Tx traffic
|
||||||
|
support on the switch port netdevices.
|
||||||
|
::
|
||||||
|
|
||||||
|
fsl_dpaa2_switch dpsw.0: Control Interface is disabled, cannot probe
|
||||||
|
|
||||||
|
Besides the configuration of the actual DPSW object, the dpaa2-switch driver
|
||||||
|
will need the following DPAA2 objects:
|
||||||
|
|
||||||
|
* 1 DPMCP - A Management Command Portal object is needed for any interraction
|
||||||
|
with the MC firmware.
|
||||||
|
|
||||||
|
* 1 DPBP - A Buffer Pool is used for seeding buffers intended for the Rx path
|
||||||
|
on the control interface.
|
||||||
|
|
||||||
|
* Access to at least one DPIO object (Software Portal) is needed for any
|
||||||
|
enqueue/dequeue operation to be performed on the control interface queues.
|
||||||
|
The DPIO object will be shared, no need for a private one.
|
||||||
|
|
||||||
|
Switching features
|
||||||
|
==================
|
||||||
|
|
||||||
|
The driver supports the configuration of L2 forwarding rules in hardware for
|
||||||
|
port bridging as well as standalone usage of the independent switch interfaces.
|
||||||
|
|
||||||
|
The hardware is not configurable with respect to VLAN awareness, thus any DPAA2
|
||||||
|
switch port should be used only in usecases with a VLAN aware bridge::
|
||||||
|
|
||||||
|
$ ip link add dev br0 type bridge vlan_filtering 1
|
||||||
|
|
||||||
|
$ ip link add dev br1 type bridge
|
||||||
|
$ ip link set dev ethX master br1
|
||||||
|
Error: fsl_dpaa2_switch: Cannot join a VLAN-unaware bridge
|
||||||
|
|
||||||
|
Topology and loop detection through STP is supported when ``stp_state 1`` is
|
||||||
|
used at bridge create ::
|
||||||
|
|
||||||
|
$ ip link add dev br0 type bridge vlan_filtering 1 stp_state 1
|
||||||
|
|
||||||
|
L2 FDB manipulation (add/delete/dump) is supported.
|
||||||
|
|
||||||
|
HW FDB learning can be configured on each switch port independently through
|
||||||
|
bridge commands. When the HW learning is disabled, a fast age procedure will be
|
||||||
|
run and any previously learnt addresses will be removed.
|
||||||
|
::
|
||||||
|
|
||||||
|
$ bridge link set dev ethX learning off
|
||||||
|
$ bridge link set dev ethX learning on
|
||||||
|
|
||||||
|
Restricting the unknown unicast and multicast flooding domain is supported, but
|
||||||
|
not independently of each other::
|
||||||
|
|
||||||
|
$ ip link set dev ethX type bridge_slave flood off mcast_flood off
|
||||||
|
$ ip link set dev ethX type bridge_slave flood off mcast_flood on
|
||||||
|
Error: fsl_dpaa2_switch: Cannot configure multicast flooding independently of unicast.
|
||||||
|
|
||||||
|
Broadcast flooding on a switch port can be disabled/enabled through the brport sysfs::
|
||||||
|
|
||||||
|
$ echo 0 > /sys/bus/fsl-mc/devices/dpsw.Y/net/ethX/brport/broadcast_flood
|
||||||
|
|
||||||
|
Offloads
|
||||||
|
========
|
||||||
|
|
||||||
|
Routing actions (redirect, trap, drop)
|
||||||
|
--------------------------------------
|
||||||
|
|
||||||
|
The DPAA2 switch is able to offload flow-based redirection of packets making
|
||||||
|
use of ACL tables. Shared filter blocks are supported by sharing a single ACL
|
||||||
|
table between multiple ports.
|
||||||
|
|
||||||
|
The following flow keys are supported:
|
||||||
|
|
||||||
|
* Ethernet: dst_mac/src_mac
|
||||||
|
* IPv4: dst_ip/src_ip/ip_proto/tos
|
||||||
|
* VLAN: vlan_id/vlan_prio/vlan_tpid/vlan_dei
|
||||||
|
* L4: dst_port/src_port
|
||||||
|
|
||||||
|
Also, the matchall filter can be used to redirect the entire traffic received
|
||||||
|
on a port.
|
||||||
|
|
||||||
|
As per flow actions, the following are supported:
|
||||||
|
|
||||||
|
* drop
|
||||||
|
* mirred egress redirect
|
||||||
|
* trap
|
||||||
|
|
||||||
|
Each ACL entry (filter) can be setup with only one of the listed
|
||||||
|
actions.
|
||||||
|
|
||||||
|
Example 1: send frames received on eth4 with a SA of 00:01:02:03:04:05 to the
|
||||||
|
CPU::
|
||||||
|
|
||||||
|
$ tc qdisc add dev eth4 clsact
|
||||||
|
$ tc filter add dev eth4 ingress flower src_mac 00:01:02:03:04:05 skip_sw action trap
|
||||||
|
|
||||||
|
Example 2: drop frames received on eth4 with VID 100 and PCP of 3::
|
||||||
|
|
||||||
|
$ tc filter add dev eth4 ingress protocol 802.1q flower skip_sw vlan_id 100 vlan_prio 3 action drop
|
||||||
|
|
||||||
|
Example 3: redirect all frames received on eth4 to eth1::
|
||||||
|
|
||||||
|
$ tc filter add dev eth4 ingress matchall action mirred egress redirect dev eth1
|
||||||
|
|
||||||
|
Example 4: Use a single shared filter block on both eth5 and eth6::
|
||||||
|
|
||||||
|
$ tc qdisc add dev eth5 ingress_block 1 clsact
|
||||||
|
$ tc qdisc add dev eth6 ingress_block 1 clsact
|
||||||
|
$ tc filter add block 1 ingress flower dst_mac 00:01:02:03:04:04 skip_sw \
|
||||||
|
action trap
|
||||||
|
$ tc filter add block 1 ingress protocol ipv4 flower src_ip 192.168.1.1 skip_sw \
|
||||||
|
action mirred egress redirect dev eth3
|
|
@ -5684,6 +5684,7 @@ DPAA2 ETHERNET SWITCH DRIVER
|
||||||
M: Ioana Ciornei <ioana.ciornei@nxp.com>
|
M: Ioana Ciornei <ioana.ciornei@nxp.com>
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
F: Documentation/networking/device_drivers/ethernet/freescale/dpaa2/switch-driver.rst
|
||||||
F: drivers/net/ethernet/freescale/dpaa2/dpaa2-switch*
|
F: drivers/net/ethernet/freescale/dpaa2/dpaa2-switch*
|
||||||
F: drivers/net/ethernet/freescale/dpaa2/dpsw*
|
F: drivers/net/ethernet/freescale/dpaa2/dpsw*
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue