77 lines
2.6 KiB
ReStructuredText
77 lines
2.6 KiB
ReStructuredText
|
.. SPDX-License-Identifier: GPL-2.0
|
||
|
|
||
|
==========================
|
||
|
Devlink E-Switch Attribute
|
||
|
==========================
|
||
|
|
||
|
Devlink E-Switch supports two modes of operation: legacy and switchdev.
|
||
|
Legacy mode operates based on traditional MAC/VLAN steering rules. Switching
|
||
|
decisions are made based on MAC addresses, VLANs, etc. There is limited ability
|
||
|
to offload switching rules to hardware.
|
||
|
|
||
|
On the other hand, switchdev mode allows for more advanced offloading
|
||
|
capabilities of the E-Switch to hardware. In switchdev mode, more switching
|
||
|
rules and logic can be offloaded to the hardware switch ASIC. It enables
|
||
|
representor netdevices that represent the slow path of virtual functions (VFs)
|
||
|
or scalable-functions (SFs) of the device. See more information about
|
||
|
:ref:`Documentation/networking/switchdev.rst <switchdev>` and
|
||
|
:ref:`Documentation/networking/representors.rst <representors>`.
|
||
|
|
||
|
In addition, the devlink E-Switch also comes with other attributes listed
|
||
|
in the following section.
|
||
|
|
||
|
Attributes Description
|
||
|
======================
|
||
|
|
||
|
The following is a list of E-Switch attributes.
|
||
|
|
||
|
.. list-table:: E-Switch attributes
|
||
|
:widths: 8 5 45
|
||
|
|
||
|
* - Name
|
||
|
- Type
|
||
|
- Description
|
||
|
* - ``mode``
|
||
|
- enum
|
||
|
- The mode of the device. The mode can be one of the following:
|
||
|
|
||
|
* ``legacy`` operates based on traditional MAC/VLAN steering
|
||
|
rules.
|
||
|
* ``switchdev`` allows for more advanced offloading capabilities of
|
||
|
the E-Switch to hardware.
|
||
|
* - ``inline-mode``
|
||
|
- enum
|
||
|
- Some HWs need the VF driver to put part of the packet
|
||
|
headers on the TX descriptor so the e-switch can do proper
|
||
|
matching and steering. Support for both switchdev mode and legacy mode.
|
||
|
|
||
|
* ``none`` none.
|
||
|
* ``link`` L2 mode.
|
||
|
* ``network`` L3 mode.
|
||
|
* ``transport`` L4 mode.
|
||
|
* - ``encap-mode``
|
||
|
- enum
|
||
|
- The encapsulation mode of the device. Support for both switchdev mode
|
||
|
and legacy mode. The mode can be one of the following:
|
||
|
|
||
|
* ``none`` Disable encapsulation support.
|
||
|
* ``basic`` Enable encapsulation support.
|
||
|
|
||
|
Example Usage
|
||
|
=============
|
||
|
|
||
|
.. code:: shell
|
||
|
|
||
|
# enable switchdev mode
|
||
|
$ devlink dev eswitch set pci/0000:08:00.0 mode switchdev
|
||
|
|
||
|
# set inline-mode and encap-mode
|
||
|
$ devlink dev eswitch set pci/0000:08:00.0 inline-mode none encap-mode basic
|
||
|
|
||
|
# display devlink device eswitch attributes
|
||
|
$ devlink dev eswitch show pci/0000:08:00.0
|
||
|
pci/0000:08:00.0: mode switchdev inline-mode none encap-mode basic
|
||
|
|
||
|
# enable encap-mode with legacy mode
|
||
|
$ devlink dev eswitch set pci/0000:08:00.0 mode legacy inline-mode none encap-mode basic
|