From 3e758d5394c65ea087f32b876e4b7f245b75dac1 Mon Sep 17 00:00:00 2001 From: Aleksander Morgado Date: Sat, 13 Apr 2013 14:01:02 +0200 Subject: broadband-modem-mbim: implement enabled facility locks loading --- src/mm-broadband-modem-mbim.c | 122 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 122 insertions(+) diff --git a/src/mm-broadband-modem-mbim.c b/src/mm-broadband-modem-mbim.c index c7e92c9e..6dc882a7 100644 --- a/src/mm-broadband-modem-mbim.c +++ b/src/mm-broadband-modem-mbim.c @@ -1233,6 +1233,126 @@ modem_3gpp_load_imei (MMIfaceModem3gpp *_self, g_object_unref (result); } +/*****************************************************************************/ +/* Facility locks status loading (3GPP interface) */ + +static MMModem3gppFacility +modem_3gpp_load_enabled_facility_locks_finish (MMIfaceModem3gpp *self, + GAsyncResult *res, + GError **error) +{ + if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error)) + return MM_MODEM_3GPP_FACILITY_NONE; + + return ((MMModem3gppFacility) GPOINTER_TO_UINT ( + g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)))); +} + +static void +pin_list_query_ready (MbimDevice *device, + GAsyncResult *res, + GSimpleAsyncResult *simple) +{ + MbimMessage *response; + GError *error = NULL; + MbimPinDesc *pin_desc_pin1; + MbimPinDesc *pin_desc_pin2; + MbimPinDesc *pin_desc_device_sim_pin; + MbimPinDesc *pin_desc_device_first_sim_pin; + MbimPinDesc *pin_desc_network_pin; + MbimPinDesc *pin_desc_network_subset_pin; + MbimPinDesc *pin_desc_service_provider_pin; + MbimPinDesc *pin_desc_corporate_pin; + + response = mbim_device_command_finish (device, res, &error); + if (response && + mbim_message_command_done_get_result (response, &error) && + mbim_message_pin_list_response_parse ( + response, + &pin_desc_pin1, + &pin_desc_pin2, + &pin_desc_device_sim_pin, + &pin_desc_device_first_sim_pin, + &pin_desc_network_pin, + &pin_desc_network_subset_pin, + &pin_desc_service_provider_pin, + &pin_desc_corporate_pin, + NULL, /* pin_desc_subsidy_lock */ + NULL, /* pin_desc_custom */ + &error)) { + MMModem3gppFacility mask = MM_MODEM_3GPP_FACILITY_NONE; + + if (pin_desc_pin1->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_SIM; + mbim_pin_desc_free (pin_desc_pin1); + + if (pin_desc_pin2->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_FIXED_DIALING; + mbim_pin_desc_free (pin_desc_pin2); + + if (pin_desc_device_sim_pin->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_PH_SIM; + mbim_pin_desc_free (pin_desc_device_sim_pin); + + if (pin_desc_device_first_sim_pin->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_PH_FSIM; + mbim_pin_desc_free (pin_desc_device_first_sim_pin); + + if (pin_desc_network_pin->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_NET_PERS; + mbim_pin_desc_free (pin_desc_network_pin); + + if (pin_desc_network_subset_pin->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_NET_SUB_PERS; + mbim_pin_desc_free (pin_desc_network_subset_pin); + + if (pin_desc_service_provider_pin->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_PROVIDER_PERS; + mbim_pin_desc_free (pin_desc_service_provider_pin); + + if (pin_desc_corporate_pin->pin_mode == MBIM_PIN_MODE_ENABLED) + mask |= MM_MODEM_3GPP_FACILITY_CORP_PERS; + mbim_pin_desc_free (pin_desc_corporate_pin); + + g_simple_async_result_set_op_res_gpointer (simple, + GUINT_TO_POINTER (mask), + NULL); + } else + g_simple_async_result_take_error (simple, error); + + if (response) + mbim_message_unref (response); + g_simple_async_result_complete (simple); + g_object_unref (simple); +} + +static void +modem_3gpp_load_enabled_facility_locks (MMIfaceModem3gpp *self, + GAsyncReadyCallback callback, + gpointer user_data) +{ + GSimpleAsyncResult *result; + MbimDevice *device; + MbimMessage *message; + + if (!peek_device (self, &device, callback, user_data)) + return; + + result = g_simple_async_result_new (G_OBJECT (self), + callback, + user_data, + modem_load_unlock_retries); + + message = mbim_message_pin_list_query_new (NULL); + mbim_device_command (device, + message, + 10, + NULL, + (GAsyncReadyCallback)pin_list_query_ready, + result); + mbim_message_unref (message); +} + /*****************************************************************************/ MMBroadbandModemMbim * @@ -1336,6 +1456,8 @@ iface_modem_3gpp_init (MMIfaceModem3gpp *iface) /* Initialization steps */ iface->load_imei = modem_3gpp_load_imei; iface->load_imei_finish = modem_3gpp_load_imei_finish; + iface->load_enabled_facility_locks = modem_3gpp_load_enabled_facility_locks; + iface->load_enabled_facility_locks_finish = modem_3gpp_load_enabled_facility_locks_finish; } static void -- cgit v1.2.3