aboutsummaryrefslogtreecommitdiff
path: root/src/kerneldevice/mm-kernel-device-udev.c
diff options
context:
space:
mode:
authorDan Williams <dan@bigw.org>2025-02-21 14:01:51 +0000
committerDan Williams <dan@bigw.org>2025-02-21 14:01:51 +0000
commit6e981b61b3ceeb54d8f3e20548c9968e281c85b8 (patch)
treebce3530522d0356fd3884440d6ed7a15de9709b0 /src/kerneldevice/mm-kernel-device-udev.c
parent286598388b129ec632998e5d72d58d847bd2892a (diff)
parent092439369ba06b488c70514b4e144fc5c83a917c (diff)
Merge request !1287 from 'sushrut-branch'
kernel-device, generic: add subsystem device ID support https://gitlab.freedesktop.org/mobile-broadband/ModemManager/-/merge_requests/1287
Diffstat (limited to 'src/kerneldevice/mm-kernel-device-udev.c')
-rw-r--r--src/kerneldevice/mm-kernel-device-udev.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/kerneldevice/mm-kernel-device-udev.c b/src/kerneldevice/mm-kernel-device-udev.c
index 09b65db4..7fede022 100644
--- a/src/kerneldevice/mm-kernel-device-udev.c
+++ b/src/kerneldevice/mm-kernel-device-udev.c
@@ -49,6 +49,7 @@ struct _MMKernelDeviceUdevPrivate {
guint16 vendor;
guint16 product;
guint16 subsystem_vendor;
+ guint16 subsystem_device;
guint16 revision;
gchar *driver;
@@ -188,6 +189,7 @@ preload_contents_pci (MMKernelDeviceUdev *self)
self->priv->vendor = udev_device_get_sysfs_attr_as_hex (iter, "vendor");
self->priv->product = udev_device_get_sysfs_attr_as_hex (iter, "device");
self->priv->subsystem_vendor = udev_device_get_sysfs_attr_as_hex (iter, "subsystem_vendor");
+ self->priv->subsystem_device = udev_device_get_sysfs_attr_as_hex (iter, "subsystem_device");
self->priv->revision = udev_device_get_sysfs_attr_as_hex (iter, "revision");
self->priv->physdev = g_object_ref (iter);
/* stop traversing as soon as the physical device is found */
@@ -300,6 +302,8 @@ preload_contents (MMKernelDeviceUdev *self)
mm_obj_dbg (self, " product: %04x", self->priv->product);
if (self->priv->subsystem_vendor)
mm_obj_dbg (self, " subsystem vendor: %04x", self->priv->subsystem_vendor);
+ if (self->priv->subsystem_device)
+ mm_obj_dbg (self, " subsystem device: %04x", self->priv->subsystem_device);
if (self->priv->revision)
mm_obj_dbg (self, " revision: %04x", self->priv->revision);
}
@@ -418,6 +422,12 @@ kernel_device_get_physdev_subsystem_vid (MMKernelDevice *self)
}
static guint16
+kernel_device_get_physdev_subsystem_pid (MMKernelDevice *self)
+{
+ return MM_KERNEL_DEVICE_UDEV (self)->priv->subsystem_device;
+}
+
+static guint16
kernel_device_get_physdev_revision (MMKernelDevice *self)
{
return MM_KERNEL_DEVICE_UDEV (self)->priv->revision;
@@ -816,6 +826,7 @@ mm_kernel_device_udev_class_init (MMKernelDeviceUdevClass *klass)
kernel_device_class->get_physdev_vid = kernel_device_get_physdev_vid;
kernel_device_class->get_physdev_pid = kernel_device_get_physdev_pid;
kernel_device_class->get_physdev_subsystem_vid = kernel_device_get_physdev_subsystem_vid;
+ kernel_device_class->get_physdev_subsystem_pid = kernel_device_get_physdev_subsystem_pid;
kernel_device_class->get_physdev_revision = kernel_device_get_physdev_revision;
kernel_device_class->get_physdev_sysfs_path = kernel_device_get_physdev_sysfs_path;
kernel_device_class->get_physdev_subsystem = kernel_device_get_physdev_subsystem;