mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

The rtnetlink family names are set to rt-$name within the YAML but the files are called rt_$name. C codegen assumes that the generated file name will match the family. The use of dashes is in line with our general expectation that name properties in the spec use dashes not underscores (even tho, as Donald points out most genl families use underscores in the name). We have 3 un-ideal options to choose from: - accept the slight inconsistency with old families using _, or - accept the slight annoyance with all languages having to do s/-/_/ when looking up family ID, or - accept the inconsistency with all name properties in new YAML spec being separated with - and just the family name always using _. Pick option 1 and rename the rtnl spec files. Reviewed-by: Jacob Keller <jacob.e.keller@intel.com> Reviewed-by: Donald Hunter <donald.hunter@gmail.com> Link: https://patch.msgid.link/20250410014658.782120-2-kuba@kernel.org Signed-off-by: Jakub Kicinski <kuba@kernel.org>
194 lines
5.5 KiB
ReStructuredText
194 lines
5.5 KiB
ReStructuredText
.. SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
======================================================
|
|
Netlink specification support for raw Netlink families
|
|
======================================================
|
|
|
|
This document describes the additional properties required by raw Netlink
|
|
families such as ``NETLINK_ROUTE`` which use the ``netlink-raw`` protocol
|
|
specification.
|
|
|
|
Specification
|
|
=============
|
|
|
|
The netlink-raw schema extends the :doc:`genetlink-legacy <genetlink-legacy>`
|
|
schema with properties that are needed to specify the protocol numbers and
|
|
multicast IDs used by raw netlink families. See :ref:`classic_netlink` for more
|
|
information. The raw netlink families also make use of type-specific
|
|
sub-messages.
|
|
|
|
Globals
|
|
-------
|
|
|
|
protonum
|
|
~~~~~~~~
|
|
|
|
The ``protonum`` property is used to specify the protocol number to use when
|
|
opening a netlink socket.
|
|
|
|
.. code-block:: yaml
|
|
|
|
# SPDX-License-Identifier: ((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause)
|
|
|
|
name: rt-addr
|
|
protocol: netlink-raw
|
|
protonum: 0 # part of the NETLINK_ROUTE protocol
|
|
|
|
|
|
Multicast group properties
|
|
--------------------------
|
|
|
|
value
|
|
~~~~~
|
|
|
|
The ``value`` property is used to specify the group ID to use for multicast
|
|
group registration.
|
|
|
|
.. code-block:: yaml
|
|
|
|
mcast-groups:
|
|
list:
|
|
-
|
|
name: rtnlgrp-ipv4-ifaddr
|
|
value: 5
|
|
-
|
|
name: rtnlgrp-ipv6-ifaddr
|
|
value: 9
|
|
-
|
|
name: rtnlgrp-mctp-ifaddr
|
|
value: 34
|
|
|
|
Sub-messages
|
|
------------
|
|
|
|
Several raw netlink families such as
|
|
:doc:`rt-link<../../networking/netlink_spec/rt-link>` and
|
|
:doc:`tc<../../networking/netlink_spec/tc>` use attribute nesting as an
|
|
abstraction to carry module specific information.
|
|
|
|
Conceptually it looks as follows::
|
|
|
|
[OUTER NEST OR MESSAGE LEVEL]
|
|
[GENERIC ATTR 1]
|
|
[GENERIC ATTR 2]
|
|
[GENERIC ATTR 3]
|
|
[GENERIC ATTR - wrapper]
|
|
[MODULE SPECIFIC ATTR 1]
|
|
[MODULE SPECIFIC ATTR 2]
|
|
|
|
The ``GENERIC ATTRs`` at the outer level are defined in the core (or rt_link or
|
|
core TC), while specific drivers, TC classifiers, qdiscs etc. can carry their
|
|
own information wrapped in the ``GENERIC ATTR - wrapper``. Even though the
|
|
example above shows attributes nesting inside the wrapper, the modules generally
|
|
have full freedom to define the format of the nest. In practice the payload of
|
|
the wrapper attr has very similar characteristics to a netlink message. It may
|
|
contain a fixed header / structure, netlink attributes, or both. Because of
|
|
those shared characteristics we refer to the payload of the wrapper attribute as
|
|
a sub-message.
|
|
|
|
A sub-message attribute uses the value of another attribute as a selector key to
|
|
choose the right sub-message format. For example if the following attribute has
|
|
already been decoded:
|
|
|
|
.. code-block:: json
|
|
|
|
{ "kind": "gre" }
|
|
|
|
and we encounter the following attribute spec:
|
|
|
|
.. code-block:: yaml
|
|
|
|
-
|
|
name: data
|
|
type: sub-message
|
|
sub-message: linkinfo-data-msg
|
|
selector: kind
|
|
|
|
Then we look for a sub-message definition called ``linkinfo-data-msg`` and use
|
|
the value of the ``kind`` attribute i.e. ``gre`` as the key to choose the
|
|
correct format for the sub-message:
|
|
|
|
.. code-block:: yaml
|
|
|
|
sub-messages:
|
|
name: linkinfo-data-msg
|
|
formats:
|
|
-
|
|
value: bridge
|
|
attribute-set: linkinfo-bridge-attrs
|
|
-
|
|
value: gre
|
|
attribute-set: linkinfo-gre-attrs
|
|
-
|
|
value: geneve
|
|
attribute-set: linkinfo-geneve-attrs
|
|
|
|
This would decode the attribute value as a sub-message with the attribute-set
|
|
called ``linkinfo-gre-attrs`` as the attribute space.
|
|
|
|
A sub-message can have an optional ``fixed-header`` followed by zero or more
|
|
attributes from an ``attribute-set``. For example the following
|
|
``tc-options-msg`` sub-message defines message formats that use a mixture of
|
|
``fixed-header``, ``attribute-set`` or both together:
|
|
|
|
.. code-block:: yaml
|
|
|
|
sub-messages:
|
|
-
|
|
name: tc-options-msg
|
|
formats:
|
|
-
|
|
value: bfifo
|
|
fixed-header: tc-fifo-qopt
|
|
-
|
|
value: cake
|
|
attribute-set: tc-cake-attrs
|
|
-
|
|
value: netem
|
|
fixed-header: tc-netem-qopt
|
|
attribute-set: tc-netem-attrs
|
|
|
|
Note that a selector attribute must appear in a netlink message before any
|
|
sub-message attributes that depend on it.
|
|
|
|
If an attribute such as ``kind`` is defined at more than one nest level, then a
|
|
sub-message selector will be resolved using the value 'closest' to the selector.
|
|
For example, if the same attribute name is defined in a nested ``attribute-set``
|
|
alongside a sub-message selector and also in a top level ``attribute-set``, then
|
|
the selector will be resolved using the value 'closest' to the selector. If the
|
|
value is not present in the message at the same level as defined in the spec
|
|
then this is an error.
|
|
|
|
Nested struct definitions
|
|
-------------------------
|
|
|
|
Many raw netlink families such as :doc:`tc<../../networking/netlink_spec/tc>`
|
|
make use of nested struct definitions. The ``netlink-raw`` schema makes it
|
|
possible to embed a struct within a struct definition using the ``struct``
|
|
property. For example, the following struct definition embeds the
|
|
``tc-ratespec`` struct definition for both the ``rate`` and the ``peakrate``
|
|
members of ``struct tc-tbf-qopt``.
|
|
|
|
.. code-block:: yaml
|
|
|
|
-
|
|
name: tc-tbf-qopt
|
|
type: struct
|
|
members:
|
|
-
|
|
name: rate
|
|
type: binary
|
|
struct: tc-ratespec
|
|
-
|
|
name: peakrate
|
|
type: binary
|
|
struct: tc-ratespec
|
|
-
|
|
name: limit
|
|
type: u32
|
|
-
|
|
name: buffer
|
|
type: u32
|
|
-
|
|
name: mtu
|
|
type: u32
|