dryang / rpms / systemd

Forked from rpms/systemd 2 years ago
Clone
87d178
From af528dcffaab1efea760395cc6676fe4b01e89b5 Mon Sep 17 00:00:00 2001
87d178
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
87d178
Date: Thu, 9 May 2019 12:34:30 +0200
87d178
Subject: [PATCH] man: describe naming schemes in a new man page
87d178
87d178
I decided to make this a separate man page because it is freakin' long.
87d178
This content could equally well go in systemd-udevd.service(8), systemd.link(5),
87d178
or a new man page for the net_id builtin.
87d178
87d178
v2:
87d178
- rename to systemd.net-naming-scheme
87d178
- add udevadm test-builtin net_id example
87d178
87d178
(cherry picked from commit 0b1e5b6ed8c6b9a2bc53709eb75e381d360f05bf)
87d178
87d178
Related: #1827462
87d178
87d178
[msekleta: I've removed parts that describe features which are not
87d178
available in RHEL-8]
87d178
---
87d178
 man/rules/meson.build             |   1 +
87d178
 man/systemd-udevd.service.xml     |  19 +-
87d178
 man/systemd.link.xml              |  10 +-
87d178
 man/systemd.net-naming-scheme.xml | 385 ++++++++++++++++++++++++++++++
87d178
 src/udev/udev-builtin-net_id.c    |   1 +
87d178
 5 files changed, 402 insertions(+), 14 deletions(-)
87d178
 create mode 100644 man/systemd.net-naming-scheme.xml
