diff options
author | Aleksander Morgado <aleksandermj@chromium.org> | 2022-08-23 12:50:05 +0000 |
---|---|---|
committer | Aleksander Morgado <aleksandermj@chromium.org> | 2022-09-07 20:21:42 +0000 |
commit | b2a976bd47009a3c417949b3de245aeae616e4bc (patch) | |
tree | 4a942bf1384448b01400ad5c5700fcb5cacb9e05 /src/mbimcli | |
parent | 19a14b86597f995c32ddfd54c27ad4da4f8385bc (diff) | |
download | libmbim-b2a976bd47009a3c417949b3de245aeae616e4bc.tar.gz |
ms-uicc-low-level-access: add support for 'Application List' operation
$ sudo mbimcli -d /dev/wwan0mbim0 --ms-query-uicc-application-list -p
[/dev/wwan0mbim0] UICC applications: (1)
Application 0: (active)
Application type: usim
Application ID: A0:00:00:00:87:10:02:FF:34:FF:07:89:31:2E:30:FF
Application name: Movistar
PIN key reference count: 2
PIN key references: 01:81
Diffstat (limited to 'src/mbimcli')
-rw-r--r-- | src/mbimcli/mbimcli-ms-uicc-low-level-access.c | 178 | ||||
-rw-r--r-- | src/mbimcli/mbimcli.c | 10 | ||||
-rw-r--r-- | src/mbimcli/mbimcli.h | 4 | ||||
-rw-r--r-- | src/mbimcli/meson.build | 1 |
4 files changed, 192 insertions, 1 deletions
diff --git a/src/mbimcli/mbimcli-ms-uicc-low-level-access.c b/src/mbimcli/mbimcli-ms-uicc-low-level-access.c new file mode 100644 index 0000000..443bc62 --- /dev/null +++ b/src/mbimcli/mbimcli-ms-uicc-low-level-access.c @@ -0,0 +1,178 @@ +/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ +/* SPDX-License-Identifier: GPL-2.0-or-later */ +/* + * mbimcli -- Command line interface to control MBIM devices + * + * Copyright (C) 2022 Google, Inc. + */ + +#include "config.h" + +#include <stdio.h> +#include <stdlib.h> +#include <locale.h> +#include <string.h> +#include <errno.h> + +#include <glib.h> +#include <gio/gio.h> + +#include <libmbim-glib.h> + +#include "mbim-common.h" +#include "mbimcli.h" +#include "mbimcli-helpers.h" + +/* Context */ +typedef struct { + MbimDevice *device; + GCancellable *cancellable; +} Context; +static Context *ctx; + +/* Options */ +static gboolean query_uicc_application_list_flag; + +static GOptionEntry entries[] = { + { "ms-query-uicc-application-list", 0, 0, G_OPTION_ARG_NONE, &query_uicc_application_list_flag, + "Query UICC application list", + NULL + }, + { NULL } +}; + +GOptionGroup * +mbimcli_ms_uicc_low_level_access_get_option_group (void) +{ + GOptionGroup *group; + + group = g_option_group_new ("ms-uicc-low-level-access", + "Microsoft UICC Low Level Access Service options:", + "Show Microsoft UICC Low Level Access Service options", + NULL, + NULL); + g_option_group_add_entries (group, entries); + + return group; +} + +gboolean +mbimcli_ms_uicc_low_level_access_options_enabled (void) +{ + static guint n_actions = 0; + static gboolean checked = FALSE; + + if (checked) + return !!n_actions; + + n_actions = query_uicc_application_list_flag; + + if (n_actions > 1) { + g_printerr ("error: too many Microsoft UICC Low Level Access Service actions requested\n"); + exit (EXIT_FAILURE); + } + + checked = TRUE; + return !!n_actions; +} + +static void +context_free (Context *context) +{ + if (!context) + return; + + if (context->cancellable) + g_object_unref (context->cancellable); + if (context->device) + g_object_unref (context->device); + g_slice_free (Context, context); +} + +static void +shutdown (gboolean operation_status) +{ + /* Cleanup context and finish async operation */ + context_free (ctx); + mbimcli_async_operation_done (operation_status); +} + +static void +application_list_query_ready (MbimDevice *device, + GAsyncResult *res) +{ + g_autoptr(MbimMessage) response = NULL; + g_autoptr(GError) error = NULL; + guint32 application_count; + guint32 active_application_index; + g_autoptr(MbimUiccApplicationArray) applications = NULL; + guint32 i; + + 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_ms_uicc_low_level_access_application_list_response_parse ( + response, + NULL, /* version */ + &application_count, + &active_application_index, + NULL, /* application_list_size_bytes */ + &applications, + &error)) { + g_printerr ("error: couldn't parse response message: %s\n", error->message); + shutdown (FALSE); + return; + } + + g_print ("[%s] UICC applications: (%u)\n", + mbim_device_get_path_display (device), + application_count); + + for (i = 0; i < application_count; i++) { + g_autofree gchar *application_id_str = NULL; + g_autofree gchar *pin_key_references_str = NULL; + + application_id_str = mbim_common_str_hex (applications[i]->application_id, applications[i]->application_id_size, ':'); + pin_key_references_str = mbim_common_str_hex (applications[i]->pin_key_references, applications[i]->pin_key_references_size, ':'); + + g_print ("Application %u:%s\n", i, (i == active_application_index) ? " (active)" : ""); + g_print ("\tApplication type: %s\n", mbim_uicc_application_type_get_string (applications[i]->application_type)); + g_print ("\tApplication ID: %s\n", application_id_str); + g_print ("\tApplication name: %s\n", applications[i]->application_name); + g_print ("\tPIN key reference count: %u\n", applications[i]->pin_key_reference_count); + g_print ("\tPIN key references: %s\n", pin_key_references_str); + } + + shutdown (TRUE); +} + +void +mbimcli_ms_uicc_low_level_access_run (MbimDevice *device, + GCancellable *cancellable) +{ + g_autoptr(MbimMessage) request = NULL; + + /* Initialize context */ + ctx = g_slice_new (Context); + ctx->device = g_object_ref (device); + ctx->cancellable = cancellable ? g_object_ref (cancellable) : NULL; + + /* Request to query UICC application list? */ + if (query_uicc_application_list_flag) { + g_debug ("Asynchronously querying UICC application list..."); + request = mbim_message_ms_uicc_low_level_access_application_list_query_new (NULL); + mbim_device_command (ctx->device, + request, + 10, + ctx->cancellable, + (GAsyncReadyCallback)application_list_query_ready, + NULL); + return; + } + + g_warn_if_reached (); +} diff --git a/src/mbimcli/mbimcli.c b/src/mbimcli/mbimcli.c index 65cf268..3c12ac6 100644 --- a/src/mbimcli/mbimcli.c +++ b/src/mbimcli/mbimcli.c @@ -308,6 +308,9 @@ device_open_ready (MbimDevice *dev, case MBIM_SERVICE_MS_VOICE_EXTENSIONS: mbimcli_ms_voice_extensions_run (dev, cancellable); return; + case MBIM_SERVICE_MS_UICC_LOW_LEVEL_ACCESS: + mbimcli_ms_uicc_low_level_access_run (dev, cancellable); + return; case MBIM_SERVICE_SMS: case MBIM_SERVICE_USSD: case MBIM_SERVICE_STK: @@ -315,7 +318,6 @@ device_open_ready (MbimDevice *dev, case MBIM_SERVICE_PROXY_CONTROL: case MBIM_SERVICE_QMI: case MBIM_SERVICE_QDU: - case MBIM_SERVICE_MS_UICC_LOW_LEVEL_ACCESS: /* unsupported actions in the CLI */ case MBIM_SERVICE_INVALID: default: @@ -440,6 +442,11 @@ parse_actions (void) actions_enabled++; } + if (mbimcli_ms_uicc_low_level_access_options_enabled ()) { + service = MBIM_SERVICE_MS_UICC_LOW_LEVEL_ACCESS; + actions_enabled++; + } + /* Noop */ if (noop_flag) actions_enabled++; @@ -487,6 +494,7 @@ int main (int argc, char **argv) g_option_context_add_group (context, mbimcli_link_management_get_option_group ()); g_option_context_add_group (context, mbimcli_intel_thermal_rf_get_option_group ()); g_option_context_add_group (context, mbimcli_ms_voice_extensions_get_option_group ()); + g_option_context_add_group (context, mbimcli_ms_uicc_low_level_access_get_option_group ()); g_option_context_add_main_entries (context, main_entries, NULL); if (!g_option_context_parse (context, &argc, &argv, &error)) { g_printerr ("error: %s\n", error->message); diff --git a/src/mbimcli/mbimcli.h b/src/mbimcli/mbimcli.h index 255e3f8..e7188e3 100644 --- a/src/mbimcli/mbimcli.h +++ b/src/mbimcli/mbimcli.h @@ -29,6 +29,7 @@ GOptionGroup *mbimcli_ms_basic_connect_extensions_get_option_group (void); GOptionGroup *mbimcli_quectel_get_option_group (void); GOptionGroup *mbimcli_intel_thermal_rf_get_option_group (void); GOptionGroup *mbimcli_ms_voice_extensions_get_option_group (void); +GOptionGroup *mbimcli_ms_uicc_low_level_access_get_option_group (void); gboolean mbimcli_basic_connect_options_enabled (void); gboolean mbimcli_phonebook_options_enabled (void); @@ -42,6 +43,7 @@ gboolean mbimcli_ms_basic_connect_extensions_options_enabled (void); gboolean mbimcli_quectel_options_enabled (void); gboolean mbimcli_intel_thermal_rf_options_enabled (void); gboolean mbimcli_ms_voice_extensions_options_enabled (void); +gboolean mbimcli_ms_uicc_low_level_access_options_enabled (void); void mbimcli_basic_connect_run (MbimDevice *device, GCancellable *cancellable); @@ -67,6 +69,8 @@ void mbimcli_intel_thermal_rf_run (MbimDevice *device, GCancellable *cancellable); void mbimcli_ms_voice_extensions_run (MbimDevice *device, GCancellable *cancellable); +void mbimcli_ms_uicc_low_level_access_run (MbimDevice *device, + GCancellable *cancellable); /* link management */ diff --git a/src/mbimcli/meson.build b/src/mbimcli/meson.build index 79c52da..2f50b6d 100644 --- a/src/mbimcli/meson.build +++ b/src/mbimcli/meson.build @@ -12,6 +12,7 @@ mbimcli_sources = files( 'mbimcli-ms-firmware-id.c', 'mbimcli-ms-host-shutdown.c', 'mbimcli-ms-sar.c', + 'mbimcli-ms-uicc-low-level-access.c', 'mbimcli-ms-voice-extensions.c', 'mbimcli-phonebook.c', 'mbimcli-quectel.c', |