aboutsummaryrefslogtreecommitdiff
path: root/plugins/nokia/mm-plugin-nokia.c
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@lanedo.com>2012-06-05 15:25:38 +0200
committerAleksander Morgado <aleksander@lanedo.com>2012-08-06 20:06:44 +0200
commit815693661c7f6a4225d271d2cec67e59bad8e070 (patch)
tree4bd354e4713a5eb11a95d50e56b6ed2e2afe30e3 /plugins/nokia/mm-plugin-nokia.c
parent4add521a98e59c9fbaaf30d965771ca01f748242 (diff)
core: compile all ports before creating the modem object
Before this, we only exported the modem to DBus when all ports were organized, in order to make sure that we select as primary port the one we really want and not the first AT port grabbed. Given that to get all the ports organized we also needed to wait to get all the ports grabbed, we can now also defer the creation of the modem object until all the ports get grabbed. This allows us to create different types of objects based on the ports available (e.g. we can now create QMI-supported modem objects if we see a QMI port around).
Diffstat (limited to 'plugins/nokia/mm-plugin-nokia.c')
-rw-r--r--plugins/nokia/mm-plugin-nokia.c73
1 files changed, 31 insertions, 42 deletions
diff --git a/plugins/nokia/mm-plugin-nokia.c b/plugins/nokia/mm-plugin-nokia.c
index 7aa102b0..56b649bd 100644
--- a/plugins/nokia/mm-plugin-nokia.c
+++ b/plugins/nokia/mm-plugin-nokia.c
@@ -12,7 +12,7 @@
*
* Copyright (C) 2008 - 2009 Novell, Inc.
* Copyright (C) 2009 - 2011 Red Hat, Inc.
- * Copyright (C) 2011 Google, Inc.
+ * Copyright (C) 2011 - 2012 Google, Inc.
*/
#include <string.h>
@@ -42,38 +42,40 @@ static const MMPortProbeAtCommand custom_init[] = {
/*****************************************************************************/
static MMBaseModem *
+create_modem (MMPluginBase *plugin,
+ const gchar *sysfs_path,
+ const gchar *driver,
+ guint16 vendor,
+ guint16 product,
+ GList *probes,
+ GError **error)
+{
+ return MM_BASE_MODEM (mm_broadband_modem_nokia_new (sysfs_path,
+ driver,
+ mm_plugin_get_name (MM_PLUGIN (plugin)),
+ vendor,
+ product));
+}
+
+static gboolean
grab_port (MMPluginBase *base,
- MMBaseModem *existing,
+ MMBaseModem *modem,
MMPortProbe *probe,
GError **error)
{
- MMBaseModem *modem = NULL;
GUdevDevice *port;
- const gchar *name, *subsys, *driver;
- guint16 vendor = 0, product = 0;
MMAtPortFlag pflags = MM_AT_PORT_FLAG_NONE;
- /* The Nokia plugin cannot do anything with non-AT ports */
+ /* The Nokia plugin cannot do anything with non-AT */
if (!mm_port_probe_is_at (probe)) {
- g_set_error_literal (error,
- MM_CORE_ERROR,
- MM_CORE_ERROR_UNSUPPORTED,
- "Ignoring non-AT port");
- return NULL;
+ g_set_error (error,
+ MM_CORE_ERROR,
+ MM_CORE_ERROR_UNSUPPORTED,
+ "Ignoring non-AT port");
+ return FALSE;
}
port = mm_port_probe_get_port (probe); /* transfer none */
- subsys = mm_port_probe_get_port_subsys (probe);
- name = mm_port_probe_get_port_name (probe);
- driver = mm_port_probe_get_port_driver (probe);
-
- if (!mm_plugin_base_get_device_ids (base, subsys, name, &vendor, &product)) {
- g_set_error_literal (error,
- MM_CORE_ERROR,
- MM_CORE_ERROR_FAILED,
- "Could not get modem product ID");
- return NULL;
- }
/* Look for port type hints */
if (g_udev_device_get_property_as_boolean (port, "ID_MM_NOKIA_PORT_TYPE_MODEM"))
@@ -81,26 +83,12 @@ grab_port (MMPluginBase *base,
else if (g_udev_device_get_property_as_boolean (port, "ID_MM_NOKIA_PORT_TYPE_AUX"))
pflags = MM_AT_PORT_FLAG_SECONDARY;
- /* If this is the first port being grabbed, create a new modem object */
- if (!existing)
- modem = MM_BASE_MODEM (mm_broadband_modem_nokia_new (mm_port_probe_get_port_physdev (probe),
- driver,
- mm_plugin_get_name (MM_PLUGIN (base)),
- vendor,
- product));
-
- if (!mm_base_modem_grab_port (existing ? existing : modem,
- subsys,
- name,
- MM_PORT_TYPE_AT, /* we only allow AT ports here */
- pflags,
- error)) {
- if (modem)
- g_object_unref (modem);
- return NULL;
- }
-
- return existing ? existing : modem;
+ return mm_base_modem_grab_port (modem,
+ mm_port_probe_get_port_subsys (probe),
+ mm_port_probe_get_port_name (probe),
+ mm_port_probe_get_port_type (probe),
+ pflags,
+ error);
}
/*****************************************************************************/
@@ -131,5 +119,6 @@ mm_plugin_nokia_class_init (MMPluginNokiaClass *klass)
{
MMPluginBaseClass *pb_class = MM_PLUGIN_BASE_CLASS (klass);
+ pb_class->create_modem = create_modem;
pb_class->grab_port = grab_port;
}