[PATCH] uim: add --uim-get-sim-state
Arjun
arjunak234 at gmail.com
Sun May 23 22:51:23 PDT 2021
Hi,
I believe I've made the required changes. Can this be merged in now?
-
Arjun
On May 8, 2021 12:02:57 AM UTC, Arjun AK <arjunak234 at gmail.com> wrote:
>From: Arjun <arjunak234 at gmail.com>
>
>This command will show whether a SIM card has been inserted and whether
>a pin is required.
>
>Signed-off-by: Arjun <arjunak234 at gmail.com>
>---
> commands-uim.c | 26 ++++++++++++++++++++++++++
> commands-uim.h | 4 +++-
> 2 files changed, 29 insertions(+), 1 deletion(-)
>
>diff --git a/commands-uim.c b/commands-uim.c
>index 859da68..03166a2 100644
>--- a/commands-uim.c
>+++ b/commands-uim.c
>@@ -54,3 +54,29 @@ cmd_uim_verify_pin2_prepare(struct qmi_dev *qmi,
>struct qmi_request *req, struct
> qmi_set_uim_verify_pin_request(msg, &data);
> return QMI_CMD_REQUEST;
> }
>+
>+
>+static void cmd_uim_get_sim_state_cb(struct qmi_dev *qmi, struct
>qmi_request *req, struct qmi_msg *msg)
>+{
>+ struct qmi_uim_get_card_status_response res;
>+ qmi_parse_uim_get_card_status_response(msg, &res);
>+
>+ void * const array = blobmsg_open_array(&status, "sim_cards");
>+ if (res.data.card_status.cards_n > 0){
>+ void * const table = blobmsg_open_table(&status, NULL);
>+
>+ for (int i = 0; i < res.data.card_status.cards_n;i++){
>+ blobmsg_add_u32(&status, "state",
>res.data.card_status.cards[i].card_state);
>+ blobmsg_add_u32(&status, "upin_state",
>res.data.card_status.cards[i].upin_state);
>+ }
>+ blobmsg_close_table(&status, table);
>+ }
>+ blobmsg_close_array(&status, array);
>+}
>+
>+static enum qmi_cmd_result
>+cmd_uim_get_sim_state_prepare(struct qmi_dev *qmi, struct qmi_request
>*req, struct qmi_msg *msg, char *arg)
>+{
>+ qmi_set_uim_get_card_status_request(msg);
>+ return QMI_CMD_REQUEST;
>+}
>diff --git a/commands-uim.h b/commands-uim.h
>index 86ebae4..02a49b1 100644
>--- a/commands-uim.h
>+++ b/commands-uim.h
>@@ -21,10 +21,12 @@
>
> #define __uqmi_uim_commands \
> __uqmi_command(uim_verify_pin1, uim-verify-pin1, required,
>QMI_SERVICE_UIM), \
>- __uqmi_command(uim_verify_pin2, uim-verify-pin2, required,
>QMI_SERVICE_UIM) \
>+ __uqmi_command(uim_verify_pin2, uim-verify-pin2, required,
>QMI_SERVICE_UIM), \
>+ __uqmi_command(uim_get_sim_state, uim-get-sim-state, no,
>QMI_SERVICE_UIM) \
>
>
> #define uim_helptext \
> " --uim-verify-pin1 <pin>: Verify PIN1 (new devices)\n" \
> " --uim-verify-pin2 <pin>: Verify PIN2 (new devices)\n" \
>+ " --uim-get-sim-state: Get current SIM state\n" \
>
More information about the openwrt-devel
mailing list