[PATCH v2 08/13] ublox: try to use AT+UACT=? to query supported bands
Aleksander Morgado
aleksander at aleksander.es
Fri Sep 15 23:22:45 UTC 2017
On 14/09/17 22:01, Aleksander Morgado wrote:
> ---
> plugins/ublox/mm-broadband-modem-ublox.c | 98 ++++++++++++++++++++++++++------
> 1 file changed, 81 insertions(+), 17 deletions(-)
>
Merged to git master.
> diff --git a/plugins/ublox/mm-broadband-modem-ublox.c b/plugins/ublox/mm-broadband-modem-ublox.c
> index 8d9da206..27345752 100644
> --- a/plugins/ublox/mm-broadband-modem-ublox.c
> +++ b/plugins/ublox/mm-broadband-modem-ublox.c
> @@ -37,6 +37,12 @@ static void iface_modem_init (MMIfaceModem *iface);
> G_DEFINE_TYPE_EXTENDED (MMBroadbandModemUblox, mm_broadband_modem_ublox, MM_TYPE_BROADBAND_MODEM, 0,
> G_IMPLEMENT_INTERFACE (MM_TYPE_IFACE_MODEM, iface_modem_init))
>
> +typedef enum {
> + FEATURE_SUPPORT_UNKNOWN,
> + FEATURE_SUPPORTED,
> + FEATURE_UNSUPPORTED,
> +} FeatureSupport;
> +
> struct _MMBroadbandModemUbloxPrivate {
> /* USB profile in use */
> MMUbloxUsbProfile profile;
> @@ -50,6 +56,9 @@ struct _MMBroadbandModemUbloxPrivate {
>
> /* Mode combination to apply if "any" requested */
> MMModemMode any_allowed;
> +
> + /* Band management */
> + FeatureSupport uact;
> };
>
> /*****************************************************************************/
> @@ -85,31 +94,85 @@ load_supported_bands_finish (MMIfaceModem *self,
> return (GArray *) g_task_propagate_pointer (G_TASK (res), error);
> }
>
> +static void
> +uact_test_ready (MMBaseModem *_self,
> + GAsyncResult *res,
> + GTask *task)
> +{
> + MMBroadbandModemUblox *self = MM_BROADBAND_MODEM_UBLOX (_self);
> + const gchar *response;
> + GError *error = NULL;
> + GArray *bands = NULL;
> + GArray *bands_2g = NULL;
> + GArray *bands_3g = NULL;
> + GArray *bands_4g = NULL;
> +
> + response = mm_base_modem_at_command_finish (_self, res, NULL);
> + if (!response) {
> + /* Flag as unsupported */
> + self->priv->uact = FEATURE_UNSUPPORTED;
> +
> + /* The list of supported tasks we give here must include not only the bands
> + * allowed in the current AcT, but the whole list of bands allowed in all
> + * AcTs. This is because the list of supported bands is loaded only once
> + * during modem initialization. Not ideal, but the current API is like that.
> + *
> + * So, we give a predefined list of supported bands and we filter them in the
> + * same way we filter the allowed AcTs.
> + */
> + bands = mm_ublox_get_supported_bands (mm_iface_modem_get_model (MM_IFACE_MODEM (self)), &error);
> + goto out;
> + }
> +
> + /* Flag as supported */
> + self->priv->uact = FEATURE_SUPPORTED;
> +
> + /* Parse UACT=? test response */
> + if (!mm_ublox_parse_uact_test (response, &bands_2g, &bands_3g, &bands_4g, &error))
> + goto out;
> +
> + /* Build a combined array */
> + bands = g_array_new (FALSE, FALSE, sizeof (MMModemBand));
> + if (bands_2g) {
> + bands = g_array_append_vals (bands, bands_2g->data, bands_2g->len);
> + g_array_unref (bands_2g);
> + }
> + if (bands_3g) {
> + bands = g_array_append_vals (bands, bands_3g->data, bands_3g->len);
> + g_array_unref (bands_3g);
> + }
> + if (bands_4g) {
> + bands = g_array_append_vals (bands, bands_4g->data, bands_4g->len);
> + g_array_unref (bands_4g);
> + }
> + g_assert (bands->len > 0);
> +
> +out:
> + if (!bands) {
> + g_assert (error);
> + g_task_return_error (task, error);
> + } else
> + g_task_return_pointer (task, bands, (GDestroyNotify) g_array_unref);
> + g_object_unref (task);
> +}
> +
> static void
> load_supported_bands (MMIfaceModem *self,
> GAsyncReadyCallback callback,
> gpointer user_data)
> {
> - GTask *task;
> - GError *error = NULL;
> - GArray *bands;
> + GTask *task;
>
> task = g_task_new (self, NULL, callback, user_data);
>
> - /* The list of supported tasks we give here must include not only the bands
> - * allowed in the current AcT, but the whole list of bands allowed in all
> - * AcTs. This is because the list of supported bands is loaded only once
> - * during modem initialization. Not ideal, but the current API is like that.
> - *
> - * So, we give a predefined list of supported bands and we filter them in the
> - * same way we filter the allowed AcTs.
> - */
> - bands = mm_ublox_get_supported_bands (mm_iface_modem_get_model (self), &error);
> - if (!bands)
> - g_task_return_error (task, error);
> - else
> - g_task_return_pointer (task, bands, (GDestroyNotify) g_array_unref);
> - g_object_unref (task);
> + /* See if AT+UACT is supported to query bands */
> + mm_base_modem_at_command (
> + MM_BASE_MODEM (self),
> + "+UACT=?",
> + 3,
> + TRUE, /* allow cached */
> + (GAsyncReadyCallback) uact_test_ready,
> + task);
> }
>
> /*****************************************************************************/
> @@ -963,6 +1026,7 @@ mm_broadband_modem_ublox_init (MMBroadbandModemUblox *self)
> self->priv->profile = MM_UBLOX_USB_PROFILE_UNKNOWN;
> self->priv->mode = MM_UBLOX_NETWORKING_MODE_UNKNOWN;
> self->priv->any_allowed = MM_MODEM_MODE_NONE;
> + self->priv->uact = FEATURE_SUPPORT_UNKNOWN;
> }
>
> static void
> --
> 2.14.1
>
--
Aleksander
https://aleksander.es
More information about the ModemManager-devel
mailing list