diff options
author | Ben Chan <benchan@chromium.org> | 2018-05-01 13:46:40 -0700 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2018-06-02 17:56:59 +0200 |
commit | 478232dc05a4aa6404f82924a316440eaba44d03 (patch) | |
tree | 3202f4ecd9381dea6aeb95bf4f6394392be7842e | |
parent | b6de1ad22ef6ca341aeddd76b1a2ab1369d9d35a (diff) | |
download | ModemManager-478232dc05a4aa6404f82924a316440eaba44d03.tar.gz |
broadband-modem-qmi: port modem_3gpp_run_registration_checks to use GTask
-rw-r--r-- | src/mm-broadband-modem-qmi.c | 76 |
1 files changed, 30 insertions, 46 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c index db5a0d04d..9ab2c103c 100644 --- a/src/mm-broadband-modem-qmi.c +++ b/src/mm-broadband-modem-qmi.c @@ -4395,28 +4395,12 @@ modem_3gpp_register_in_network (MMIfaceModem3gpp *self, /*****************************************************************************/ /* Registration checks (3GPP interface) */ -typedef struct { - MMBroadbandModemQmi *self; - QmiClientNas *client; - GSimpleAsyncResult *result; -} Run3gppRegistrationChecksContext; - -static void -run_3gpp_registration_checks_context_complete_and_free (Run3gppRegistrationChecksContext *ctx) -{ - g_simple_async_result_complete (ctx->result); - g_object_unref (ctx->result); - g_object_unref (ctx->client); - g_object_unref (ctx->self); - g_free (ctx); -} - static gboolean modem_3gpp_run_registration_checks_finish (MMIfaceModem3gpp *self, GAsyncResult *res, GError **error) { - return !g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error); + return g_task_propagate_boolean (G_TASK (res), error); } static void @@ -4607,32 +4591,35 @@ common_process_serving_system_3gpp (MMBroadbandModemQmi *self, static void get_serving_system_3gpp_ready (QmiClientNas *client, GAsyncResult *res, - Run3gppRegistrationChecksContext *ctx) + GTask *task) { + MMBroadbandModemQmi *self; QmiMessageNasGetServingSystemOutput *output; GError *error = NULL; output = qmi_client_nas_get_serving_system_finish (client, res, &error); if (!output) { g_prefix_error (&error, "QMI operation failed: "); - g_simple_async_result_take_error (ctx->result, error); - run_3gpp_registration_checks_context_complete_and_free (ctx); + g_task_return_error (task, error); + g_object_unref (task); return; } if (!qmi_message_nas_get_serving_system_output_get_result (output, &error)) { g_prefix_error (&error, "Couldn't get serving system: "); - g_simple_async_result_take_error (ctx->result, error); + g_task_return_error (task, error); + g_object_unref (task); qmi_message_nas_get_serving_system_output_unref (output); - run_3gpp_registration_checks_context_complete_and_free (ctx); return; } - common_process_serving_system_3gpp (ctx->self, output, NULL); + self = g_task_get_source_object (task); - g_simple_async_result_set_op_res_gboolean (ctx->result, TRUE); + common_process_serving_system_3gpp (self, output, NULL); + + g_task_return_boolean (task, TRUE); + g_object_unref (task); qmi_message_nas_get_serving_system_output_unref (output); - run_3gpp_registration_checks_context_complete_and_free (ctx); } #if defined WITH_NEWEST_QMI_COMMANDS @@ -5092,32 +5079,35 @@ common_process_system_info_3gpp (MMBroadbandModemQmi *self, static void get_system_info_ready (QmiClientNas *client, GAsyncResult *res, - Run3gppRegistrationChecksContext *ctx) + GTask *task) { + MMBroadbandModemQmi *self; QmiMessageNasGetSystemInfoOutput *output; GError *error = NULL; output = qmi_client_nas_get_system_info_finish (client, res, &error); if (!output) { g_prefix_error (&error, "QMI operation failed: "); - g_simple_async_result_take_error (ctx->result, error); - run_3gpp_registration_checks_context_complete_and_free (ctx); + g_task_return_error (task, error); + g_object_unref (task); return; } if (!qmi_message_nas_get_system_info_output_get_result (output, &error)) { g_prefix_error (&error, "Couldn't get system info: "); - g_simple_async_result_take_error (ctx->result, error); + g_task_return_error (task, error); qmi_message_nas_get_system_info_output_unref (output); - run_3gpp_registration_checks_context_complete_and_free (ctx); + g_object_unref (task); return; } - common_process_system_info_3gpp (ctx->self, output, NULL); + self = g_task_get_source_object (task); - g_simple_async_result_set_op_res_gboolean (ctx->result, TRUE); + common_process_system_info_3gpp (self, output, NULL); + + g_task_return_boolean (task, TRUE); + g_object_unref (task); qmi_message_nas_get_system_info_output_unref (output); - run_3gpp_registration_checks_context_complete_and_free (ctx); } #endif /* WITH_NEWEST_QMI_COMMANDS */ @@ -5130,41 +5120,35 @@ modem_3gpp_run_registration_checks (MMIfaceModem3gpp *self, GAsyncReadyCallback callback, gpointer user_data) { - Run3gppRegistrationChecksContext *ctx; + GTask *task; QmiClient *client = NULL; - if (!ensure_qmi_client (MM_BROADBAND_MODEM_QMI (self), + if (!assure_qmi_client (MM_BROADBAND_MODEM_QMI (self), QMI_SERVICE_NAS, &client, callback, user_data)) return; - ctx = g_new0 (Run3gppRegistrationChecksContext, 1); - ctx->self = g_object_ref (self); - ctx->client = g_object_ref (client); - ctx->result = g_simple_async_result_new (G_OBJECT (self), - callback, - user_data, - modem_3gpp_run_registration_checks); + task = g_task_new (self, NULL, callback, user_data); #if defined WITH_NEWEST_QMI_COMMANDS /* System Info was added in NAS 1.8 */ if (qmi_client_check_version (client, 1, 8)) { - qmi_client_nas_get_system_info (ctx->client, + qmi_client_nas_get_system_info (QMI_CLIENT_NAS (client), NULL, 10, NULL, (GAsyncReadyCallback)get_system_info_ready, - ctx); + task); return; } #endif /* WITH_NEWEST_QMI_COMMANDS */ - qmi_client_nas_get_serving_system (ctx->client, + qmi_client_nas_get_serving_system (QMI_CLIENT_NAS (client), NULL, 10, NULL, (GAsyncReadyCallback)get_serving_system_3gpp_ready, - ctx); + task); } /*****************************************************************************/ |