aboutsummaryrefslogtreecommitdiff
path: root/src/mm-base-manager.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2020-10-24 15:40:57 +0200
committerAleksander Morgado <aleksander@aleksander.es>2020-11-13 08:57:06 +0000
commit71f5c975430b0455e7ca81b2d2d1bef0174d0be2 (patch)
tree1992d85df2913b7f624ab58b9fc8aa3d04cf0f4f /src/mm-base-manager.c
parent950abbf8ee8624827d63a0d0186beac81232e8f6 (diff)
base-manager: automatic required subsystem detection
Instead of assuming we require a fixed set of subsystems to monitor, compile the full list based on what the plugins have requested themselves.
Diffstat (limited to 'src/mm-base-manager.c')
-rw-r--r--src/mm-base-manager.c62
1 files changed, 26 insertions, 36 deletions
diff --git a/src/mm-base-manager.c b/src/mm-base-manager.c
index 87eddc34..27e7404b 100644
--- a/src/mm-base-manager.c
+++ b/src/mm-base-manager.c
@@ -368,6 +368,11 @@ handle_kernel_event (MMBaseManager *self,
return FALSE;
}
+ if (!g_strv_contains (mm_plugin_manager_get_subsystems (self->priv->plugin_manager), subsystem)) {
+ g_set_error (error, MM_CORE_ERROR, MM_CORE_ERROR_INVALID_ARGS, "Invalid 'subsystem' parameter given: '%s'", subsystem);
+ return FALSE;
+ }
+
name = mm_kernel_event_properties_get_name (properties);
if (!name) {
g_set_error (error, MM_CORE_ERROR, MM_CORE_ERROR_INVALID_ARGS, "Missing mandatory parameter 'name'");
@@ -457,28 +462,19 @@ static void
process_scan (MMBaseManager *self,
gboolean manual_scan)
{
- GList *devices, *iter;
-
- devices = g_udev_client_query_by_subsystem (self->priv->udev, "tty");
- for (iter = devices; iter; iter = g_list_next (iter)) {
- start_device_added (self, G_UDEV_DEVICE (iter->data), manual_scan);
- g_object_unref (G_OBJECT (iter->data));
+ const gchar **subsystems;
+ guint i;
+
+ subsystems = mm_plugin_manager_get_subsystems (self->priv->plugin_manager);
+ for (i = 0; subsystems[i]; i++) {
+ GList *devices;
+ GList *iter;
+
+ devices = g_udev_client_query_by_subsystem (self->priv->udev, subsystems[i]);
+ for (iter = devices; iter; iter = g_list_next (iter))
+ start_device_added (self, G_UDEV_DEVICE (iter->data), manual_scan);
+ g_list_free_full (devices, g_object_unref);
}
- g_list_free (devices);
-
- devices = g_udev_client_query_by_subsystem (self->priv->udev, "net");
- for (iter = devices; iter; iter = g_list_next (iter)) {
- start_device_added (self, G_UDEV_DEVICE (iter->data), manual_scan);
- g_object_unref (G_OBJECT (iter->data));
- }
- g_list_free (devices);
-
- devices = g_udev_client_query_by_subsystem (self->priv->udev, "usbmisc");
- for (iter = devices; iter; iter = g_list_next (iter)) {
- start_device_added (self, G_UDEV_DEVICE (iter->data), manual_scan);
- g_object_unref (G_OBJECT (iter->data));
- }
- g_list_free (devices);
}
#endif
@@ -1365,15 +1361,6 @@ mm_base_manager_init (MMBaseManager *self)
/* Setup internal list of inhibited devices */
self->priv->inhibited_devices = g_hash_table_new_full (g_str_hash, g_str_equal, g_free, (GDestroyNotify)inhibited_device_info_free);
-#if defined WITH_UDEV
- {
- const gchar *subsys[5] = { "tty", "net", "usbmisc", NULL };
-
- /* Setup UDev client */
- self->priv->udev = g_udev_client_new (subsys);
- }
-#endif
-
/* By default, enable autoscan */
self->priv->auto_scan = TRUE;
@@ -1399,12 +1386,6 @@ initable_init (GInitable *initable,
{
MMBaseManager *self = MM_BASE_MANAGER (initable);
-#if defined WITH_UDEV
- /* If autoscan enabled, list for udev events */
- if (self->priv->auto_scan)
- g_signal_connect_swapped (self->priv->udev, "uevent", G_CALLBACK (handle_uevent), initable);
-#endif
-
/* Create filter */
self->priv->filter = mm_filter_new (self->priv->filter_policy, error);
if (!self->priv->filter)
@@ -1415,6 +1396,15 @@ initable_init (GInitable *initable,
if (!self->priv->plugin_manager)
return FALSE;
+#if defined WITH_UDEV
+ /* Create udev client based on the subsystems requested by the plugins */
+ self->priv->udev = g_udev_client_new (mm_plugin_manager_get_subsystems (self->priv->plugin_manager));
+
+ /* If autoscan enabled, list for udev events */
+ if (self->priv->auto_scan)
+ g_signal_connect_swapped (self->priv->udev, "uevent", G_CALLBACK (handle_uevent), initable);
+#endif
+
/* Export the manager interface */
if (!g_dbus_interface_skeleton_export (G_DBUS_INTERFACE_SKELETON (initable),
self->priv->connection,