aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDan Williams <dcbw@redhat.com>2012-02-25 20:18:48 -0600
committerDan Williams <dcbw@redhat.com>2012-02-28 10:06:04 -0600
commit30e706309462f6b207753209649143902ee538fa (patch)
tree465aa1b22594a3a4a7c8b1f634d60bf93db5c434
parent4dad94d5004f325e25dc3b09d87585eab38d4c3f (diff)
iridium: convert to new port grabbing schemeports
-rw-r--r--plugins/mm-modem-iridium-gsm.c50
-rw-r--r--plugins/mm-plugin-iridium.c6
2 files changed, 16 insertions, 40 deletions
diff --git a/plugins/mm-modem-iridium-gsm.c b/plugins/mm-modem-iridium-gsm.c
index 9aa4106c..7c1b96d7 100644
--- a/plugins/mm-modem-iridium-gsm.c
+++ b/plugins/mm-modem-iridium-gsm.c
@@ -37,11 +37,9 @@
*
*/
-static void modem_init (MMModem *modem_class);
static void modem_gsm_network_init (MMModemGsmNetwork *gsm_network_class);
G_DEFINE_TYPE_EXTENDED (MMModemIridiumGsm, mm_modem_iridium_gsm, MM_TYPE_GENERIC_GSM, 0,
- G_IMPLEMENT_INTERFACE (MM_TYPE_MODEM, modem_init)
G_IMPLEMENT_INTERFACE (MM_TYPE_MODEM_GSM_NETWORK, modem_gsm_network_init))
@@ -79,35 +77,16 @@ mm_modem_iridium_gsm_new (const char *device,
NULL));
}
-static gboolean
-grab_port (MMModem *modem,
- const char *subsys,
- const char *name,
- MMPortType suggested_type,
- gpointer user_data,
- GError **error)
+static void
+port_grabbed (MMGenericGsm *gsm,
+ MMPort *port,
+ MMAtPortFlags pflags,
+ gpointer user_data)
{
- MMGenericGsm *gsm = MM_GENERIC_GSM (modem);
- MMPortType ptype = MM_PORT_TYPE_IGNORED;
- MMPort *port = NULL;
-
- if (suggested_type == MM_PORT_TYPE_UNKNOWN) {
- if (!mm_generic_gsm_get_at_port (gsm, MM_PORT_TYPE_PRIMARY))
- ptype = MM_PORT_TYPE_PRIMARY;
- else if (!mm_generic_gsm_get_at_port (gsm, MM_PORT_TYPE_SECONDARY))
- ptype = MM_PORT_TYPE_SECONDARY;
- } else
- ptype = suggested_type;
-
- port = mm_generic_gsm_grab_port (gsm, subsys, name, ptype, error);
- if (port && MM_IS_AT_SERIAL_PORT (port)) {
+ if (MM_IS_AT_SERIAL_PORT (port)) {
/* Set 9600 baudrate by default */
- g_object_set (G_OBJECT (port),
- MM_SERIAL_PORT_BAUD, 9600,
- NULL);
+ g_object_set (G_OBJECT (port), MM_SERIAL_PORT_BAUD, 9600, NULL);
}
-
- return !!port;
}
static gboolean
@@ -116,7 +95,7 @@ after_atz_sleep_cb (gpointer user_data)
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
MMAtSerialPort *port;
- port = mm_generic_gsm_get_at_port (MM_GENERIC_GSM (info->modem), MM_PORT_TYPE_PRIMARY);
+ port = mm_generic_gsm_get_at_port (MM_GENERIC_GSM (info->modem), MM_AT_PORT_FLAG_PRIMARY);
g_assert (port);
/* And send remaining initialization commands here, we do not care about the
@@ -176,7 +155,7 @@ do_enable (MMGenericGsm *modem, MMModemFn callback, gpointer user_data)
MMCallbackInfo *info;
MMAtSerialPort *primary;
- primary = mm_generic_gsm_get_at_port (modem, MM_PORT_TYPE_PRIMARY);
+ primary = mm_generic_gsm_get_at_port (modem, MM_AT_PORT_FLAG_PRIMARY);
g_assert (primary);
info = mm_callback_info_new (MM_MODEM (modem), callback, user_data);
@@ -222,7 +201,7 @@ after_disconnect_sleep_cb (gpointer user_data)
if (mm_callback_info_check_modem_removed (info))
return FALSE;
- primary = mm_generic_gsm_get_at_port (MM_GENERIC_GSM (info->modem), MM_PORT_TYPE_PRIMARY);
+ primary = mm_generic_gsm_get_at_port (MM_GENERIC_GSM (info->modem), MM_AT_PORT_FLAG_PRIMARY);
g_assert (primary);
/* Propagate errors when reopening the port */
@@ -246,7 +225,7 @@ do_disconnect (MMGenericGsm *gsm,
info = mm_callback_info_new (MM_MODEM (gsm), callback, user_data);
- primary = mm_generic_gsm_get_at_port (gsm, MM_PORT_TYPE_PRIMARY);
+ primary = mm_generic_gsm_get_at_port (gsm, MM_AT_PORT_FLAG_PRIMARY);
g_assert (primary);
/* Close the serial port and wait some seconds before reopening it */
@@ -484,12 +463,6 @@ get_property (GObject *object,
/*****************************************************************************/
static void
-modem_init (MMModem *modem_class)
-{
- modem_class->grab_port = grab_port;
-}
-
-static void
modem_gsm_network_init (MMModemGsmNetwork *network_class)
{
network_class->get_signal_quality = get_signal_quality;
@@ -531,6 +504,7 @@ mm_modem_iridium_gsm_class_init (MMModemIridiumGsmClass *klass)
MM_GENERIC_GSM_PROP_PS_NETWORK_SUPPORTED,
MM_GENERIC_GSM_PS_NETWORK_SUPPORTED);
+ gsm_class->port_grabbed = port_grabbed;
gsm_class->do_enable = do_enable;
gsm_class->do_disconnect = do_disconnect;
gsm_class->get_access_technology = get_access_technology;
diff --git a/plugins/mm-plugin-iridium.c b/plugins/mm-plugin-iridium.c
index 67fee60e..1cff3845 100644
--- a/plugins/mm-plugin-iridium.c
+++ b/plugins/mm-plugin-iridium.c
@@ -175,6 +175,7 @@ grab_port (MMPluginBase *base,
guint32 caps;
guint16 vendor = 0x1e2d;
guint16 product = 0;
+ MMPortType ptype;
port = mm_plugin_base_supports_task_get_port (task);
g_assert (port);
@@ -188,6 +189,7 @@ grab_port (MMPluginBase *base,
caps = mm_plugin_base_supports_task_get_probed_capabilities (task);
sysfs_path = mm_plugin_base_supports_task_get_physdev_path (task);
+ ptype = mm_plugin_base_probed_capabilities_to_port_type (caps);
if (!existing) {
if (caps & MM_PLUGIN_BASE_PORT_CAP_GSM) {
modem = mm_modem_iridium_gsm_new (sysfs_path,
@@ -198,14 +200,14 @@ grab_port (MMPluginBase *base,
}
if (modem) {
- if (!mm_modem_grab_port (modem, subsys, name, MM_PORT_TYPE_UNKNOWN, NULL, error)) {
+ if (!mm_modem_grab_port (modem, subsys, name, ptype, MM_AT_PORT_FLAG_NONE, NULL, error)) {
g_object_unref (modem);
return NULL;
}
}
} else if (get_level_for_capabilities (caps)) {
modem = existing;
- if (!mm_modem_grab_port (modem, subsys, name, MM_PORT_TYPE_UNKNOWN, NULL, error))
+ if (!mm_modem_grab_port (modem, subsys, name, ptype, MM_AT_PORT_FLAG_NONE, NULL, error))
return NULL;
}