diff options
author | Aleksander Morgado <aleksander@aleksander.es> | 2021-10-21 17:44:08 +0200 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2021-11-02 09:50:17 +0000 |
commit | f9343692e30e9fff7b85eaedb23796ccfeb9a5f0 (patch) | |
tree | 2b78f515d59972fab05ca577d6d88d7d14778f9e | |
parent | c3f61547d21c76bf4d198e5de517d83f2ba71781 (diff) |
broadband-modem: implement support for 'SetPacketServiceState()'
-rw-r--r-- | src/mm-broadband-modem.c | 30 | ||||
-rw-r--r-- | src/mm-modem-helpers.c | 23 | ||||
-rw-r--r-- | src/mm-modem-helpers.h | 3 |
3 files changed, 56 insertions, 0 deletions
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 @@ -4617,6 +4617,34 @@ modem_3gpp_set_eps_ue_mode_operation (MMIfaceModem3gpp *self, } /*****************************************************************************/ +/* 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) */ static gboolean @@ -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 @@ -2937,6 +2937,29 @@ out: } /*************************************************************************/ +/* 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 storage_from_str (const gchar *str) 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 */ |