aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAleksander Morgado <aleksander@aleksander.es>2018-12-16 14:00:59 +0100
committerAleksander Morgado <aleksander@aleksander.es>2019-04-02 12:11:25 +0200
commit51a5b628ad5daadbeea3254100f5485785ba6833 (patch)
tree0bb0e7d66fe1fdbd8ed177cbc81ee292ec629f04
parent8c053f637af1c232a6bf591c0643c6ea7e090378 (diff)
broadband-modem-qmi: static array to define used QMI services
-rw-r--r--src/mm-broadband-modem-qmi.c29
1 files changed, 14 insertions, 15 deletions
diff --git a/src/mm-broadband-modem-qmi.c b/src/mm-broadband-modem-qmi.c
index ca274c43..41c07c23 100644
--- a/src/mm-broadband-modem-qmi.c
+++ b/src/mm-broadband-modem-qmi.c
@@ -8235,9 +8235,18 @@ enabling_started (MMBroadbandModem *self,
/*****************************************************************************/
/* First initialization step */
+static const QmiService qmi_services[] = {
+ QMI_SERVICE_DMS,
+ QMI_SERVICE_NAS,
+ QMI_SERVICE_WMS,
+ QMI_SERVICE_PDS,
+ QMI_SERVICE_OMA,
+ QMI_SERVICE_UIM,
+ QMI_SERVICE_LOC,
+};
+
typedef struct {
MMPortQmi *qmi;
- QmiService services[32];
guint service_index;
} InitializationStartedContext;
@@ -8355,7 +8364,7 @@ qmi_port_allocate_client_ready (MMPortQmi *qmi,
if (!mm_port_qmi_allocate_client_finish (qmi, res, &error)) {
mm_dbg ("Couldn't allocate client for service '%s': %s",
- qmi_service_get_string (ctx->services[ctx->service_index]),
+ qmi_service_get_string (qmi_services[ctx->service_index]),
error->message);
g_error_free (error);
}
@@ -8373,7 +8382,7 @@ allocate_next_client (GTask *task)
self = g_task_get_source_object (task);
ctx = g_task_get_task_data (task);
- if (ctx->services[ctx->service_index] == QMI_SERVICE_UNKNOWN) {
+ if (ctx->service_index == G_N_ELEMENTS (qmi_services)) {
/* Done we are, track device removal and launch parent's callback */
track_qmi_device_removed (self, ctx->qmi);
parent_initialization_started (task);
@@ -8382,7 +8391,7 @@ allocate_next_client (GTask *task)
/* Otherwise, allocate next client */
mm_port_qmi_allocate_client (ctx->qmi,
- ctx->services[ctx->service_index],
+ qmi_services[ctx->service_index],
MM_PORT_QMI_FLAG_DEFAULT,
NULL,
(GAsyncReadyCallback)qmi_port_allocate_client_ready,
@@ -8441,7 +8450,7 @@ initialization_started (MMBroadbandModem *self,
gpointer user_data)
{
InitializationStartedContext *ctx;
- GTask *task;
+ GTask *task;
ctx = g_new0 (InitializationStartedContext, 1);
ctx->qmi = mm_base_modem_get_port_qmi (MM_BASE_MODEM (self));
@@ -8467,16 +8476,6 @@ initialization_started (MMBroadbandModem *self,
return;
}
- /* Setup services to open */
- ctx->services[0] = QMI_SERVICE_DMS;
- ctx->services[1] = QMI_SERVICE_NAS;
- ctx->services[2] = QMI_SERVICE_WMS;
- ctx->services[3] = QMI_SERVICE_PDS;
- ctx->services[4] = QMI_SERVICE_OMA;
- ctx->services[5] = QMI_SERVICE_UIM;
- ctx->services[6] = QMI_SERVICE_LOC;
- ctx->services[7] = QMI_SERVICE_UNKNOWN;
-
/* Now open our QMI port */
mm_port_qmi_open (ctx->qmi,
TRUE,