diff options
author | som <somashekhar.puttagangaiah@intel.com> | 2022-09-14 21:28:47 +0530 |
---|---|---|
committer | Aleksander Morgado <aleksander@aleksander.es> | 2022-09-16 12:01:38 +0000 |
commit | ecb98017b40252315dc95796acb2d3a8b481ea99 (patch) | |
tree | 42796b92bbbf8bcce6ada25040a01695833b0d7e | |
parent | d66f82bdf4eb71a5ea00bd56189dbdf0cb907a20 (diff) | |
download | libmbim-ecb98017b40252315dc95796acb2d3a8b481ea99.tar.gz |
mbimcli: Add Emergency mode state option in cli
This commit provides option to test emergency mode state
using mbimcli option.
Co-author: Bestha, Lakshminarayana
-rw-r--r-- | src/mbimcli/mbimcli-basic-connect.c | 84 | ||||
-rw-r--r-- | src/mbimcli/mbimcli-helpers.h | 1 |
2 files changed, 84 insertions, 1 deletions
diff --git a/src/mbimcli/mbimcli-basic-connect.c b/src/mbimcli/mbimcli-basic-connect.c index 6744780..280a049 100644 --- a/src/mbimcli/mbimcli-basic-connect.c +++ b/src/mbimcli/mbimcli-basic-connect.c @@ -64,6 +64,8 @@ static gchar *set_provisioned_contexts_str; static gchar *set_signal_state_str; static gchar *set_network_idle_hint_str; static gboolean query_network_idle_hint_flag; +static gchar *set_emergency_mode_str; +static gboolean query_emergency_mode_flag; static gboolean query_connection_state_arg_parse (const char *option_name, const char *value, @@ -220,6 +222,14 @@ static GOptionEntry entries[] = { "Query network idle hint", NULL }, + { "set-emergency-mode", 0, 0, G_OPTION_ARG_STRING, &set_emergency_mode_str, + "Set emergency mode", + "[(on|off)]" + }, + { "query-emergency-mode", 0, 0, G_OPTION_ARG_NONE, &query_emergency_mode_flag, + "Query emergency mode", + NULL + }, { NULL } }; @@ -319,7 +329,9 @@ mbimcli_basic_connect_options_enabled (void) !!set_provisioned_contexts_str + !!set_signal_state_str + !!set_network_idle_hint_str + - query_network_idle_hint_flag); + query_network_idle_hint_flag + + !!set_emergency_mode_str + + query_emergency_mode_flag); if (n_actions > 1) { g_printerr ("error: too many Basic Connect actions requested\n"); @@ -2267,6 +2279,39 @@ network_idle_hint_ready (MbimDevice *device, shutdown (TRUE); } +static void +emergency_mode_ready (MbimDevice *device, + GAsyncResult *res) +{ + g_autoptr(MbimMessage) response = NULL; + g_autoptr(GError) error = NULL; + MbimEmergencyModeState emergency_state; + const gchar *emergency_state_str = NULL; + + response = mbim_device_command_finish (device, res, &error); + if (!response || !mbim_message_response_get_result (response, MBIM_MESSAGE_TYPE_COMMAND_DONE, &error)) { + g_printerr ("error: operation failed: %s\n", error->message); + shutdown (FALSE); + return; + } + + if (!mbim_message_emergency_mode_response_parse ( + response, + &emergency_state, + &error)) { + g_printerr ("error: couldn't parse response message: %s\n", error->message); + shutdown (FALSE); + return; + } + + emergency_state_str = mbim_emergency_mode_state_get_string (emergency_state); + g_print ("[%s] Emergency mode: '%s'\n", + mbim_device_get_path_display (device), + VALIDATE_UNKNOWN (emergency_state_str)); + + shutdown (TRUE); +} + void mbimcli_basic_connect_run (MbimDevice *device, GCancellable *cancellable) @@ -2952,5 +2997,42 @@ mbimcli_basic_connect_run (MbimDevice *device, return; } + /* Set emergency mode state */ + if (set_emergency_mode_str) { + MbimEmergencyModeState emergency_state; + + if (!mbimcli_read_emergency_mode_state_from_string (set_emergency_mode_str, &emergency_state)) { + shutdown (FALSE); + return; + } + + request = mbim_message_emergency_mode_set_new (emergency_state, &error); + if (!request) { + g_printerr ("error: couldn't create request: %s\n", error->message); + shutdown (FALSE); + return; + } + + mbim_device_command (ctx->device, + request, + 10, + ctx->cancellable, + (GAsyncReadyCallback)emergency_mode_ready, + NULL); + return; + } + + /* Query emergency mode state */ + if (query_emergency_mode_flag) { + request = mbim_message_emergency_mode_query_new (NULL); + mbim_device_command (ctx->device, + request, + 10, + ctx->cancellable, + (GAsyncReadyCallback)emergency_mode_ready, + NULL); + return; + } + g_warn_if_reached (); } diff --git a/src/mbimcli/mbimcli-helpers.h b/src/mbimcli/mbimcli-helpers.h index 2db5122..247624c 100644 --- a/src/mbimcli/mbimcli-helpers.h +++ b/src/mbimcli/mbimcli-helpers.h @@ -66,6 +66,7 @@ gboolean mbimcli_parse_sar_config_state_array (const gchar *str, MBIMCLI_ENUM_LIST_ITEM (MbimDefaultPduActivationHint, default_pdu_activation_hint, "default pdu activation hint") \ MBIMCLI_ENUM_LIST_ITEM (MbimAccessMediaType, access_media_type, "access media type") \ MBIMCLI_ENUM_LIST_ITEM (MbimNetworkIdleHintState, network_idle_hint_state, "network idle hint state") \ + MBIMCLI_ENUM_LIST_ITEM (MbimEmergencyModeState, emergency_mode_state, "emergency mode state") \ MBIMCLI_ENUM_LIST_ITEM (MbimIntelBootMode, intel_boot_mode, "intel boot mode") #define MBIMCLI_ENUM_LIST_ITEM(TYPE,TYPE_UNDERSCORE,DESCR) \ |