1.. SPDX-License-Identifier: BSD-3-Clause 2 3========================================= 4Netlink protocol specifications (in YAML) 5========================================= 6 7Netlink protocol specifications are complete, machine readable descriptions of 8Netlink protocols written in YAML. The goal of the specifications is to allow 9separating Netlink parsing from user space logic and minimize the amount of 10hand written Netlink code for each new family, command, attribute. 11Netlink specs should be complete and not depend on any other spec 12or C header file, making it easy to use in languages which can't include 13kernel headers directly. 14 15Internally kernel uses the YAML specs to generate: 16 17 - the C uAPI header 18 - documentation of the protocol as a ReST file 19 - policy tables for input attribute validation 20 - operation tables 21 22YAML specifications can be found under ``Documentation/netlink/specs/`` 23 24This document describes details of the schema. 25See :doc:`intro-specs` for a practical starting guide. 26 27All specs must be licensed under 28``((GPL-2.0 WITH Linux-syscall-note) OR BSD-3-Clause)`` 29to allow for easy adoption in user space code. 30 31Compatibility levels 32==================== 33 34There are four schema levels for Netlink specs, from the simplest used 35by new families to the most complex covering all the quirks of the old ones. 36Each next level inherits the attributes of the previous level, meaning that 37user capable of parsing more complex ``genetlink`` schemas is also compatible 38with simpler ones. The levels are: 39 40 - ``genetlink`` - most streamlined, should be used by all new families 41 - ``genetlink-c`` - superset of ``genetlink`` with extra attributes allowing 42 customization of define and enum type and value names; this schema should 43 be equivalent to ``genetlink`` for all implementations which don't interact 44 directly with C uAPI headers 45 - ``genetlink-legacy`` - Generic Netlink catch all schema supporting quirks of 46 all old genetlink families, strange attribute formats, binary structures etc. 47 - ``netlink-raw`` - catch all schema supporting pre-Generic Netlink protocols 48 such as ``NETLINK_ROUTE`` 49 50The definition of the schemas (in ``jsonschema``) can be found 51under ``Documentation/netlink/``. 52 53Schema structure 54================ 55 56YAML schema has the following conceptual sections: 57 58 - globals 59 - definitions 60 - attributes 61 - operations 62 - multicast groups 63 64Most properties in the schema accept (or in fact require) a ``doc`` 65sub-property documenting the defined object. 66 67The following sections describe the properties of the most modern ``genetlink`` 68schema. See the documentation of :doc:`genetlink-c <c-code-gen>` 69for information on how C names are derived from name properties. 70 71genetlink 72========= 73 74Globals 75------- 76 77Attributes listed directly at the root level of the spec file. 78 79name 80~~~~ 81 82Name of the family. Name identifies the family in a unique way, since 83the Family IDs are allocated dynamically. 84 85version 86~~~~~~~ 87 88Generic Netlink family version, default is 1. 89 90protocol 91~~~~~~~~ 92 93The schema level, default is ``genetlink``, which is the only value 94allowed for new ``genetlink`` families. 95 96definitions 97----------- 98 99Array of type and constant definitions. 100 101name 102~~~~ 103 104Name of the type / constant. 105 106type 107~~~~ 108 109One of the following types: 110 111 - const - a single, standalone constant 112 - enum - defines an integer enumeration, with values for each entry 113 incrementing by 1, (e.g. 0, 1, 2, 3) 114 - flags - defines an integer enumeration, with values for each entry 115 occupying a bit, starting from bit 0, (e.g. 1, 2, 4, 8) 116 117value 118~~~~~ 119 120The value for the ``const``. 121 122value-start 123~~~~~~~~~~~ 124 125The first value for ``enum`` and ``flags``, allows overriding the default 126start value of ``0`` (for ``enum``) and starting bit (for ``flags``). 127For ``flags`` ``value-start`` selects the starting bit, not the shifted value. 128 129Sparse enumerations are not supported. 130 131entries 132~~~~~~~ 133 134Array of names of the entries for ``enum`` and ``flags``. 135 136header 137~~~~~~ 138 139For C-compatible languages, header which already defines this value. 140In case the definition is shared by multiple families (e.g. ``IFNAMSIZ``) 141code generators for C-compatible languages may prefer to add an appropriate 142include instead of rendering a new definition. 143 144attribute-sets 145-------------- 146 147This property contains information about netlink attributes of the family. 148All families have at least one attribute set, most have multiple. 149``attribute-sets`` is an array, with each entry describing a single set. 150 151Note that the spec is "flattened" and is not meant to visually resemble 152the format of the netlink messages (unlike certain ad-hoc documentation 153formats seen in kernel comments). In the spec subordinate attribute sets 154are not defined inline as a nest, but defined in a separate attribute set 155referred to with a ``nested-attributes`` property of the container. 156 157Spec may also contain fractional sets - sets which contain a ``subset-of`` 158property. Such sets describe a section of a full set, allowing narrowing down 159which attributes are allowed in a nest or refining the validation criteria. 160Fractional sets can only be used in nests. They are not rendered to the uAPI 161in any fashion. 162 163name 164~~~~ 165 166Uniquely identifies the attribute set, operations and nested attributes 167refer to the sets by the ``name``. 168 169subset-of 170~~~~~~~~~ 171 172Re-defines a portion of another set (a fractional set). 173Allows narrowing down fields and changing validation criteria 174or even types of attributes depending on the nest in which they 175are contained. The ``value`` of each attribute in the fractional 176set is implicitly the same as in the main set. 177 178attributes 179~~~~~~~~~~ 180 181List of attributes in the set. 182 183Attribute properties 184-------------------- 185 186name 187~~~~ 188 189Identifies the attribute, unique within the set. 190 191type 192~~~~ 193 194Netlink attribute type, see :ref:`attr_types`. 195 196.. _assign_val: 197 198value 199~~~~~ 200 201Numerical attribute ID, used in serialized Netlink messages. 202The ``value`` property can be skipped, in which case the attribute ID 203will be the value of the previous attribute plus one (recursively) 204and ``1`` for the first attribute in the attribute set. 205 206Attributes (and operations) use ``1`` as the default value for the first 207entry (unlike enums in definitions which start from ``0``) because 208entry ``0`` is almost always reserved as undefined. Spec can explicitly 209set value to ``0`` if needed. 210 211Note that the ``value`` of an attribute is defined only in its main set 212(not in subsets). 213 214enum 215~~~~ 216 217For integer types specifies that values in the attribute belong 218to an ``enum`` or ``flags`` from the ``definitions`` section. 219 220enum-as-flags 221~~~~~~~~~~~~~ 222 223Treat ``enum`` as ``flags`` regardless of its type in ``definitions``. 224When both ``enum`` and ``flags`` forms are needed ``definitions`` should 225contain an ``enum`` and attributes which need the ``flags`` form should 226use this attribute. 227 228nested-attributes 229~~~~~~~~~~~~~~~~~ 230 231Identifies the attribute space for attributes nested within given attribute. 232Only valid for complex attributes which may have sub-attributes. 233 234multi-attr (arrays) 235~~~~~~~~~~~~~~~~~~~ 236 237Boolean property signifying that the attribute may be present multiple times. 238Allowing an attribute to repeat is the recommended way of implementing arrays 239(no extra nesting). 240 241byte-order 242~~~~~~~~~~ 243 244For integer types specifies attribute byte order - ``little-endian`` 245or ``big-endian``. 246 247checks 248~~~~~~ 249 250Input validation constraints used by the kernel. User space should query 251the policy of the running kernel using Generic Netlink introspection, 252rather than depend on what is specified in the spec file. 253 254The validation policy in the kernel is formed by combining the type 255definition (``type`` and ``nested-attributes``) and the ``checks``. 256 257sub-type 258~~~~~~~~ 259 260Legacy families have special ways of expressing arrays. ``sub-type`` can be 261used to define the type of array members in case array members are not 262fully defined as attributes (in a bona fide attribute space). For instance 263a C array of u32 values can be specified with ``type: binary`` and 264``sub-type: u32``. Binary types and legacy array formats are described in 265more detail in :doc:`genetlink-legacy`. 266 267operations 268---------- 269 270This section describes messages passed between the kernel and the user space. 271There are three types of entries in this section - operations, notifications 272and events. 273 274Operations describe the most common request - response communication. User 275sends a request and kernel replies. Each operation may contain any combination 276of the two modes familiar to netlink users - ``do`` and ``dump``. 277``do`` and ``dump`` in turn contain a combination of ``request`` and 278``response`` properties. If no explicit message with attributes is passed 279in a given direction (e.g. a ``dump`` which does not accept filter, or a ``do`` 280of a SET operation to which the kernel responds with just the netlink error 281code) ``request`` or ``response`` section can be skipped. 282``request`` and ``response`` sections list the attributes allowed in a message. 283The list contains only the names of attributes from a set referred 284to by the ``attribute-set`` property. 285 286Notifications and events both refer to the asynchronous messages sent by 287the kernel to members of a multicast group. The difference between the 288two is that a notification shares its contents with a GET operation 289(the name of the GET operation is specified in the ``notify`` property). 290This arrangement is commonly used for notifications about 291objects where the notification carries the full object definition. 292 293Events are more focused and carry only a subset of information rather than full 294object state (a made up example would be a link state change event with just 295the interface name and the new link state). Events contain the ``event`` 296property. Events are considered less idiomatic for netlink and notifications 297should be preferred. 298 299list 300~~~~ 301 302The only property of ``operations`` for ``genetlink``, holds the list of 303operations, notifications etc. 304 305Operation properties 306-------------------- 307 308name 309~~~~ 310 311Identifies the operation. 312 313value 314~~~~~ 315 316Numerical message ID, used in serialized Netlink messages. 317The same enumeration rules are applied as to 318:ref:`attribute values<assign_val>`. 319 320attribute-set 321~~~~~~~~~~~~~ 322 323Specifies the attribute set contained within the message. 324 325do 326~~~ 327 328Specification for the ``doit`` request. Should contain ``request``, ``reply`` 329or both of these properties, each holding a :ref:`attr_list`. 330 331dump 332~~~~ 333 334Specification for the ``dumpit`` request. Should contain ``request``, ``reply`` 335or both of these properties, each holding a :ref:`attr_list`. 336 337notify 338~~~~~~ 339 340Designates the message as a notification. Contains the name of the operation 341(possibly the same as the operation holding this property) which shares 342the contents with the notification (``do``). 343 344event 345~~~~~ 346 347Specification of attributes in the event, holds a :ref:`attr_list`. 348``event`` property is mutually exclusive with ``notify``. 349 350mcgrp 351~~~~~ 352 353Used with ``event`` and ``notify``, specifies which multicast group 354message belongs to. 355 356.. _attr_list: 357 358Message attribute list 359---------------------- 360 361``request``, ``reply`` and ``event`` properties have a single ``attributes`` 362property which holds the list of attribute names. 363 364Messages can also define ``pre`` and ``post`` properties which will be rendered 365as ``pre_doit`` and ``post_doit`` calls in the kernel (these properties should 366be ignored by user space). 367 368mcast-groups 369------------ 370 371This section lists the multicast groups of the family. 372 373list 374~~~~ 375 376The only property of ``mcast-groups`` for ``genetlink``, holds the list 377of groups. 378 379Multicast group properties 380-------------------------- 381 382name 383~~~~ 384 385Uniquely identifies the multicast group in the family. Similarly to 386Family ID, Multicast Group ID needs to be resolved at runtime, based 387on the name. 388 389.. _attr_types: 390 391Attribute types 392=============== 393 394This section describes the attribute types supported by the ``genetlink`` 395compatibility level. Refer to documentation of different levels for additional 396attribute types. 397 398Scalar integer types 399-------------------- 400 401Fixed-width integer types: 402``u8``, ``u16``, ``u32``, ``u64``, ``s8``, ``s16``, ``s32``, ``s64``. 403 404Note that types smaller than 32 bit should be avoided as using them 405does not save any memory in Netlink messages (due to alignment). 406See :ref:`pad_type` for padding of 64 bit attributes. 407 408The payload of the attribute is the integer in host order unless ``byte-order`` 409specifies otherwise. 410 411.. _pad_type: 412 413pad 414--- 415 416Special attribute type used for padding attributes which require alignment 417bigger than standard 4B alignment required by netlink (e.g. 64 bit integers). 418There can only be a single attribute of the ``pad`` type in any attribute set 419and it should be automatically used for padding when needed. 420 421flag 422---- 423 424Attribute with no payload, its presence is the entire information. 425 426binary 427------ 428 429Raw binary data attribute, the contents are opaque to generic code. 430 431string 432------ 433 434Character string. Unless ``checks`` has ``unterminated-ok`` set to ``true`` 435the string is required to be null terminated. 436``max-len`` in ``checks`` indicates the longest possible string, 437if not present the length of the string is unbounded. 438 439Note that ``max-len`` does not count the terminating character. 440 441nest 442---- 443 444Attribute containing other (nested) attributes. 445``nested-attributes`` specifies which attribute set is used inside. 446