mirror of
https://github.com/torvalds/linux.git
synced 2024-11-24 05:02:12 +00:00
321f7ab0d4
The switch ASIC has a limited capacity of physical ('flavour physical' in devlink terminology) ports that it can support. While each system is brought up with a different number of ports, this number can be increased via splitting up to the ASIC's limit. Expose physical ports as a devlink resource so that user space will have visibility to the maximum number of ports that can be supported and the current occupancy. In addition, add a "Generic Resources" section in devlink-resource documentation so the different drivers will be aligned by the same resource name when exposing to user space. Signed-off-by: Danielle Ratson <danieller@nvidia.com> Reviewed-by: Jiri Pirko <jiri@nvidia.com> Signed-off-by: Ido Schimmel <idosch@nvidia.com> Signed-off-by: Jakub Kicinski <kuba@kernel.org>
77 lines
2.7 KiB
ReStructuredText
77 lines
2.7 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0
|
|
|
|
================
|
|
Devlink Resource
|
|
================
|
|
|
|
``devlink`` provides the ability for drivers to register resources, which
|
|
can allow administrators to see the device restrictions for a given
|
|
resource, as well as how much of the given resource is currently
|
|
in use. Additionally, these resources can optionally have configurable size.
|
|
This could enable the administrator to limit the number of resources that
|
|
are used.
|
|
|
|
For example, the ``netdevsim`` driver enables ``/IPv4/fib`` and
|
|
``/IPv4/fib-rules`` as resources to limit the number of IPv4 FIB entries and
|
|
rules for a given device.
|
|
|
|
Resource Ids
|
|
============
|
|
|
|
Each resource is represented by an id, and contains information about its
|
|
current size and related sub resources. To access a sub resource, you
|
|
specify the path of the resource. For example ``/IPv4/fib`` is the id for
|
|
the ``fib`` sub-resource under the ``IPv4`` resource.
|
|
|
|
Generic Resources
|
|
=================
|
|
|
|
Generic resources are used to describe resources that can be shared by multiple
|
|
device drivers and their description must be added to the following table:
|
|
|
|
.. list-table:: List of Generic Resources
|
|
:widths: 10 90
|
|
|
|
* - Name
|
|
- Description
|
|
* - ``physical_ports``
|
|
- A limited capacity of physical ports that the switch ASIC can support
|
|
|
|
example usage
|
|
-------------
|
|
|
|
The resources exposed by the driver can be observed, for example:
|
|
|
|
.. code:: shell
|
|
|
|
$devlink resource show pci/0000:03:00.0
|
|
pci/0000:03:00.0:
|
|
name kvd size 245760 unit entry
|
|
resources:
|
|
name linear size 98304 occ 0 unit entry size_min 0 size_max 147456 size_gran 128
|
|
name hash_double size 60416 unit entry size_min 32768 size_max 180224 size_gran 128
|
|
name hash_single size 87040 unit entry size_min 65536 size_max 212992 size_gran 128
|
|
|
|
Some resource's size can be changed. Examples:
|
|
|
|
.. code:: shell
|
|
|
|
$devlink resource set pci/0000:03:00.0 path /kvd/hash_single size 73088
|
|
$devlink resource set pci/0000:03:00.0 path /kvd/hash_double size 74368
|
|
|
|
The changes do not apply immediately, this can be validated by the 'size_new'
|
|
attribute, which represents the pending change in size. For example:
|
|
|
|
.. code:: shell
|
|
|
|
$devlink resource show pci/0000:03:00.0
|
|
pci/0000:03:00.0:
|
|
name kvd size 245760 unit entry size_valid false
|
|
resources:
|
|
name linear size 98304 size_new 147456 occ 0 unit entry size_min 0 size_max 147456 size_gran 128
|
|
name hash_double size 60416 unit entry size_min 32768 size_max 180224 size_gran 128
|
|
name hash_single size 87040 unit entry size_min 65536 size_max 212992 size_gran 128
|
|
|
|
Note that changes in resource size may require a device reload to properly
|
|
take effect.
|