aboutsummaryrefslogtreecommitdiff
path: root/src/mm-sim-qmi.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/mm-sim-qmi.c')
-rw-r--r--src/mm-sim-qmi.c114
1 files changed, 114 insertions, 0 deletions
diff --git a/src/mm-sim-qmi.c b/src/mm-sim-qmi.c
index 685eeb65..16b96c65 100644
--- a/src/mm-sim-qmi.c
+++ b/src/mm-sim-qmi.c
@@ -23,12 +23,122 @@
#include <ModemManager.h>
#include <libmm-common.h>
+#include "mm-log.h"
#include "mm-sim-qmi.h"
G_DEFINE_TYPE (MMSimQmi, mm_sim_qmi, MM_TYPE_SIM);
/*****************************************************************************/
+static gboolean
+ensure_qmi_client (MMSimQmi *self,
+ QmiService service,
+ QmiClient **o_client,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ MMBaseModem *modem = NULL;
+ QmiClient *client;
+
+ g_object_get (self,
+ MM_SIM_MODEM, &modem,
+ NULL);
+ g_assert (MM_IS_BASE_MODEM (modem));
+
+ client = mm_qmi_port_peek_client (mm_base_modem_peek_port_qmi (modem), service);
+ if (!client)
+ g_simple_async_report_error_in_idle (G_OBJECT (self),
+ callback,
+ user_data,
+ MM_CORE_ERROR,
+ MM_CORE_ERROR_FAILED,
+ "Couldn't peek client for service '%s'",
+ qmi_service_get_string (service));
+ else
+ *o_client = client;
+
+ g_object_unref (modem);
+ return !!client;
+}
+
+/*****************************************************************************/
+/* Load SIM ID (ICCID) */
+
+static gchar *
+load_sim_identifier_finish (MMSim *self,
+ GAsyncResult *res,
+ GError **error)
+{
+ gchar *sim_identifier;
+
+ if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
+ return NULL;
+
+ sim_identifier = g_strdup (g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)));
+ mm_dbg ("loaded SIM identifier: %s", sim_identifier);
+ return sim_identifier;
+}
+
+static void
+dms_uim_get_iccid_ready (QmiClientDms *client,
+ GAsyncResult *res,
+ GSimpleAsyncResult *simple)
+{
+ QmiMessageDmsUimGetIccidOutput *output = NULL;
+ GError *error = NULL;
+
+ output = qmi_client_dms_uim_get_iccid_finish (client, res, &error);
+ if (!output) {
+ g_prefix_error (&error, "QMI operation failed: ");
+ g_simple_async_result_take_error (simple, error);
+ } else if (!qmi_message_dms_uim_get_iccid_output_get_result (output, &error)) {
+ g_prefix_error (&error, "Couldn't get UIM ICCID: ");
+ g_simple_async_result_take_error (simple, error);
+ } else {
+ const gchar *str = NULL;
+
+ qmi_message_dms_uim_get_iccid_output_get_iccid (output, &str, NULL);
+ g_simple_async_result_set_op_res_gpointer (simple,
+ g_strdup (str),
+ (GDestroyNotify)g_free);
+ }
+
+ if (output)
+ qmi_message_dms_uim_get_iccid_output_unref (output);
+
+ g_simple_async_result_complete (simple);
+ g_object_unref (simple);
+}
+
+static void
+load_sim_identifier (MMSim *self,
+ GAsyncReadyCallback callback,
+ gpointer user_data)
+{
+ GSimpleAsyncResult *result;
+ QmiClient *client = NULL;
+
+ if (!ensure_qmi_client (MM_SIM_QMI (self),
+ QMI_SERVICE_DMS, &client,
+ callback, user_data))
+ return;
+
+ result = g_simple_async_result_new (G_OBJECT (self),
+ callback,
+ user_data,
+ load_sim_identifier);
+
+ mm_dbg ("loading SIM identifier...");
+ qmi_client_dms_uim_get_iccid (QMI_CLIENT_DMS (client),
+ NULL,
+ 5,
+ NULL,
+ (GAsyncReadyCallback)dms_uim_get_iccid_ready,
+ result);
+}
+
+/*****************************************************************************/
+
MMSim *
mm_sim_qmi_new_finish (GAsyncResult *res,
GError **error)
@@ -72,4 +182,8 @@ mm_sim_qmi_init (MMSimQmi *self)
static void
mm_sim_qmi_class_init (MMSimQmiClass *klass)
{
+ MMSimClass *sim_class = MM_SIM_CLASS (klass);
+
+ sim_class->load_sim_identifier = load_sim_identifier;
+ sim_class->load_sim_identifier_finish = load_sim_identifier_finish;
}