From f9343692e30e9fff7b85eaedb23796ccfeb9a5f0 Mon Sep 17 00:00:00 2001 From: Aleksander Morgado Date: Thu, 21 Oct 2021 17:44:08 +0200 Subject: broadband-modem: implement support for 'SetPacketServiceState()' --- src/mm-broadband-modem.c | 30 ++++++++++++++++++++++++++++++ src/mm-modem-helpers.c | 23 +++++++++++++++++++++++ src/mm-modem-helpers.h | 3 +++ 3 files changed, 56 insertions(+) diff --git a/src/mm-broadband-modem.c b/src/mm-broadband-modem.c index 9bed3d64..6b4e7b2e 100644 --- a/src/mm-broadband-modem.c +++ b/src/mm-broadband-modem.c @@ -4616,6 +4616,34 @@ modem_3gpp_set_eps_ue_mode_operation (MMIfaceModem3gpp *self, g_free (cmd); } +/*****************************************************************************/ +/* Set packet service state (3GPP interface) */ + +static gboolean +modem_3gpp_set_packet_service_state_finish (MMIfaceModem3gpp *self, + GAsyncResult *res, + GError **error) +{ + return !!mm_base_modem_at_command_finish (MM_BASE_MODEM (self), res, error); +} + +static void +modem_3gpp_set_packet_service_state (MMIfaceModem3gpp *self, + MMModem3gppPacketServiceState state, + GAsyncReadyCallback callback, + gpointer user_data) +{ + g_autofree gchar *cmd = NULL; + + cmd = mm_3gpp_build_cgatt_set_request (state); + mm_base_modem_at_command (MM_BASE_MODEM (self), + cmd, + 10, + FALSE, + callback, + user_data); +} + /*****************************************************************************/ /* Unsolicited registration messages handling (3GPP interface) */ @@ -13427,6 +13455,8 @@ iface_modem_3gpp_init (MMIfaceModem3gpp *iface) iface->set_eps_ue_mode_operation = modem_3gpp_set_eps_ue_mode_operation; iface->set_eps_ue_mode_operation_finish = modem_3gpp_set_eps_ue_mode_operation_finish; iface->create_initial_eps_bearer = modem_3gpp_create_initial_eps_bearer; + iface->set_packet_service_state = modem_3gpp_set_packet_service_state; + iface->set_packet_service_state_finish = modem_3gpp_set_packet_service_state_finish; } static void diff --git a/src/mm-modem-helpers.c b/src/mm-modem-helpers.c index 7c92305a..6f645dbb 100644 --- a/src/mm-modem-helpers.c +++ b/src/mm-modem-helpers.c @@ -2936,6 +2936,29 @@ out: return TRUE; } +/*************************************************************************/ +/* CGATT helpers */ + +gchar * +mm_3gpp_build_cgatt_set_request (MMModem3gppPacketServiceState state) +{ + guint cgatt_action; + + switch (state) { + case MM_MODEM_3GPP_PACKET_SERVICE_STATE_ATTACHED: + cgatt_action = 1; + break; + case MM_MODEM_3GPP_PACKET_SERVICE_STATE_DETACHED: + cgatt_action = 0; + break; + case MM_MODEM_3GPP_PACKET_SERVICE_STATE_UNKNOWN: + default: + return NULL; + } + + return g_strdup_printf ("+CGATT=%u", cgatt_action); +} + /*************************************************************************/ static MMSmsStorage diff --git a/src/mm-modem-helpers.h b/src/mm-modem-helpers.h index 98bcea37..ed5364ef 100644 --- a/src/mm-modem-helpers.h +++ b/src/mm-modem-helpers.h @@ -408,6 +408,9 @@ gboolean mm_3gpp_parse_ccwa_service_query_response (const gchar *response, gboolean *status, GError **error); +/* CGATT helpers */ +gchar *mm_3gpp_build_cgatt_set_request (MMModem3gppPacketServiceState state); + /* Additional 3GPP-specific helpers */ -- cgit v1.2.3