Resolves: RHEL-108555,RHEL-108568,RHEL-108576,RHEL-108584,RHEL-108596,RHEL-108598,RHEL-109096,RHEL-109488,RHEL-111065,RHEL-31756,RHEL-50103
164 lines
6.8 KiB
Diff
164 lines
6.8 KiB
Diff
From fa27bab14e2ede08dcac41ab78901ab3b653e556 Mon Sep 17 00:00:00 2001
|
|
From: Jan Macku <jamacku@redhat.com>
|
|
Date: Tue, 26 Aug 2025 15:30:49 +0200
|
|
Subject: [PATCH] Revert "Revert "udev-builtin-net_id: use firmware_node/sun
|
|
for ID_NET_NAME_SLOT""
|
|
|
|
This reverts commit ae92c09f0ddfea2ff6042e152eec9af86013da38.
|
|
|
|
Also introduce rhel-9.8 naming scheme.
|
|
|
|
rhel-only: policy
|
|
|
|
Resolves: RHEL-50103
|
|
---
|
|
man/systemd.net-naming-scheme.xml | 9 ++++-
|
|
src/shared/netif-naming-scheme.c | 1 +
|
|
src/shared/netif-naming-scheme.h | 2 +
|
|
src/udev/udev-builtin-net_id.c | 66 +++++++++++++++++++++++++++----
|
|
4 files changed, 70 insertions(+), 8 deletions(-)
|
|
|
|
diff --git a/man/systemd.net-naming-scheme.xml b/man/systemd.net-naming-scheme.xml
|
|
index 34e8e46459..c6ee7b4b6e 100644
|
|
--- a/man/systemd.net-naming-scheme.xml
|
|
+++ b/man/systemd.net-naming-scheme.xml
|
|
@@ -526,6 +526,13 @@
|
|
<listitem><para>Same as naming scheme <constant>rhel-9.5</constant>.</para></listitem>
|
|
</varlistentry>
|
|
|
|
+ <varlistentry>
|
|
+ <term><constant>rhel-9.8</constant></term>
|
|
+
|
|
+ <listitem>
|
|
+ <para>PCI slot number is now read from <constant>firmware_node/sun</constant> sysfs file.</para></listitem>
|
|
+ </varlistentry>
|
|
+
|
|
</variablelist>
|
|
|
|
<para>By default <constant>rhel-9.0</constant> is used.</para>
|
|
@@ -679,7 +686,7 @@ ID_NET_NAME_ONBOARD_LABEL=Ethernet Port 1
|
|
</example>
|
|
|
|
<example>
|
|
- <title>PCI Ethernet card in hotplug slot with firmware index number</title>
|
|
+ <title>PCI Ethernet card in slot with firmware index number</title>
|
|
|
|
<programlisting># /sys/devices/pci0000:00/0000:00:1c.3/0000:05:00.0/net/ens1
|
|
ID_NET_NAME_MAC=enx000000000466
|
|
diff --git a/src/shared/netif-naming-scheme.c b/src/shared/netif-naming-scheme.c
|
|
index a38c3f1e2f..4ed866491e 100644
|
|
--- a/src/shared/netif-naming-scheme.c
|
|
+++ b/src/shared/netif-naming-scheme.c
|
|
@@ -47,6 +47,7 @@ static const NamingScheme naming_schemes[] = {
|
|
{ "rhel-9.5", NAMING_RHEL_9_5 },
|
|
{ "rhel-9.6", NAMING_RHEL_9_6 },
|
|
{ "rhel-9.7", NAMING_RHEL_9_7 },
|
|
+ { "rhel-9.8", NAMING_RHEL_9_8 },
|
|
/* … add more schemes here, as the logic to name devices is updated … */
|
|
|
|
EXTRA_NET_NAMING_MAP
|
|
diff --git a/src/shared/netif-naming-scheme.h b/src/shared/netif-naming-scheme.h
|
|
index 3cba656707..c16476522a 100644
|
|
--- a/src/shared/netif-naming-scheme.h
|
|
+++ b/src/shared/netif-naming-scheme.h
|
|
@@ -42,6 +42,7 @@ typedef enum NamingSchemeFlags {
|
|
* This is disabled since rhel-9.5, as it seems not to work at least for some setups. See upstream issue #28929. */
|
|
NAMING_DEVICETREE_ALIASES = 1 << 15, /* Generate names from devicetree aliases */
|
|
NAMING_SR_IOV_R = 1 << 17, /* Use "r" suffix for SR-IOV VF representors */
|
|
+ NAMING_FIRMWARE_NODE_SUN = 1 << 18, /* Use firmware_node/sun to get PCI slot number */
|
|
|
|
/* And now the masks that combine the features above */
|
|
NAMING_V238 = 0,
|
|
@@ -76,6 +77,7 @@ typedef enum NamingSchemeFlags {
|
|
NAMING_RHEL_9_5 = NAMING_RHEL_9_4 & ~NAMING_BRIDGE_MULTIFUNCTION_SLOT,
|
|
NAMING_RHEL_9_6 = NAMING_RHEL_9_5,
|
|
NAMING_RHEL_9_7 = NAMING_RHEL_9_5,
|
|
+ NAMING_RHEL_9_8 = NAMING_RHEL_9_5 | NAMING_FIRMWARE_NODE_SUN,
|
|
|
|
EXTRA_NET_NAMING_SCHEMES
|
|
|
|
diff --git a/src/udev/udev-builtin-net_id.c b/src/udev/udev-builtin-net_id.c
|
|
index 16c9971876..291fb4ba36 100644
|
|
--- a/src/udev/udev-builtin-net_id.c
|
|
+++ b/src/udev/udev-builtin-net_id.c
|
|
@@ -442,6 +442,51 @@ static int pci_get_hotplug_slot(sd_device *dev, uint32_t *ret) {
|
|
return -ENOENT;
|
|
}
|
|
|
|
+static int get_device_firmware_node_sun(sd_device *dev, uint32_t *ret) {
|
|
+ const char *attr;
|
|
+ int r;
|
|
+
|
|
+ assert(dev);
|
|
+ assert(ret);
|
|
+
|
|
+ r = device_get_sysattr_value_filtered(dev, "firmware_node/sun", &attr);
|
|
+ if (r < 0)
|
|
+ return log_device_debug_errno(dev, r, "Failed to read firmware_node/sun, ignoring: %m");
|
|
+
|
|
+ r = safe_atou32(attr, ret);
|
|
+ if (r < 0)
|
|
+ return log_device_warning_errno(dev, r, "Failed to parse firmware_node/sun '%s', ignoring: %m", attr);
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
+static int pci_get_slot_from_firmware_node_sun(sd_device *dev, uint32_t *ret) {
|
|
+ int r;
|
|
+ sd_device *slot_dev;
|
|
+
|
|
+ assert(dev);
|
|
+ assert(ret);
|
|
+
|
|
+ /* Try getting the ACPI _SUN for the device */
|
|
+ if (get_device_firmware_node_sun(dev, ret) >= 0)
|
|
+ return 0;
|
|
+
|
|
+ r = sd_device_get_parent_with_subsystem_devtype(dev, "pci", NULL, &slot_dev);
|
|
+ if (r < 0)
|
|
+ return log_device_debug_errno(dev, r, "Failed to find pci parent, ignoring: %m");
|
|
+
|
|
+ if (is_pci_bridge(slot_dev) && is_pci_multifunction(dev) <= 0)
|
|
+ return log_device_debug_errno(dev, SYNTHETIC_ERRNO(ESTALE),
|
|
+ "Not using slot information because the parent pcieport "
|
|
+ "is a bridge and the PCI device is not multifunction.");
|
|
+
|
|
+ /* Try getting the ACPI _SUN from the parent pcieport */
|
|
+ if (get_device_firmware_node_sun(slot_dev, ret) >= 0)
|
|
+ return 0;
|
|
+
|
|
+ return -ENOENT;
|
|
+}
|
|
+
|
|
static int dev_pci_slot(sd_device *dev, const LinkInfo *info, NetNames *names) {
|
|
const char *sysname, *attr;
|
|
unsigned domain, bus, slot, func;
|
|
@@ -517,13 +562,20 @@ static int dev_pci_slot(sd_device *dev, const LinkInfo *info, NetNames *names) {
|
|
domain, bus, slot, func, strempty(info->phys_port_name), dev_port,
|
|
special_glyph(SPECIAL_GLYPH_ARROW_RIGHT), empty_to_na(names->pci_path));
|
|
|
|
- r = pci_get_hotplug_slot(names->pcidev, &hotplug_slot);
|
|
- if (r < 0)
|
|
- return r;
|
|
- if (r > 0)
|
|
- /* If the hotplug slot is found through the function ID, then drop the domain from the name.
|
|
- * See comments in parse_hotplug_slot_from_function_id(). */
|
|
- domain = 0;
|
|
+ if (naming_scheme_has(NAMING_FIRMWARE_NODE_SUN))
|
|
+ r = pci_get_slot_from_firmware_node_sun(names->pcidev, &hotplug_slot);
|
|
+ else
|
|
+ r = -1;
|
|
+ /* If we don't find a slot using firmware_node/sun, fallback to hotplug_slot */
|
|
+ if (r < 0) {
|
|
+ r = pci_get_hotplug_slot(names->pcidev, &hotplug_slot);
|
|
+ if (r < 0)
|
|
+ return r;
|
|
+ if (r > 0)
|
|
+ /* If the hotplug slot is found through the function ID, then drop the domain from the name.
|
|
+ * See comments in parse_hotplug_slot_from_function_id(). */
|
|
+ domain = 0;
|
|
+ }
|
|
|
|
s = names->pci_slot;
|
|
l = sizeof(names->pci_slot);
|