diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/mm-device.c | 7 | ||||
-rw-r--r-- | src/mm-manager.c | 9 |
2 files changed, 15 insertions, 1 deletions
diff --git a/src/mm-device.c b/src/mm-device.c index d2ca4de4..0d65d19b 100644 --- a/src/mm-device.c +++ b/src/mm-device.c @@ -232,6 +232,7 @@ const gchar * mm_device_utils_get_port_driver (GUdevDevice *udev_port) { const gchar *driver, *subsys; + const char *name = g_udev_device_get_name (udev_port); driver = g_udev_device_get_driver (udev_port); if (!driver) { @@ -254,6 +255,12 @@ mm_device_utils_get_port_driver (GUdevDevice *udev_port) g_object_unref (parent); } + /* Newer kernels don't set up the rfcomm port parent in sysfs, + * so we must infer it from the device name. + */ + if (!driver && strncmp (name, "rfcomm", 6) == 0) + driver = "bluetooth"; + return driver; } diff --git a/src/mm-manager.c b/src/mm-manager.c index 8c7969ee..3d5eea8b 100644 --- a/src/mm-manager.c +++ b/src/mm-manager.c @@ -170,13 +170,20 @@ find_physical_device (GUdevDevice *child) { GUdevDevice *iter, *old = NULL; GUdevDevice *physdev = NULL; - const char *subsys, *type; + const char *subsys, *type, *name; guint32 i = 0; gboolean is_usb = FALSE, is_pci = FALSE, is_pcmcia = FALSE, is_platform = FALSE; gboolean is_pnp = FALSE; g_return_val_if_fail (child != NULL, NULL); + /* Bluetooth rfcomm devices are "virtual" and don't necessarily have + * parents at all. + */ + name = g_udev_device_get_name (child); + if (name && strncmp (name, "rfcomm", 6) == 0) + return g_object_ref (child); + iter = g_object_ref (child); while (iter && i++ < 8) { subsys = g_udev_device_get_subsystem (iter); |