87d178
87d178
diff --git a/man/rules/meson.build b/man/rules/meson.build
87d178
index 7ae94ea265..e6c0a99bbd 100644
87d178
--- a/man/rules/meson.build
87d178
+++ b/man/rules/meson.build
87d178
@@ -714,6 +714,7 @@ manpages = [
87d178
  ['systemd.kill', '5', [], ''],
87d178
  ['systemd.link', '5', [], ''],
87d178
  ['systemd.mount', '5', [], ''],
87d178
+ ['systemd.net-naming-scheme', '7', [], ''],
87d178
  ['systemd.netdev', '5', [], 'ENABLE_NETWORKD'],
87d178
  ['systemd.network', '5', [], 'ENABLE_NETWORKD'],
87d178
  ['systemd.nspawn', '5', [], ''],
87d178
diff --git a/man/systemd-udevd.service.xml b/man/systemd-udevd.service.xml
87d178
index b738591c93..f4cdb2f1e7 100644
87d178
--- a/man/systemd-udevd.service.xml
87d178
+++ b/man/systemd-udevd.service.xml
87d178
@@ -174,15 +174,11 @@
87d178
         <term><varname>net.naming-scheme=</varname></term>
87d178
         <listitem>
87d178
           <para>Network interfaces are renamed to give them predictable names when possible (unless
87d178
-          <varname>net.ifnames=0</varname> is specified, see above). The names are derived from various
87d178
-          device metadata fields. Newer versions of <filename>systemd-udevd.service</filename> take more of
87d178
-          these fields into account, improving (and thus possibly changing) the names used for the same
87d178
-          devices. With this kernel command line option it is possible to pick a specific version of this
87d178
-          algorithm. It expects a naming scheme identifier as argument. Currently the following identifiers
87d178
-          are known: <literal>rhel-8.0</literal>, <literal>rhel-8.1</literal>, <literal>rhel-8.2</literal>,
87d178
-          <literal>rhel-8.3</literal> which each implement the naming scheme that was the default in the
87d178
-          indicated Red Hat Enterprise Linux minor version. In addition, <literal>latest</literal> may be
87d178
-          used to designate the latest scheme known (to this particular version of
87d178
+          <varname>net.ifnames=0</varname> is specified, see above). With this kernel command line option it
87d178
+          is possible to pick a specific version of this algorithm and override the default chosen at
87d178
+          compilation time. Expects one of the naming scheme identifiers listed in
87d178
+          <citerefentry><refentrytitle>systemd.net-naming-scheme</refentrytitle><manvolnum>7</manvolnum></citerefentry>,
87d178
+          or <literal>latest</literal> to select the latest scheme known (to this particular version of
87d178
           <filename>systemd-udevd.service</filename>).</para>
87d178
           <para>Note that selecting a specific scheme is not sufficient to fully stabilize interface naming:
87d178
           the naming is generally derived from driver attributes exposed by the kernel. As the kernel is
87d178
@@ -191,9 +187,8 @@
87d178
         </listitem>
87d178
       </varlistentry>
87d178
     </variablelist>
87d178
-    
87d178
-         in kernel-command-line.xml -->
87d178
- </refsect1>
87d178
+    
87d178
+  </refsect1>
87d178
 
87d178
   <refsect1>
87d178
     <title>See Also</title>
87d178
diff --git a/man/systemd.link.xml b/man/systemd.link.xml
87d178
index 6708753e82..32657308d0 100644
87d178
--- a/man/systemd.link.xml
87d178
+++ b/man/systemd.link.xml
87d178
@@ -286,6 +286,7 @@
87d178
                 <para>The name is set based on information given by
87d178
                 the firmware for on-board devices, as exported by the
87d178
                 udev property <literal>ID_NET_NAME_ONBOARD</literal>.
87d178
+                See <citerefentry><refentrytitle>systemd.net-naming-scheme</refentrytitle><manvolnum>7</manvolnum></citerefentry>.
87d178
                 </para>
87d178
               </listitem>
87d178
             </varlistentry>
87d178
@@ -295,6 +296,7 @@
87d178
                 <para>The name is set based on information given by
87d178
                 the firmware for hot-plug devices, as exported by the
87d178
                 udev property <literal>ID_NET_NAME_SLOT</literal>.
87d178
+                See <citerefentry><refentrytitle>systemd.net-naming-scheme</refentrytitle><manvolnum>7</manvolnum></citerefentry>.
87d178
                 </para>
87d178
               </listitem>
87d178
             </varlistentry>
87d178
@@ -303,7 +305,9 @@
87d178
               <listitem>
87d178
                 <para>The name is set based on the device's physical
87d178
                 location, as exported by the udev property
87d178
-                <literal>ID_NET_NAME_PATH</literal>.</para>
87d178
+                <literal>ID_NET_NAME_PATH</literal>.
87d178
+                See <citerefentry><refentrytitle>systemd.net-naming-scheme</refentrytitle><manvolnum>7</manvolnum></citerefentry>.
87d178
+                </para>
87d178
               </listitem>
87d178
             </varlistentry>
87d178
             <varlistentry>
87d178
@@ -311,7 +315,9 @@
87d178
               <listitem>
87d178
                 <para>The name is set based on the device's persistent
87d178
                 MAC address, as exported by the udev property
87d178
-                <literal>ID_NET_NAME_MAC</literal>.</para>
87d178
+                <literal>ID_NET_NAME_MAC</literal>.
87d178
+                See <citerefentry><refentrytitle>systemd.net-naming-scheme</refentrytitle><manvolnum>7</manvolnum></citerefentry>.
87d178
+                </para>
87d178
               </listitem>
87d178
             </varlistentry>
87d178
           </variablelist>
87d178
diff --git a/man/systemd.net-naming-scheme.xml b/man/systemd.net-naming-scheme.xml
87d178
new file mode 100644
87d178
index 0000000000..a12cc3c460
87d178
--- /dev/null
87d178
+++ b/man/systemd.net-naming-scheme.xml
87d178
@@ -0,0 +1,385 @@
87d178
+
87d178
+
87d178
+  "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">
87d178
+
87d178
+
87d178
+<refentry id="systemd.net-naming-scheme">
87d178
+  <refentryinfo>
87d178
+    <title>systemd.net-naming-scheme</title>
87d178
+    <productname>systemd</productname>
87d178
+  </refentryinfo>
87d178
+
87d178
+  <refmeta>
87d178
+    <refentrytitle>systemd.net-naming-scheme</refentrytitle>
87d178
+    <manvolnum>7</manvolnum>
87d178
+  </refmeta>
87d178
+
87d178
+  <refnamediv>
87d178
+    <refname>systemd.net-naming-scheme</refname>
87d178
+    <refpurpose>Network device naming schemes</refpurpose>
87d178
+  </refnamediv>
87d178
+
87d178
+  <refsect1>
87d178
+    <title>Description</title>
87d178
+
87d178
+    <para>Network interfaces may be renamed to give them predictable names when there's enough information to
87d178
+    generate appropriate names and the use of certain types of names is configured. This page describes the
87d178
+    first part, i.e. what possible names may be generated. Those names are generated by the
87d178
+    <citerefentry><refentrytitle>systemd-udevd.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>
87d178
+    builtin <command>net_id</command> and exported as udev properties
87d178
+    (<varname>ID_NET_NAME_ONBOARD=</varname>, <varname>ID_NET_LABEL_ONBOARD=</varname>,
87d178
+    <varname>ID_NET_NAME_PATH=</varname>, <varname>ID_NET_NAME_SLOT=</varname>).</para>
87d178
+
87d178
+    <para>Names are derived from various device metadata attributes. Newer versions of udev take more of
87d178
+    these attributes into account, improving (and thus possibly changing) the names used for the same
87d178
+    devices. Differents version of the naming rules are called "naming schemes". The default naming scheme is
87d178
+    chosen at compilation time. Usually this will be the latest implemented version, but it is also possible
87d178
+    to set one of the older versions to preserve compatibility. This may be useful for example for
87d178
+    distributions, which may introduce new versions of systemd in stable releases without changing the naming
87d178
+    scheme. The naming scheme may also be overriden using the <varname>net.naming-scheme=</varname> kernel
87d178
+    command line switch, see
87d178
+    <citerefentry><refentrytitle>systemd-udevd.service</refentrytitle><manvolnum>8</manvolnum></citerefentry>.
87d178
+    Available naming schemes are described below.</para>
87d178
+
87d178
+    <para>After the udev proprties have been generated, appropriate udev rules may be used to actually rename
87d178
+    devices based on those properties. See the description of <varname>NamePolicy=</varname> in
87d178
+    <citerefentry><refentrytitle>systemd.link</refentrytitle><manvolnum>5</manvolnum></citerefentry>.
87d178
+    </para>
87d178
+  </refsect1>
87d178
+
87d178
+  <refsect1>
87d178
+    <title>Naming</title>
87d178
+
87d178
+    <para>All names start with a two-character prefix that signifies the interface type.</para>
87d178
+
87d178
+    
87d178
+      <title>Two character prefixes based on the type of interface</title>
87d178
+
87d178
+      <tgroup cols='2'>
87d178
+        
87d178
+          <row>
87d178
+            <entry>Prefix</entry>
87d178
+            <entry>Description</entry>
87d178
+          </row>
87d178
+        
87d178
+        
87d178
+          <row>
87d178
+            <entry><constant>en</constant></entry>
87d178
+            <entry>Ethernet</entry>
87d178
+          </row>
87d178
+          <row>
87d178
+            <entry><constant>sl</constant></entry>
87d178
+            <entry>serial line IP (slip)</entry>
87d178
+          </row>
87d178
+          <row>
87d178
+            <entry><constant>wl</constant></entry>
87d178
+            <entry>Wireless local area network (WLAN)</entry>
87d178
+          </row>
87d178
+          <row>
87d178
+            <entry><constant>ww</constant></entry>
87d178
+            <entry>Wireless wide area network (WWAN)</entry>
87d178
+          </row>
87d178
+        
87d178
+      </tgroup>
87d178
+    
87d178
+
87d178
+    <para>The udev <command>net_id</command> builtin exports the following udev device properties:</para>
87d178
+
87d178
+    <variablelist>
87d178
+        <varlistentry>
87d178
+          <term><varname>ID_NET_NAME_ONBOARD=<replaceable>prefix</replaceable><constant>o</constant><replaceable>number</replaceable></varname></term>
87d178
+
87d178
+          <listitem><para>This name is set based on the ordering information given by the firmware for
87d178
+          on-board devices. The name consists of the prefix, letter <constant>o</constant>, and a number
87d178
+          specified by the firmware. This is only available for PCI devices.</para>
87d178
+          </listitem>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><varname>ID_NET_LABEL_ONBOARD=<replaceable>prefix</replaceable> <replaceable>label</replaceable></varname></term>
87d178
+
87d178
+          <listitem><para>This property is set based on label given by the firmware for on-board devices. The
87d178
+          name consists of the prefix concatenated with the label. This is only available for PCI devices.
87d178
+          </para>
87d178
+          </listitem>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><varname>ID_NET_NAME_MAC=<replaceable>prefix</replaceable><constant>x</constant><replaceable>AABBCCDDEEFF</replaceable></varname></term>
87d178
+
87d178
+          <listitem><para>This name consists of the prefix, letter <constant>x</constant>, and 12 hexadecimal
87d178
+          digits of the MAC address. It is available if the device has a fixed MAC address. Because this name
87d178
+          is based on an attribute of the card itself, it remains "stable" when the device is moved (even
87d178
+          between machines), but will change when the hardware is replaced.</para>
87d178
+          </listitem>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><varname>ID_NET_NAME_SLOT=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]</varname></term>
87d178
+          <term><varname>ID_NET_NAME_SLOT=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]<constant>b</constant><replaceable>number</replaceable></varname></term>
87d178
+          <term><varname>ID_NET_NAME_SLOT=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]<constant>u</constant><replaceable>port</replaceable>…[<constant>c</constant><replaceable>config</replaceable>][<constant>i</constant><replaceable>interface</replaceable>]</varname></term>
87d178
+          <term><varname>ID_NET_NAME_SLOT=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]<constant>v</constant><replaceable>slot</replaceable></varname></term>
87d178
+
87d178
+          <listitem><para>This property describes the slot position. Different schemes are used depending on
87d178
+          the bus type, as described in the table below. In all cases, PCI slot information must be known. In
87d178
+          case of USB, BCMA, and SR-VIO devices, the full name consists of the prefix, PCI slot identifier,
87d178
+          and USB or BCMA or SR-VIO slot identifier. The first two parts are denoted as "…" in the table
87d178
+          below.</para>
87d178
+
87d178
+          
87d178
+            <title>Slot naming schemes</title>
87d178
+
87d178
+            <tgroup cols='2'>
87d178
+              
87d178
+                <row>
87d178
+                  <entry>Format</entry>
87d178
+                  <entry>Description</entry>
87d178
+                </row>
87d178
+              
87d178
+
87d178
+              
87d178
+                <row>
87d178
+                  <entry><replaceable>prefix</replaceable> [<constant>P</constant><replaceable>domain</replaceable>] <constant>s</constant><replaceable>slot</replaceable> [<constant>f</constant><replaceable>function</replaceable>] [<constant>n</constant><replaceable>port_name</replaceable> | <constant>d</constant><replaceable>dev_port</replaceable>]</entry>
87d178
+                  <entry>PCI slot number</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry>… <constant>b</constant><replaceable>number</replaceable></entry>
87d178
+                  <entry>Broadcom bus (BCMA) core number</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry>… <constant>u</constant><replaceable>port</replaceable>… [<constant>c</constant><replaceable>config</replaceable>] [<constant>i</constant><replaceable>interface</replaceable>]</entry>
87d178
+                  <entry>USB port number chain</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry>… <constant>v</constant><replaceable>slot</replaceable></entry>
87d178
+                  <entry>SR-VIO slot number</entry>
87d178
+                </row>
87d178
+              
87d178
+            </tgroup>
87d178
+          
87d178
+
87d178
+          <para>The PCI domain is only prepended when it is not 0. All multi-function PCI devices will carry
87d178
+          the <constant>f<replaceable>function</replaceable></constant> number in the device name, including
87d178
+          the function 0 device. For non-multi-function devices, the number is suppressed if 0. The port name
87d178
+          <replaceable>port_name</replaceable> is used, or the port number
87d178
+          <constant>d</constant><replaceable>dev_port</replaceable> if the name is not known.</para>
87d178
+
87d178
+          <para>For BCMA devices, the core number is suppressed when 0.</para>
87d178
+
87d178
+          <para>For USB devices the full chain of port numbers of hubs is composed. If the name gets longer
87d178
+          than the maximum number of 15 characters, the name is not exported. The usual USB configuration
87d178
+          number 1 and interface number 0 values are suppressed.</para>
87d178
+          </listitem>
87d178
+
87d178
+          <para>SR-IOV virtual devices are named based on the name of the parent interface, with a suffix of
87d178
+          <constant>v</constant> and the virtual device number, with any leading zeros removed. The bus
87d178
+          number is ignored. This device type is found in IBM PowerVMs.</para>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><varname>ID_NET_NAME_PATH=<replaceable>prefix</replaceable><constant>c</constant><replaceable>bus_id</replaceable></varname></term>
87d178
+          <term><varname>ID_NET_NAME_PATH=<replaceable>prefix</replaceable><constant>a</constant><replaceable>vendor</replaceable><replaceable>model</replaceable><constant>i</constant><replaceable>instance</replaceable></varname></term>
87d178
+          <term><varname>ID_NET_NAME_PATH=<replaceable>prefix</replaceable><constant>i</constant><replaceable>address</replaceable><constant>n</constant><replaceable>port_name</replaceable></varname></term>
87d178
+          <term><varname>ID_NET_NAME_PATH=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>p</constant><replaceable>bus</replaceable><constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>phys_port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]</varname></term>
87d178
+          <term><varname>ID_NET_NAME_PATH=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>p</constant><replaceable>bus</replaceable><constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>phys_port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]<constant>b</constant><replaceable>number</replaceable></varname></term>
87d178
+          <term><varname>ID_NET_NAME_PATH=<replaceable>prefix</replaceable>[<constant>P</constant><replaceable>domain</replaceable>]<constant>p</constant><replaceable>bus</replaceable><constant>s</constant><replaceable>slot</replaceable>[<constant>f</constant><replaceable>function</replaceable>][<constant>n</constant><replaceable>phys_port_name</replaceable>|<constant>d</constant><replaceable>dev_port</replaceable>]<constant>u</constant><replaceable>port</replaceable>…[<constant>c</constant><replaceable>config</replaceable>][<constant>i</constant><replaceable>interface</replaceable>]</varname></term>
87d178
+
87d178
+          <listitem><para>This property describes the device installation location. Different schemes are
87d178
+          used depending on the bus type, as described in the table below. For BCMA and USB devices, PCI path
87d178
+          information must known, and the full name consists of the prefix, PCI slot identifier, and USB or
87d178
+          BCMA location. The first two parts are denoted as "…" in the table below.</para>
87d178
+
87d178
+          
87d178
+            <title>Path naming schemes</title>
87d178
+
87d178
+            <tgroup cols='2'>
87d178
+              
87d178
+                <row>
87d178
+                  <entry>Format</entry>
87d178
+                  <entry>Description</entry>
87d178
+                </row>
87d178
+              
87d178
+
87d178
+              
87d178
+                <row>
87d178
+                  <entry><replaceable>prefix</replaceable> <constant>c</constant><replaceable>bus_id</replaceable></entry>
87d178
+                  <entry>CCW or grouped CCW device identifier</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry><replaceable>prefix</replaceable> <constant>a</constant><replaceable>vendor</replaceable> <replaceable>model</replaceable> <constant>i</constant><replaceable>instance</replaceable></entry>
87d178
+                  <entry>ACPI path names for ARM64 platform devices</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry><replaceable>prefix</replaceable> [<constant>P</constant><replaceable>domain</replaceable>] <constant>p</constant><replaceable>bus</replaceable> <constant>s</constant><replaceable>slot</replaceable> [<constant>f</constant><replaceable>function</replaceable>] [<constant>n</constant><replaceable>phys_port_name</replaceable> | <constant>d</constant><replaceable>dev_port</replaceable>]</entry>
87d178
+                  <entry>PCI geographical location</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry>… <constant>b</constant><replaceable>number</replaceable></entry>
87d178
+                  <entry>Broadcom bus (BCMA) core number</entry>
87d178
+                </row>
87d178
+
87d178
+                <row>
87d178
+                  <entry>… <constant>u</constant><replaceable>port</replaceable>… [<constant>c</constant><replaceable>config</replaceable>] [<constant>i</constant><replaceable>interface</replaceable>]</entry>
87d178
+                  <entry>USB port number chain</entry>
87d178
+                </row>
87d178
+
87d178
+              
87d178
+            </tgroup>
87d178
+          
87d178
+
87d178
+          <para>CCW and grouped CCW devices are found in IBM System Z mainframes. Any leading zeros and
87d178
+          dots are suppressed.</para>
87d178
+
87d178
+          <para>For PCI, BCMA, and USB devices, the same rules as described above for slot naming are
87d178
+          used.</para>
87d178
+          </listitem>
87d178
+        </varlistentry>
87d178
+    </variablelist>
87d178
+  </refsect1>
87d178
+
87d178
+  <refsect1>
87d178
+    <title>History</title>
87d178
+
87d178
+    <para>The following "naming schemes" have been defined:</para>
87d178
+
87d178
+    <variablelist>
87d178
+        <varlistentry>
87d178
+          <term><constant>rhel-8.0</constant></term>
87d178
+
87d178
+          <listitem><para>Naming was changed for virtual network interfaces created with SR-IOV and NPAR and
87d178
+          for devices where the PCI network controller device does not have a slot number associated.</para>
87d178
+
87d178
+          <para>SR-IOV virtual devices are named based on the name of the parent interface, with a suffix of
87d178
+          <literal>v<replaceable>port</replaceable></literal>, where <replaceable>port</replaceable> is the
87d178
+          virtual device number. Previously those virtual devices were named as if completely independent.
87d178
+          </para>
87d178
+
87d178
+          <para>The ninth and later NPAR virtual devices are named following the scheme used for the first
87d178
+          eight NPAR partitions. Previously those devices were not renamed and the kernel default
87d178
+          ("eth<replaceable>N</replaceable>") was used.</para>
87d178
+
87d178
+          <para>Names are also generated for PCI devices where the PCI network controller device does not
87d178
+          have an associated slot number itself, but one of its parents does. Previously those devices were
87d178
+          not renamed and the kernel default was used.</para>
87d178
+          </listitem>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><constant>rhel-8.1</constant></term>
87d178
+
87d178
+          <para>Same as naming scheme <constant>rhel-8.0</constant>.</para>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><constant>rhel-8.2</constant></term>
87d178
+
87d178
+          <para>Same as naming scheme <constant>rhel-8.0</constant>.</para>
87d178
+        </varlistentry>
87d178
+
87d178
+        <varlistentry>
87d178
+          <term><constant>rhel-8.3</constant></term>
87d178
+
87d178
+          <para>Same as naming scheme <constant>rhel-8.0</constant>.</para>
87d178
+        </varlistentry>
87d178
+
87d178
+        <para>Note that <constant>latest</constant> may be used to denote the latest scheme known (to this
87d178
+        particular version of systemd.</para>
87d178
+    </variablelist>
87d178
+  </refsect1>
87d178
+
87d178
+  <refsect1>
87d178
+    <title>Examples</title>
87d178
+
87d178
+    <example>
87d178
+      <title>Using <command>udevadm test-builtin</command> to display device properties</title>
87d178
+
87d178
+      <programlisting>$ udevadm test-builtin net_id /sys/class/net/enp0s31f6
87d178
+...
87d178
+Using default interface naming scheme 'rhel-8.3'.
87d178
+ID_NET_NAMING_SCHEME=rhel-8.3
87d178
+ID_NET_NAME_MAC=enx54ee75cb1dc0
87d178
+ID_OUI_FROM_DATABASE=Wistron InfoComm(Kunshan)Co.,Ltd.
87d178
+ID_NET_NAME_PATH=enp0s31f6
87d178
+...</programlisting>
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>PCI Ethernet card with firmware index "1"</title>
87d178
+
87d178
+      <programlisting>ID_NET_NAME_ONBOARD=eno1
87d178
+ID_NET_NAME_ONBOARD_LABEL=enEthernet Port 1
87d178
+      </programlisting>
87d178
+      
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>PCI Ethernet card in hotplug slot with firmware index number</title>
87d178
+
87d178
+      <programlisting># /sys/devices/pci0000:00/0000:00:1c.3/0000:05:00.0/net/ens1
87d178
+ID_NET_NAME_MAC=enx000000000466
87d178
+ID_NET_NAME_PATH=enp5s0
87d178
+ID_NET_NAME_SLOT=ens1</programlisting>
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>PCI Ethernet multi-function card with 2 ports</title>
87d178
+
87d178
+      <programlisting># /sys/devices/pci0000:00/0000:00:1c.0/0000:02:00.0/net/enp2s0f0
87d178
+ID_NET_NAME_MAC=enx78e7d1ea46da
87d178
+ID_NET_NAME_PATH=enp2s0f0
87d178
+
87d178
+# /sys/devices/pci0000:00/0000:00:1c.0/0000:02:00.1/net/enp2s0f1
87d178
+ID_NET_NAME_MAC=enx78e7d1ea46dc
87d178
+ID_NET_NAME_PATH=enp2s0f1</programlisting>
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>PCI WLAN card</title>
87d178
+
87d178
+      <programlisting># /sys/devices/pci0000:00/0000:00:1c.1/0000:03:00.0/net/wlp3s0
87d178
+ID_NET_NAME_MAC=wlx0024d7e31130
87d178
+ID_NET_NAME_PATH=wlp3s0</programlisting>
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>USB built-in 3G modem</title>
87d178
+
87d178
+      <programlisting># /sys/devices/pci0000:00/0000:00:1d.0/usb2/2-1/2-1.4/2-1.4:1.6/net/wwp0s29u1u4i6
87d178
+ID_NET_NAME_MAC=wwx028037ec0200
87d178
+ID_NET_NAME_PATH=wwp0s29u1u4i6</programlisting>
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>USB Android phone</title>
87d178
+
87d178
+      <programlisting># /sys/devices/pci0000:00/0000:00:1d.0/usb2/2-1/2-1.2/2-1.2:1.0/net/enp0s29u1u2
87d178
+ID_NET_NAME_MAC=enxd626b3450fb5
87d178
+ID_NET_NAME_PATH=enp0s29u1u2</programlisting>
87d178
+    </example>
87d178
+
87d178
+    <example>
87d178
+      <title>s390 grouped CCW interface</title>
87d178
+
87d178
+      <programlisting># /sys/devices/css0/0.0.0007/0.0.f5f0/group_device/net/encf5f0
87d178
+ID_NET_NAME_MAC=enx026d3c00000a
87d178
+ID_NET_NAME_PATH=encf5f0</programlisting>
87d178
+    </example>
87d178
+  </refsect1>
87d178
+
87d178
+  <refsect1>
87d178
+    <title>See Also</title>
87d178
+    <para>
87d178
+      <citerefentry><refentrytitle>udev</refentrytitle><manvolnum>7</manvolnum></citerefentry>,
87d178
+      <citerefentry><refentrytitle>udevadm</refentrytitle><manvolnum>8</manvolnum></citerefentry>,
87d178
+      <ulink url="https://www.freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames">the
87d178
+      original page describing stable interface names</ulink>
87d178
+    </para>
87d178
+  </refsect1>
87d178
+
87d178
+</refentry>
87d178
diff --git a/src/udev/udev-builtin-net_id.c b/src/udev/udev-builtin-net_id.c
87d178
index d85dc2848b..aa553d5ade 100644
87d178
--- a/src/udev/udev-builtin-net_id.c
87d178
+++ b/src/udev/udev-builtin-net_id.c
87d178
@@ -78,6 +78,7 @@
87d178
  *  /sys/devices/css0/0.0.0007/0.0.f5f0/group_device/net/encf5f0
87d178
  *  ID_NET_NAME_MAC=enx026d3c00000a
87d178
  *  ID_NET_NAME_PATH=encf5f0
87d178
+ * When the code here is changed, man/systemd.net-naming-scheme.xml must be updated too.
87d178
  */
87d178
 
87d178
 #include <errno.h>