[PATCH] mark SIM provisioned by default in load_subscription_state

Aleksander Morgado aleksander at lanedo.com
Sun Oct 20 08:15:16 PDT 2013


On 19/10/13 00:27, Prathmesh Prabhu wrote:
> load_subscription_state is called only after a successful registration, so the
> default behaviour should be to mark the SIM as provisioned.
> This default behaviour is needed because it is not possible for plugins to
> detect a successful registration state during the registration update itself.
> So, this function is the first place where a plugin can detect a successful
> registration update.
> ---

Pushed, thanks.

Any ETA for the altair patch with the more detailed info based on the PCO?


>  src/mm-broadband-modem.c | 45 +++++++++++++++++++++++++++++++++++++++++++++
>  1 file changed, 45 insertions(+)
> 
> diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c
> index edac4cb..32fa672 100644
> --- a/src/mm-broadband-modem.c
> +++ b/src/mm-broadband-modem.c
> @@ -3440,6 +3440,49 @@ modem_3gpp_load_operator_name (MMIfaceModem3gpp *self,
>  }
>  
>  /*****************************************************************************/
> +/* Subscription State Loading (3GPP interface) */
> +
> +static MMModem3gppSubscriptionState
> +modem_3gpp_load_subscription_state_finish (MMIfaceModem3gpp *self,
> +                                           GAsyncResult *res,
> +                                           GError **error)
> +{
> +    if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res), error))
> +        return MM_MODEM_3GPP_SUBSCRIPTION_STATE_UNKNOWN;
> +
> +    return (MMModem3gppSubscriptionState) GPOINTER_TO_UINT (
> +        g_simple_async_result_get_op_res_gpointer (G_SIMPLE_ASYNC_RESULT (res)));
> +}
> +
> +static void
> +modem_3gpp_load_subscription_state (MMIfaceModem3gpp *self,
> +                                    GAsyncReadyCallback callback,
> +                                    gpointer user_data)
> +{
> +    GSimpleAsyncResult *result;
> +
> +    result = g_simple_async_result_new (G_OBJECT (self),
> +                                        callback,
> +                                        user_data,
> +                                        modem_3gpp_load_subscription_state);
> +
> +   /* Reloading subscription state only occurs on a successfully registered
> +    * modem. (Although the 3GPP interface does not reflect this until after
> +    * loading operator information completes.)
> +    * By default, we can assume that successful registration implies a
> +    * provisioned SIM.
> +    */
> +    mm_dbg ("Load subscription state: Marking the SIM as provisioned.");
> +    g_simple_async_result_set_op_res_gpointer (
> +        result,
> +        GUINT_TO_POINTER (MM_MODEM_3GPP_SUBSCRIPTION_STATE_PROVISIONED),
> +        NULL);
> +
> +    g_simple_async_result_complete_in_idle (result);
> +    g_object_unref (result);
> +}
> +
> +/*****************************************************************************/
>  /* Unsolicited registration messages handling (3GPP interface) */
>  
>  static gboolean
> @@ -9626,6 +9669,8 @@ iface_modem_3gpp_init (MMIfaceModem3gpp *iface)
>      iface->load_operator_code_finish = modem_3gpp_load_operator_code_finish;
>      iface->load_operator_name = modem_3gpp_load_operator_name;
>      iface->load_operator_name_finish = modem_3gpp_load_operator_name_finish;
> +    iface->load_subscription_state = modem_3gpp_load_subscription_state;
> +    iface->load_subscription_state_finish = modem_3gpp_load_subscription_state_finish;
>      iface->run_registration_checks = modem_3gpp_run_registration_checks;
>      iface->run_registration_checks_finish = modem_3gpp_run_registration_checks_finish;
>      iface->register_in_network = modem_3gpp_register_in_network;
> 


-- 
Aleksander


More information about the ModemManager-devel mailing list