broadband-modem-qmi: Use UIM service for querying facility locks

DMS_UIM messages have been deprecated, and have been replaced by
equivalent UIM messages. Use UIM_GET_CARD_STATUS while querying for facility
locks if dms_uim messages were found to be deprecated.
This commit is contained in:
Pavan Holla
2020-09-28 20:38:24 +00:00
committed by Aleksander Morgado
parent 72d8bae65b
commit aa4dce2afc
4 changed files with 108 additions and 13 deletions

View File

@@ -705,7 +705,7 @@ unlock_required_uim_get_card_status_ready (QmiClientUim *client,
if (!mm_qmi_uim_get_card_status_output_parse (self, if (!mm_qmi_uim_get_card_status_output_parse (self,
output, output,
&lock, &lock,
NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
&error)) { &error)) {
/* The device may report a SIM NOT INSERTED error if we're querying the /* The device may report a SIM NOT INSERTED error if we're querying the
* card status soon after power on. We'll let the Modem interface generic * card status soon after power on. We'll let the Modem interface generic
@@ -957,8 +957,8 @@ unlock_retries_uim_get_card_status_ready (QmiClientUim *client,
if (!mm_qmi_uim_get_card_status_output_parse (self, if (!mm_qmi_uim_get_card_status_output_parse (self,
output, output,
NULL, NULL,
&pin1_retries, &puk1_retries, NULL, &pin1_retries, &puk1_retries,
&pin2_retries, &puk2_retries, NULL, &pin2_retries, &puk2_retries,
&error)) { &error)) {
g_task_return_error (task, error); g_task_return_error (task, error);
g_object_unref (task); g_object_unref (task);
@@ -1891,7 +1891,7 @@ typedef struct {
MMModem3gppFacility locks; MMModem3gppFacility locks;
} LoadEnabledFacilityLocksContext; } LoadEnabledFacilityLocksContext;
static void get_next_facility_lock_status (GTask *task); static void get_next_facility_lock_status_via_dms (GTask *task);
static void static void
load_enabled_facility_locks_context_free (LoadEnabledFacilityLocksContext *ctx) load_enabled_facility_locks_context_free (LoadEnabledFacilityLocksContext *ctx)
@@ -1916,6 +1916,80 @@ modem_3gpp_load_enabled_facility_locks_finish (MMIfaceModem3gpp *self,
return (MMModem3gppFacility)value; return (MMModem3gppFacility)value;
} }
static void
get_sim_lock_status_via_get_card_status_ready (QmiClientUim *client,
GAsyncResult *res,
GTask *task)
{
MMBroadbandModemQmi *self;
LoadEnabledFacilityLocksContext *ctx;
QmiMessageUimGetCardStatusOutput *output;
GError *error = NULL;
MMModemLock lock = MM_MODEM_LOCK_UNKNOWN;
QmiUimPinState pin1_state;
QmiUimPinState pin2_state;
self = g_task_get_source_object (task);
ctx = g_task_get_task_data (task);
output = qmi_client_uim_get_card_status_finish (client, res, &error);
if (!output ||
!qmi_message_uim_get_card_status_output_get_result (output, &error)) {
g_prefix_error (&error, "QMI operation failed: ");
g_task_return_error (task, error);
g_object_unref (task);
if (output)
qmi_message_uim_get_card_status_output_unref (output);
return;
}
if (!mm_qmi_uim_get_card_status_output_parse (self,
output,
&lock,
&pin1_state, NULL, NULL, &pin2_state, NULL, NULL,
&error)) {
g_prefix_error (&error, "QMI operation failed: ");
g_task_return_error (task, error);
} else {
ctx->locks &= ~(MM_MODEM_3GPP_FACILITY_SIM);
ctx->locks &= ~(MM_MODEM_3GPP_FACILITY_FIXED_DIALING);
if (pin1_state == QMI_UIM_PIN_STATE_ENABLED_VERIFIED ||
pin1_state == QMI_UIM_PIN_STATE_ENABLED_NOT_VERIFIED ||
pin1_state == QMI_UIM_PIN_STATE_BLOCKED) {
ctx->locks |= (MM_MODEM_3GPP_FACILITY_SIM);
}
if (pin2_state == QMI_UIM_PIN_STATE_ENABLED_VERIFIED ||
pin2_state == QMI_UIM_PIN_STATE_ENABLED_NOT_VERIFIED ||
pin2_state == QMI_UIM_PIN_STATE_BLOCKED) {
ctx->locks |= (MM_MODEM_3GPP_FACILITY_FIXED_DIALING);
}
g_task_return_int (task, ctx->locks);
}
qmi_message_uim_get_card_status_output_unref (output);
g_object_unref (task);
}
static void
get_sim_lock_status_via_get_card_status (GTask *task)
{
MMBroadbandModemQmi *self;
LoadEnabledFacilityLocksContext *ctx;
self = g_task_get_source_object (task);
ctx = g_task_get_task_data (task);
mm_obj_dbg (self, "Getting UIM card status to read pin lock state...");
qmi_client_uim_get_card_status (QMI_CLIENT_UIM (ctx->client),
NULL,
5,
NULL,
(GAsyncReadyCallback) get_sim_lock_status_via_get_card_status_ready,
task);
}
static void static void
get_sim_lock_status_via_pin_status_ready (QmiClientDms *client, get_sim_lock_status_via_pin_status_ready (QmiClientDms *client,
GAsyncResult *res, GAsyncResult *res,
@@ -2035,11 +2109,11 @@ dms_uim_get_ck_status_ready (QmiClientDms *client,
/* And go on with the next one */ /* And go on with the next one */
ctx->current++; ctx->current++;
get_next_facility_lock_status (task); get_next_facility_lock_status_via_dms (task);
} }
static void static void
get_next_facility_lock_status (GTask *task) get_next_facility_lock_status_via_dms (GTask *task)
{ {
LoadEnabledFacilityLocksContext *ctx; LoadEnabledFacilityLocksContext *ctx;
guint i; guint i;
@@ -2085,10 +2159,17 @@ modem_3gpp_load_enabled_facility_locks (MMIfaceModem3gpp *self,
GTask *task; GTask *task;
QmiClient *client = NULL; QmiClient *client = NULL;
if (!mm_shared_qmi_ensure_client (MM_SHARED_QMI (self), if (!MM_BROADBAND_MODEM_QMI (self)->priv->dms_uim_deprecated) {
QMI_SERVICE_DMS, &client, if (!mm_shared_qmi_ensure_client (MM_SHARED_QMI (self),
callback, user_data)) QMI_SERVICE_DMS, &client,
return; callback, user_data))
return;
} else {
if (!mm_shared_qmi_ensure_client (MM_SHARED_QMI (self),
QMI_SERVICE_UIM, &client,
callback, user_data))
return;
}
ctx = g_new (LoadEnabledFacilityLocksContext, 1); ctx = g_new (LoadEnabledFacilityLocksContext, 1);
ctx->client = g_object_ref (client); ctx->client = g_object_ref (client);
@@ -2105,7 +2186,13 @@ modem_3gpp_load_enabled_facility_locks (MMIfaceModem3gpp *self,
task = g_task_new (self, NULL, callback, user_data); task = g_task_new (self, NULL, callback, user_data);
g_task_set_task_data (task, ctx, (GDestroyNotify)load_enabled_facility_locks_context_free); g_task_set_task_data (task, ctx, (GDestroyNotify)load_enabled_facility_locks_context_free);
get_next_facility_lock_status (task); /* DMS uses get_ck_status and get_pin_status to probe facilities
* UIM Messages to get all facility locks are not open-source yet
* UIM uses get_card_status to probe only FACILITY_SIM and FACILITY_FIXED_DIALING */
if (!MM_BROADBAND_MODEM_QMI (self)->priv->dms_uim_deprecated)
get_next_facility_lock_status_via_dms (task);
else
get_sim_lock_status_via_get_card_status (task);
} }
/*****************************************************************************/ /*****************************************************************************/

View File

@@ -1798,8 +1798,10 @@ gboolean
mm_qmi_uim_get_card_status_output_parse (gpointer log_object, mm_qmi_uim_get_card_status_output_parse (gpointer log_object,
QmiMessageUimGetCardStatusOutput *output, QmiMessageUimGetCardStatusOutput *output,
MMModemLock *o_lock, MMModemLock *o_lock,
QmiUimPinState *o_pin1_state,
guint *o_pin1_retries, guint *o_pin1_retries,
guint *o_puk1_retries, guint *o_puk1_retries,
QmiUimPinState *o_pin2_state,
guint *o_pin2_retries, guint *o_pin2_retries,
guint *o_puk2_retries, guint *o_puk2_retries,
GError **error) GError **error)
@@ -1935,11 +1937,15 @@ mm_qmi_uim_get_card_status_output_parse (gpointer log_
return FALSE; return FALSE;
} }
/* Report retries if requested to do so */ /* Report state and retries if requested to do so */
if (o_pin1_state)
*o_pin1_state = app->pin1_state;
if (o_pin1_retries) if (o_pin1_retries)
*o_pin1_retries = app->pin1_retries; *o_pin1_retries = app->pin1_retries;
if (o_puk1_retries) if (o_puk1_retries)
*o_puk1_retries = app->puk1_retries; *o_puk1_retries = app->puk1_retries;
if (o_pin2_state)
*o_pin2_state = app->pin2_state;
if (o_pin2_retries) if (o_pin2_retries)
*o_pin2_retries = app->pin2_retries; *o_pin2_retries = app->pin2_retries;
if (o_puk2_retries) if (o_puk2_retries)

View File

@@ -160,8 +160,10 @@ GArray *mm_firmware_unique_id_to_qmi_unique_id (const gchar *unique_id,
gboolean mm_qmi_uim_get_card_status_output_parse (gpointer log_object, gboolean mm_qmi_uim_get_card_status_output_parse (gpointer log_object,
QmiMessageUimGetCardStatusOutput *output, QmiMessageUimGetCardStatusOutput *output,
MMModemLock *o_lock, MMModemLock *o_lock,
QmiUimPinState *o_pin1_state,
guint *o_pin1_retries, guint *o_pin1_retries,
guint *o_puk1_retries, guint *o_puk1_retries,
QmiUimPinState *o_pin2_state,
guint *o_pin2_retries, guint *o_pin2_retries,
guint *o_puk2_retries, guint *o_puk2_retries,
GError **error); GError **error);

View File

@@ -144,7 +144,7 @@ uim_get_card_status_ready (QmiClientUim *client,
output = qmi_client_uim_get_card_status_finish (client, res, &error); output = qmi_client_uim_get_card_status_finish (client, res, &error);
if (!output || if (!output ||
!qmi_message_uim_get_card_status_output_get_result (output, &error) || !qmi_message_uim_get_card_status_output_get_result (output, &error) ||
(!mm_qmi_uim_get_card_status_output_parse (self, output, NULL, NULL, NULL, NULL, NULL, &error) && (!mm_qmi_uim_get_card_status_output_parse (self, output, NULL, NULL, NULL, NULL, NULL, NULL, NULL, &error) &&
(g_error_matches (error, MM_MOBILE_EQUIPMENT_ERROR, MM_MOBILE_EQUIPMENT_ERROR_SIM_NOT_INSERTED) || (g_error_matches (error, MM_MOBILE_EQUIPMENT_ERROR, MM_MOBILE_EQUIPMENT_ERROR_SIM_NOT_INSERTED) ||
g_error_matches (error, MM_CORE_ERROR, MM_CORE_ERROR_RETRY)))) { g_error_matches (error, MM_CORE_ERROR, MM_CORE_ERROR_RETRY)))) {
mm_obj_dbg (self, "sim not yet considered ready... retrying"); mm_obj_dbg (self, "sim not yet considered ready... retrying");