1 #include "qmi-message.h"
10 static const char *get_pin_status(int status
)
12 static const char *pin_status
[] = {
13 [QMI_DMS_UIM_PIN_STATUS_NOT_INITIALIZED
] = "not_initialized",
14 [QMI_DMS_UIM_PIN_STATUS_ENABLED_NOT_VERIFIED
] = "not_verified",
15 [QMI_DMS_UIM_PIN_STATUS_ENABLED_VERIFIED
] = "verified",
16 [QMI_DMS_UIM_PIN_STATUS_DISABLED
] = "disabled",
17 [QMI_DMS_UIM_PIN_STATUS_BLOCKED
] = "blocked",
18 [QMI_DMS_UIM_PIN_STATUS_PERMANENTLY_BLOCKED
] = "permanently_blocked",
19 [QMI_DMS_UIM_PIN_STATUS_UNBLOCKED
] = "unblocked",
20 [QMI_DMS_UIM_PIN_STATUS_CHANGED
] = "changed",
22 const char *res
= "Unknown";
24 if (status
< ARRAY_SIZE(pin_status
) && pin_status
[status
])
25 res
= pin_status
[status
];
30 static void cmd_dms_get_pin_status_cb(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
)
32 struct qmi_dms_uim_get_pin_status_response res
;
35 qmi_parse_dms_uim_get_pin_status_response(msg
, &res
);
36 c
= blobmsg_open_table(&status
, NULL
);
37 if (res
.set
.pin1_status
) {
38 blobmsg_add_string(&status
, "pin1_status", get_pin_status(res
.data
.pin1_status
.current_status
));
39 blobmsg_add_u32(&status
, "pin1_verify_tries", (int32_t) res
.data
.pin1_status
.verify_retries_left
);
40 blobmsg_add_u32(&status
, "pin1_unblock_tries", (int32_t) res
.data
.pin1_status
.unblock_retries_left
);
42 if (res
.set
.pin2_status
) {
43 blobmsg_add_string(&status
, "pin2_status", get_pin_status(res
.data
.pin2_status
.current_status
));
44 blobmsg_add_u32(&status
, "pin2_verify_tries", (int32_t) res
.data
.pin2_status
.verify_retries_left
);
45 blobmsg_add_u32(&status
, "pin2_unblock_tries", (int32_t) res
.data
.pin2_status
.unblock_retries_left
);
47 blobmsg_close_table(&status
, c
);
50 static enum qmi_cmd_result
51 cmd_dms_get_pin_status_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
53 qmi_set_dms_uim_get_pin_status_request(msg
);
54 return QMI_CMD_REQUEST
;
57 #define cmd_dms_verify_pin1_cb no_cb
58 static enum qmi_cmd_result
59 cmd_dms_verify_pin1_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
61 struct qmi_dms_uim_verify_pin_request data
= {
62 QMI_INIT_SEQUENCE(info
,
63 .pin_id
= QMI_DMS_UIM_PIN_ID_PIN
,
67 qmi_set_dms_uim_verify_pin_request(msg
, &data
);
68 return QMI_CMD_REQUEST
;
71 #define cmd_dms_verify_pin2_cb no_cb
72 static enum qmi_cmd_result
73 cmd_dms_verify_pin2_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
75 struct qmi_dms_uim_verify_pin_request data
= {
76 QMI_INIT_SEQUENCE(info
,
77 .pin_id
= QMI_DMS_UIM_PIN_ID_PIN2
,
81 qmi_set_dms_uim_verify_pin_request(msg
, &data
);
82 return QMI_CMD_REQUEST
;
85 #define cmd_dms_set_pin_cb no_cb
86 static enum qmi_cmd_result
87 cmd_dms_set_pin_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
89 dms_req_data
.pin
= arg
;
93 static enum qmi_cmd_result
94 cmd_dms_set_pin_protection_prepare(struct qmi_msg
*msg
, char *arg
)
96 if (!dms_req_data
.pin
) {
97 uqmi_add_error("Missing argument");
102 if (strcasecmp(arg
, "disabled") == 0)
104 else if (strcasecmp(arg
, "enabled") == 0)
107 uqmi_add_error("Invalid value (valid: disabled, enabled)");
111 struct qmi_dms_uim_set_pin_protection_request dms_pin_protection_req
= {
112 QMI_INIT_SEQUENCE(info
,
113 .pin_id
= dms_req_data
.pin_id
115 QMI_INIT_PTR(info
.pin
, dms_req_data
.pin
),
116 QMI_INIT_PTR(info
.protection_enabled
, is_enabled
)
119 qmi_set_dms_uim_set_pin_protection_request(msg
, &dms_pin_protection_req
);
120 return QMI_CMD_REQUEST
;
123 #define cmd_dms_set_pin1_protection_cb no_cb
124 static enum qmi_cmd_result
125 cmd_dms_set_pin1_protection_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
127 dms_req_data
.pin_id
= QMI_DMS_UIM_PIN_ID_PIN
;
128 return cmd_dms_set_pin_protection_prepare(msg
, arg
);
131 #define cmd_dms_set_pin2_protection_cb no_cb
132 static enum qmi_cmd_result
133 cmd_dms_set_pin2_protection_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
135 dms_req_data
.pin_id
= QMI_DMS_UIM_PIN_ID_PIN2
;
136 return cmd_dms_set_pin_protection_prepare(msg
, arg
);
139 #define cmd_dms_set_new_pin_cb no_cb
140 static enum qmi_cmd_result
141 cmd_dms_set_new_pin_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
143 dms_req_data
.new_pin
= arg
;
147 #define cmd_dms_set_puk_cb no_cb
148 static enum qmi_cmd_result
149 cmd_dms_set_puk_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
151 dms_req_data
.puk
= arg
;
155 #define cmd_dms_unblock_pin1_cb no_cb
156 static enum qmi_cmd_result
157 cmd_dms_unblock_pin1_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
159 if (!dms_req_data
.puk
|| !dms_req_data
.new_pin
) {
160 uqmi_add_error("Missing argument");
164 struct qmi_dms_uim_unblock_pin_request dms_unlock_pin_req
= {
165 QMI_INIT_SEQUENCE(info
,
166 .pin_id
= QMI_DMS_UIM_PIN_ID_PIN
168 QMI_INIT_PTR(info
.puk
, dms_req_data
.puk
),
169 QMI_INIT_PTR(info
.new_pin
, dms_req_data
.new_pin
)
172 qmi_set_dms_uim_unblock_pin_request(msg
, &dms_unlock_pin_req
);
173 return QMI_CMD_REQUEST
;
176 #define cmd_dms_unblock_pin2_cb no_cb
177 static enum qmi_cmd_result
178 cmd_dms_unblock_pin2_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
180 if (!dms_req_data
.puk
|| !dms_req_data
.new_pin
) {
181 uqmi_add_error("Missing argument");
185 struct qmi_dms_uim_unblock_pin_request dms_unlock_pin_req
= {
186 QMI_INIT_SEQUENCE(info
,
187 .pin_id
= QMI_DMS_UIM_PIN_ID_PIN2
189 QMI_INIT_PTR(info
.puk
, dms_req_data
.puk
),
190 QMI_INIT_PTR(info
.new_pin
, dms_req_data
.new_pin
)
193 qmi_set_dms_uim_unblock_pin_request(msg
, &dms_unlock_pin_req
);
194 return QMI_CMD_REQUEST
;
197 static void cmd_dms_get_iccid_cb(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
)
199 struct qmi_dms_uim_get_iccid_response res
;
201 qmi_parse_dms_uim_get_iccid_response(msg
, &res
);
203 blobmsg_add_string(&status
, NULL
, res
.data
.iccid
);
206 static enum qmi_cmd_result
207 cmd_dms_get_iccid_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
209 qmi_set_dms_uim_get_iccid_request(msg
);
210 return QMI_CMD_REQUEST
;
213 static void cmd_dms_get_imsi_cb(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
)
215 struct qmi_dms_uim_get_imsi_response res
;
217 qmi_parse_dms_uim_get_imsi_response(msg
, &res
);
219 blobmsg_add_string(&status
, NULL
, res
.data
.imsi
);
222 static enum qmi_cmd_result
223 cmd_dms_get_imsi_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
225 qmi_set_dms_uim_get_imsi_request(msg
);
226 return QMI_CMD_REQUEST
;
229 static void cmd_dms_get_msisdn_cb(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
)
231 struct qmi_dms_get_msisdn_response res
;
233 qmi_parse_dms_get_msisdn_response(msg
, &res
);
235 blobmsg_add_string(&status
, NULL
, res
.data
.msisdn
);
238 static enum qmi_cmd_result
239 cmd_dms_get_msisdn_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
241 qmi_set_dms_get_msisdn_request(msg
);
242 return QMI_CMD_REQUEST
;
245 #define cmd_dms_reset_cb no_cb
246 static enum qmi_cmd_result
247 cmd_dms_reset_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
249 qmi_set_dms_reset_request(msg
);
250 return QMI_CMD_REQUEST
;
253 #define cmd_dms_set_operating_mode_cb no_cb
254 static enum qmi_cmd_result
255 cmd_dms_set_operating_mode_prepare(struct qmi_dev
*qmi
, struct qmi_request
*req
, struct qmi_msg
*msg
, char *arg
)
257 static const char *modes
[] = {
258 [QMI_DMS_OPERATING_MODE_ONLINE
] = "online",
259 [QMI_DMS_OPERATING_MODE_LOW_POWER
] = "low_power",
260 [QMI_DMS_OPERATING_MODE_FACTORY_TEST
] = "factory_test",
261 [QMI_DMS_OPERATING_MODE_OFFLINE
] = "offline",
262 [QMI_DMS_OPERATING_MODE_RESET
] = "reset",
263 [QMI_DMS_OPERATING_MODE_SHUTTING_DOWN
] = "shutting_down",
264 [QMI_DMS_OPERATING_MODE_PERSISTENT_LOW_POWER
] = "persistent_low_power",
265 [QMI_DMS_OPERATING_MODE_MODE_ONLY_LOW_POWER
] = "mode_only_low_power",
267 static struct qmi_dms_set_operating_mode_request sreq
= {
268 QMI_INIT(mode
, QMI_DMS_OPERATING_MODE_ONLINE
),
272 for (i
= 0; i
< ARRAY_SIZE(modes
); i
++) {
276 if (strcmp(arg
, modes
[i
]) != 0)
280 qmi_set_dms_set_operating_mode_request(msg
, &sreq
);
281 return QMI_CMD_REQUEST
;
284 return uqmi_add_error("Invalid argument");