summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2021-10-21 17:44:08 +0200
committerAleksander Morgado <aleksander@aleksander.es>2021-11-02 09:50:17 +0000
commitf9343692e30e9fff7b85eaedb23796ccfeb9a5f0 (patch)
tree2b78f515d59972fab05ca577d6d88d7d14778f9e
parentc3f61547d21c76bf4d198e5de517d83f2ba71781 (diff)
broadband-modem: implement support for 'SetPacketServiceState()'
-rw-r--r--src/mm-broadband-modem.c30
-rw-r--r--src/mm-modem-helpers.c23
-rw-r--r--src/mm-modem-helpers.h3
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 */