[PATCH 2/2] Adding a short delay after SIM unlock

Aleksander Morgado aleksander at aleksander.es
Fri May 13 18:06:54 UTC 2016


On Fri, May 13, 2016 at 5:15 PM, Carlo Lobrano <c.lobrano at gmail.com> wrote:
> A short delay is necessary with some SIMs when
> they have just been unlocked. Using 1 second as secure margin.

I assume there's no SIM status notification, or maybe a command to
check for SIM readiness, right?

> ---
>  plugins/telit/mm-broadband-modem-telit.c | 38 ++++++++++++++++++++++++++++++++
>  1 file changed, 38 insertions(+)
>
> diff --git a/plugins/telit/mm-broadband-modem-telit.c b/plugins/telit/mm-broadband-modem-telit.c
> index 8baf2cf..9d9b6d3 100644
> --- a/plugins/telit/mm-broadband-modem-telit.c
> +++ b/plugins/telit/mm-broadband-modem-telit.c
> @@ -42,6 +42,42 @@ G_DEFINE_TYPE_EXTENDED (MMBroadbandModemTelit, mm_broadband_modem_telit, MM_TYPE
>                          G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM, iface_modem_init)
>                          G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM_3GPP, iface_modem_3gpp_init));
>
> +
> +/*****************************************************************************/
> +/* After Sim Unlock (Modem interface) */
> +static gboolean
> +modem_after_sim_unlock_finish (MMIfaceModem *self,
> +                               GAsyncResult *res,
> +                               GError **error)
> +{
> +    return TRUE;
> +}
> +
> +static gboolean
> +after_sim_unlock_ready (GSimpleAsyncResult *result)
> +{
> +    g_simple_async_result_complete (result);
> +    g_object_unref (result);
> +    return G_SOURCE_REMOVE;
> +}
> +
> +static void
> +modem_after_sim_unlock (MMIfaceModem *self,
> +                        GAsyncReadyCallback callback,
> +                        gpointer user_data)
> +{
> +    GSimpleAsyncResult *result;
> +
> +    result = g_simple_async_result_new (G_OBJECT (self),
> +                                        callback,
> +                                        user_data,
> +                                        modem_after_sim_unlock);
> +
> +    /* A short delay is necessary with some SIMs when
> +    they have just been unlocked. Using 1 second as secure margin. */
> +    g_timeout_add_seconds (1, (GSourceFunc) after_sim_unlock_ready, result);
> +}
> +
>  /*****************************************************************************/
>  /* Set current bands (Modem interface) */
>
> @@ -1052,6 +1088,8 @@ iface_modem_init (MMIfaceModem *iface)
>      iface->load_current_modes_finish = load_current_modes_finish;
>      iface->set_current_modes = set_current_modes;
>      iface->set_current_modes_finish = set_current_modes_finish;
> +    iface->modem_after_sim_unlock = modem_after_sim_unlock;
> +    iface->modem_after_sim_unlock_finish = modem_after_sim_unlock_finish;
>  }
>
>  static void
> --
> 2.1.4
>
> _______________________________________________
> ModemManager-devel mailing list
> ModemManager-devel at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/modemmanager-devel



-- 
Aleksander
https://aleksander.es


More information about the ModemManager-devel mailing list