aboutsummaryrefslogtreecommitdiff
path: root/cli/mmcli-modem-3gpp.c
diff options
context:
space:
mode:
Diffstat (limited to 'cli/mmcli-modem-3gpp.c')
-rw-r--r--cli/mmcli-modem-3gpp.c76
1 files changed, 76 insertions, 0 deletions
diff --git a/cli/mmcli-modem-3gpp.c b/cli/mmcli-modem-3gpp.c
index 18ff955c..234fdf83 100644
--- a/cli/mmcli-modem-3gpp.c
+++ b/cli/mmcli-modem-3gpp.c
@@ -51,6 +51,7 @@ static gboolean scan_flag;
static gboolean register_home_flag;
static gchar *register_in_operator_str;
static gchar *set_eps_ue_mode_operation_str;
+static gchar *set_initial_eps_bearer_settings_str;
static gboolean ussd_status_flag;
static gchar *ussd_initiate_str;
static gchar *ussd_respond_str;
@@ -73,6 +74,10 @@ static GOptionEntry entries[] = {
"Set the UE mode of operation for EPS",
"[ps-1|ps-2|csps-1|csps-2]"
},
+ { "3gpp-set-initial-eps-bearer-settings", 0, 0, G_OPTION_ARG_STRING, &set_initial_eps_bearer_settings_str,
+ "Set the initial EPS bearer settings",
+ "[\"key=value,...\"]"
+ },
{ "3gpp-ussd-status", 0, 0, G_OPTION_ARG_NONE, &ussd_status_flag,
"Show status of any ongoing USSD session",
NULL
@@ -120,6 +125,7 @@ mmcli_modem_3gpp_options_enabled (void)
register_home_flag +
!!register_in_operator_str +
!!set_eps_ue_mode_operation_str +
+ !!set_initial_eps_bearer_settings_str +
ussd_status_flag +
!!ussd_initiate_str +
!!ussd_respond_str +
@@ -262,6 +268,32 @@ register_ready (MMModem3gpp *modem_3gpp,
}
static void
+set_initial_eps_bearer_settings_process_reply (gboolean result,
+ const GError *error)
+{
+ if (!result) {
+ g_printerr ("error: couldn't set initial EPS bearer properties: '%s'\n",
+ error ? error->message : "unknown error");
+ exit (EXIT_FAILURE);
+ }
+
+ g_print ("Successfully set initial EPS bearer properties\n");
+}
+
+static void
+set_initial_eps_bearer_settings_ready (MMModem3gpp *modem,
+ GAsyncResult *res)
+{
+ gboolean result;
+ GError *error = NULL;
+
+ result = mm_modem_3gpp_set_initial_eps_bearer_settings_finish (modem, res, &error);
+ set_initial_eps_bearer_settings_process_reply (result, error);
+
+ mmcli_async_operation_done ();
+}
+
+static void
set_eps_ue_mode_operation_process_reply (gboolean result,
const GError *error)
{
@@ -452,6 +484,28 @@ get_modem_ready (GObject *source,
return;
}
+ /* Request to set initial EPS bearer properties? */
+ if (set_initial_eps_bearer_settings_str) {
+ GError *error = NULL;
+ MMBearerProperties *config;
+
+ config = mm_bearer_properties_new_from_string (set_initial_eps_bearer_settings_str, &error);
+ if (!config) {
+ g_printerr ("Error parsing properties string: '%s'\n", error->message);
+ exit (EXIT_FAILURE);
+ }
+
+ g_debug ("Asynchronously setting initial EPS bearer properties...");
+ mm_modem_3gpp_set_initial_eps_bearer_settings (ctx->modem_3gpp,
+ config,
+ ctx->cancellable,
+ (GAsyncReadyCallback)set_initial_eps_bearer_settings_ready,
+ NULL);
+ g_object_unref (config);
+ return;
+
+ }
+
/* Request to initiate USSD session? */
if (ussd_initiate_str) {
ensure_modem_3gpp_ussd ();
@@ -568,6 +622,28 @@ mmcli_modem_3gpp_run_synchronous (GDBusConnection *connection)
return;
}
+ /* Request to set initial EPS bearer properties? */
+ if (set_initial_eps_bearer_settings_str) {
+ GError *error = NULL;
+ gboolean result;
+ MMBearerProperties *config;
+
+ config = mm_bearer_properties_new_from_string (set_initial_eps_bearer_settings_str, &error);
+ if (!config) {
+ g_printerr ("Error parsing properties string: '%s'\n", error->message);
+ exit (EXIT_FAILURE);
+ }
+
+ g_debug ("Synchronously setting initial EPS bearer properties...");
+ result = mm_modem_3gpp_set_initial_eps_bearer_settings_sync (ctx->modem_3gpp,
+ config,
+ NULL,
+ &error);
+ set_initial_eps_bearer_settings_process_reply (result, error);
+ g_object_unref (config);
+ return;
+ }
+
/* Request to show USSD status? */
if (ussd_status_flag) {
ensure_modem_3gpp_ussd ();