aboutsummaryrefslogtreecommitdiff
path: root/plugins/mm-modem-option.c
diff options
context:
space:
mode:
authorTambet Ingo <tambet@gmail.com>2008-10-30 17:00:15 +0200
committerTambet Ingo <tambet@gmail.com>2008-10-30 17:00:15 +0200
commit00c79d7fa153895dd9cddaeda8cadcaa50005223 (patch)
treecbed49eeb1961128c939623e8291914be9963aba /plugins/mm-modem-option.c
parent0b9badee75d162f23d7f462eb5a5ccbcb73bef3a (diff)
Explicitly check the PIN after modem is enabled.
Diffstat (limited to 'plugins/mm-modem-option.c')
-rw-r--r--plugins/mm-modem-option.c85
1 files changed, 34 insertions, 51 deletions
diff --git a/plugins/mm-modem-option.c b/plugins/mm-modem-option.c
index 27d7e854..c5800d8f 100644
--- a/plugins/mm-modem-option.c
+++ b/plugins/mm-modem-option.c
@@ -24,59 +24,53 @@ mm_modem_option_new (const char *data_device,
}
static void
-enable_done (MMSerial *serial,
- GString *response,
- GError *error,
- gpointer user_data)
+check_pin_done (MMSerial *serial,
+ GString *response,
+ GError *error,
+ gpointer user_data)
{
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
+ gboolean parsed = FALSE;
if (error)
info->error = g_error_copy (error);
- else {
- /* Option returns OK on +CFUN=1 right away but needs some time
- to finish initialization */
- sleep (7);
+ else if (g_str_has_prefix (response->str, "+CPIN: ")) {
+ const char *str = response->str + 7;
+
+ if (g_str_has_prefix (str, "READY"))
+ parsed = TRUE;
+ else if (g_str_has_prefix (str, "SIM PIN"))
+ info->error = mm_mobile_error_for_code (MM_MOBILE_ERROR_SIM_PIN);
+ else if (g_str_has_prefix (str, "SIM PUK"))
+ info->error = mm_mobile_error_for_code (MM_MOBILE_ERROR_SIM_PUK);
}
+ if (!info->error && !parsed)
+ info->error = g_error_new (MM_MODEM_ERROR, MM_MODEM_ERROR_GENERAL,
+ "%s", "Could not parse PIN request results");
+
mm_callback_info_schedule (info);
}
static void
-init_done (MMSerial *serial,
- GString *response,
- GError *error,
- gpointer user_data)
+parent_enable_done (MMModem *modem, GError *error, gpointer user_data)
{
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
- if (error) {
+ if (error)
info->error = g_error_copy (error);
- mm_callback_info_schedule (info);
- } else
- mm_serial_queue_command (serial, "+CFUN=1", 5, enable_done, user_data);
-}
-
-static void
-enable_flash_done (MMSerial *serial, gpointer user_data)
-{
- mm_serial_queue_command (serial, "Z E0 V1 X4 &C1 +CMEE=1", 3, init_done, user_data);
-}
+ else if (GPOINTER_TO_INT (mm_callback_info_get_data (info, "option-enable"))) {
+ /* Option returns OK on +CFUN=1 right away but needs some time
+ to finish initialization */
+ sleep (10);
-static void
-disable_done (MMSerial *serial,
- GString *response,
- GError *error,
- gpointer user_data)
-{
- mm_serial_close (serial);
- mm_callback_info_schedule ((MMCallbackInfo *) user_data);
-}
+ /* Now check the PIN explicitly, option doesn't seem to report
+ that it needs it otherwise */
+ mm_serial_queue_command (MM_SERIAL (modem), "+CPIN?", 3, check_pin_done, info);
+ return;
+ }
-static void
-disable_flash_done (MMSerial *serial, gpointer user_data)
-{
- mm_serial_queue_command (serial, "+CFUN=0", 5, disable_done, user_data);
+ mm_callback_info_schedule (info);
}
static void
@@ -85,25 +79,14 @@ enable (MMModem *modem,
MMModemFn callback,
gpointer user_data)
{
+ MMModem *parent_modem_iface;
MMCallbackInfo *info;
- /* First, reset the previously used CID */
- mm_generic_gsm_set_cid (MM_GENERIC_GSM (modem), 0);
-
info = mm_callback_info_new (modem, callback, user_data);
+ mm_callback_info_set_data (info, "option-enable", GINT_TO_POINTER (enable), NULL);
- if (!enable) {
- if (mm_serial_is_connected (MM_SERIAL (modem)))
- mm_serial_flash (MM_SERIAL (modem), 1000, disable_flash_done, info);
- else
- disable_flash_done (MM_SERIAL (modem), info);
- } else {
- if (mm_serial_open (MM_SERIAL (modem), &info->error))
- mm_serial_flash (MM_SERIAL (modem), 100, enable_flash_done, info);
-
- if (info->error)
- mm_callback_info_schedule (info);
- }
+ parent_modem_iface = g_type_interface_peek_parent (MM_MODEM_GET_INTERFACE (modem));
+ parent_modem_iface->enable (modem, enable, parent_enable_done, info);
}
static void