diff options
author | ori inbar <ori.inbar.altair.semi.com@gmail.com> | 2013-04-23 13:15:42 -0500 |
---|---|---|
committer | Aleksander Morgado <aleksander@lanedo.com> | 2013-04-24 23:05:35 +0200 |
commit | ba83bc61d05629762c72c2dce18cff5fadc30658 (patch) | |
tree | 4243e1d708678a3dc30b2b4b132fe7feba62a81b | |
parent | 126d89b2f311b46784434db52a6614699bac83b5 (diff) | |
download | ModemManager-ba83bc61d05629762c72c2dce18cff5fadc30658.tar.gz |
altair-lte: Add SIM unlock retries query to the Altair plugin.
-rw-r--r-- | plugins/altair/mm-broadband-modem-altair-lte.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/plugins/altair/mm-broadband-modem-altair-lte.c b/plugins/altair/mm-broadband-modem-altair-lte.c index 019417e9e..b2ed7c5f9 100644 --- a/plugins/altair/mm-broadband-modem-altair-lte.c +++ b/plugins/altair/mm-broadband-modem-altair-lte.c @@ -140,6 +140,77 @@ modem_create_bearer (MMIfaceModem *self, } /*****************************************************************************/ +/* Load unlock retries (Modem interface) */ + +static MMUnlockRetries * +load_unlock_retries_finish (MMIfaceModem *self, + GAsyncResult *res, + GError **error) +{ + if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error)) + return NULL; + return (MMUnlockRetries *) g_object_ref (g_simple_async_result_get_op_res_gpointer ( + G_SIMPLE_ASYNC_RESULT (res))); +} + +static void +load_unlock_retries_ready (MMBaseModem *self, + GAsyncResult *res, + GSimpleAsyncResult *operation_result) +{ + const gchar *response; + GError *error = NULL; + int pin1, puk1,pin2, puk2; + + response = mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, &error); + if (!response) { + mm_dbg ("Couldn't query unlock retries: '%s'", error->message); + g_simple_async_result_take_error (operation_result, error); + g_simple_async_result_complete (operation_result); + g_object_unref (operation_result); + return; + } + + response = mm_strip_tag (response, "%CPININFO:"); + if (sscanf (response, " %d, %d, %d, %d", &pin1, &puk1,&pin2, &puk2) == 4) { + MMUnlockRetries *retries; + retries = mm_unlock_retries_new (); + mm_unlock_retries_set (retries, MM_MODEM_LOCK_SIM_PIN, pin1); + mm_unlock_retries_set (retries, MM_MODEM_LOCK_SIM_PUK, puk1); + mm_unlock_retries_set (retries, MM_MODEM_LOCK_SIM_PIN2, pin2); + mm_unlock_retries_set (retries, MM_MODEM_LOCK_SIM_PUK2, puk2); + g_simple_async_result_set_op_res_gpointer (operation_result, + retries, + (GDestroyNotify)g_object_unref); + } else { + g_simple_async_result_set_error (operation_result, + MM_CORE_ERROR, + MM_CORE_ERROR_FAILED, + "Invalid unlock retries response: '%s'", + response); + } + g_simple_async_result_complete (operation_result); + g_object_unref (operation_result); +} + +static void +load_unlock_retries (MMIfaceModem *self, + GAsyncReadyCallback callback, + gpointer user_data) +{ + mm_base_modem_at_command ( + MM_BASE_MODEM (self), + "%CPININFO", + 3, + FALSE, + (GAsyncReadyCallback)load_unlock_retries_ready, + g_simple_async_result_new (G_OBJECT (self), + callback, + user_data, + load_unlock_retries)); +} + +/*****************************************************************************/ /* Load current capabilities (Modem interface) */ static MMModemCapability @@ -893,6 +964,8 @@ iface_modem_init (MMIfaceModem *iface) iface->modem_power_down_finish = modem_power_down_finish; iface->create_bearer = modem_create_bearer; iface->create_bearer_finish = modem_create_bearer_finish; + iface->load_unlock_retries = load_unlock_retries; + iface->load_unlock_retries_finish = load_unlock_retries_finish; iface->load_current_capabilities = load_current_capabilities; iface->load_current_capabilities_finish = load_current_capabilities_finish; iface->load_supported_bands = load_supported_bands; |