From ff5840c3c7cd6b9de8881d4c081dfa9bc5e43b11 Mon Sep 17 00:00:00 2001 From: Daniele Palmas Date: Wed, 4 May 2022 11:04:34 +0200 Subject: kernel-device, generic: add subsystem vendor ID support Add subsystem vendor ID support, that can be used in pci devices instead of vendor ID customization. --- src/kerneldevice/mm-kernel-device-udev.c | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'src/kerneldevice/mm-kernel-device-udev.c') diff --git a/src/kerneldevice/mm-kernel-device-udev.c b/src/kerneldevice/mm-kernel-device-udev.c index 19389f66..09b65db4 100644 --- a/src/kerneldevice/mm-kernel-device-udev.c +++ b/src/kerneldevice/mm-kernel-device-udev.c @@ -48,6 +48,7 @@ struct _MMKernelDeviceUdevPrivate { GUdevDevice *physdev; guint16 vendor; guint16 product; + guint16 subsystem_vendor; guint16 revision; gchar *driver; @@ -186,6 +187,7 @@ preload_contents_pci (MMKernelDeviceUdev *self) if (!self->priv->physdev && (g_strcmp0 (g_udev_device_get_subsystem (iter), "pci") == 0)) { 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->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 */ @@ -296,6 +298,8 @@ preload_contents (MMKernelDeviceUdev *self) mm_obj_dbg (self, " vendor: %04x", self->priv->vendor); if (self->priv->product) 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->revision) mm_obj_dbg (self, " revision: %04x", self->priv->revision); } @@ -407,6 +411,12 @@ kernel_device_get_physdev_pid (MMKernelDevice *self) return MM_KERNEL_DEVICE_UDEV (self)->priv->product; } +static guint16 +kernel_device_get_physdev_subsystem_vid (MMKernelDevice *self) +{ + return MM_KERNEL_DEVICE_UDEV (self)->priv->subsystem_vendor; +} + static guint16 kernel_device_get_physdev_revision (MMKernelDevice *self) { @@ -805,6 +815,7 @@ mm_kernel_device_udev_class_init (MMKernelDeviceUdevClass *klass) kernel_device_class->get_physdev_uid = kernel_device_get_physdev_uid; 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_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; -- cgit v1.2.3-70-g09d2