diff options
author | Aleksander Morgado <aleksander@aleksander.es> | 2018-07-08 14:27:35 +0200 |
---|---|---|
committer | Dan Williams <dcbw@redhat.com> | 2018-09-12 17:25:19 +0000 |
commit | 6026c99f2ec99e2721356ee645472d8403676bf6 (patch) | |
tree | 8c9c7b5ee6d88ee82b27622704a402c53a5f3009 /src/mm-shared-qmi.c | |
parent | 9dc26cc44d79f18789a510e050fc899b680587ec (diff) |
shared-qmi: reuse device factory reset logic in MBIM whenever possible
Diffstat (limited to 'src/mm-shared-qmi.c')
-rw-r--r-- | src/mm-shared-qmi.c | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/src/mm-shared-qmi.c b/src/mm-shared-qmi.c index 9a2cbd25..dba063cf 100644 --- a/src/mm-shared-qmi.c +++ b/src/mm-shared-qmi.c @@ -190,6 +190,79 @@ mm_shared_qmi_reset (MMIfaceModem *self, } /*****************************************************************************/ +/* Factory reset (Modem interface) */ + +gboolean +mm_shared_qmi_factory_reset_finish (MMIfaceModem *self, + GAsyncResult *res, + GError **error) +{ + return g_task_propagate_boolean (G_TASK (res), error); +} + +static void +dms_restore_factory_defaults_ready (QmiClientDms *client, + GAsyncResult *res, + GTask *task) +{ + QmiMessageDmsRestoreFactoryDefaultsOutput *output = NULL; + GError *error = NULL; + + output = qmi_client_dms_restore_factory_defaults_finish (client, res, &error); + if (!output) { + g_prefix_error (&error, "QMI operation failed: "); + g_task_return_error (task, error); + } else if (!qmi_message_dms_restore_factory_defaults_output_get_result (output, &error)) { + g_prefix_error (&error, "Couldn't restore factory defaults: "); + g_task_return_error (task, error); + } else + g_task_return_boolean (task, TRUE); + + if (output) + qmi_message_dms_restore_factory_defaults_output_unref (output); + + g_object_unref (task); +} + +void +mm_shared_qmi_factory_reset (MMIfaceModem *self, + const gchar *code, + GAsyncReadyCallback callback, + gpointer user_data) +{ + QmiMessageDmsRestoreFactoryDefaultsInput *input; + GTask *task; + QmiClient *client = NULL; + GError *error = NULL; + + if (!mm_shared_qmi_ensure_client (MM_SHARED_QMI (self), + QMI_SERVICE_DMS, &client, + callback, user_data)) + return; + + task = g_task_new (self, NULL, callback, user_data); + + input = qmi_message_dms_restore_factory_defaults_input_new (); + if (!qmi_message_dms_restore_factory_defaults_input_set_service_programming_code ( + input, + code, + &error)) { + qmi_message_dms_restore_factory_defaults_input_unref (input); + g_task_return_error (task, error); + g_object_unref (task); + return; + } + + mm_dbg ("performing a factory reset..."); + qmi_client_dms_restore_factory_defaults (QMI_CLIENT_DMS (client), + input, + 10, + NULL, + (GAsyncReadyCallback)dms_restore_factory_defaults_ready, + task); +} + +/*****************************************************************************/ /* Location: Set SUPL server */ typedef struct { |