shared-qmi: reuse device factory reset logic in MBIM whenever possible
This commit is contained in:

committed by
Dan Williams

parent
9dc26cc44d
commit
6026c99f2e
@@ -4507,6 +4507,8 @@ iface_modem_init (MMIfaceModem *iface)
|
|||||||
#if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED
|
#if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED
|
||||||
iface->reset = mm_shared_qmi_reset;
|
iface->reset = mm_shared_qmi_reset;
|
||||||
iface->reset_finish = mm_shared_qmi_reset_finish;
|
iface->reset_finish = mm_shared_qmi_reset_finish;
|
||||||
|
iface->factory_reset = mm_shared_qmi_factory_reset;
|
||||||
|
iface->factory_reset_finish = mm_shared_qmi_factory_reset_finish;
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -3087,80 +3087,6 @@ create_sim (MMIfaceModem *self,
|
|||||||
user_data);
|
user_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*****************************************************************************/
|
|
||||||
/* Factory reset (Modem interface) */
|
|
||||||
|
|
||||||
static gboolean
|
|
||||||
modem_factory_reset_finish (MMIfaceModem *self,
|
|
||||||
GAsyncResult *res,
|
|
||||||
GError **error)
|
|
||||||
{
|
|
||||||
return g_task_propagate_boolean (G_TASK (res), error);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
dms_restore_factory_defaults_ready (QmiClientDms *client,
|
|
||||||
GAsyncResult *res,
|
|
||||||
GTask *task)
|
|
||||||
{
|
|
||||||
QmiMessageDmsRestoreFactoryDefaultsOutput *output = NULL;
|
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
output = qmi_client_dms_restore_factory_defaults_finish (client, res, &error);
|
|
||||||
if (!output) {
|
|
||||||
g_prefix_error (&error, "QMI operation failed: ");
|
|
||||||
g_task_return_error (task, error);
|
|
||||||
} else if (!qmi_message_dms_restore_factory_defaults_output_get_result (output, &error)) {
|
|
||||||
g_prefix_error (&error, "Couldn't restore factory defaults: ");
|
|
||||||
g_task_return_error (task, error);
|
|
||||||
} else
|
|
||||||
g_task_return_boolean (task, TRUE);
|
|
||||||
|
|
||||||
if (output)
|
|
||||||
qmi_message_dms_restore_factory_defaults_output_unref (output);
|
|
||||||
|
|
||||||
g_object_unref (task);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
modem_factory_reset (MMIfaceModem *self,
|
|
||||||
const gchar *code,
|
|
||||||
GAsyncReadyCallback callback,
|
|
||||||
gpointer user_data)
|
|
||||||
{
|
|
||||||
QmiMessageDmsRestoreFactoryDefaultsInput *input;
|
|
||||||
GTask *task;
|
|
||||||
QmiClient *client = NULL;
|
|
||||||
GError *error = NULL;
|
|
||||||
|
|
||||||
if (!mm_shared_qmi_ensure_client (MM_SHARED_QMI (self),
|
|
||||||
QMI_SERVICE_DMS, &client,
|
|
||||||
callback, user_data))
|
|
||||||
return;
|
|
||||||
|
|
||||||
task = g_task_new (self, NULL, callback, user_data);
|
|
||||||
|
|
||||||
input = qmi_message_dms_restore_factory_defaults_input_new ();
|
|
||||||
if (!qmi_message_dms_restore_factory_defaults_input_set_service_programming_code (
|
|
||||||
input,
|
|
||||||
code,
|
|
||||||
&error)) {
|
|
||||||
qmi_message_dms_restore_factory_defaults_input_unref (input);
|
|
||||||
g_task_return_error (task, error);
|
|
||||||
g_object_unref (task);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
mm_dbg ("performing a factory reset...");
|
|
||||||
qmi_client_dms_restore_factory_defaults (QMI_CLIENT_DMS (client),
|
|
||||||
input,
|
|
||||||
10,
|
|
||||||
NULL,
|
|
||||||
(GAsyncReadyCallback)dms_restore_factory_defaults_ready,
|
|
||||||
task);
|
|
||||||
qmi_message_dms_restore_factory_defaults_input_unref (input);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
/* Load current modes (Modem interface) */
|
/* Load current modes (Modem interface) */
|
||||||
|
|
||||||
@@ -10321,8 +10247,8 @@ iface_modem_init (MMIfaceModem *iface)
|
|||||||
/* Other actions */
|
/* Other actions */
|
||||||
iface->reset = mm_shared_qmi_reset;
|
iface->reset = mm_shared_qmi_reset;
|
||||||
iface->reset_finish = mm_shared_qmi_reset_finish;
|
iface->reset_finish = mm_shared_qmi_reset_finish;
|
||||||
iface->factory_reset = modem_factory_reset;
|
iface->factory_reset = mm_shared_qmi_factory_reset;
|
||||||
iface->factory_reset_finish = modem_factory_reset_finish;
|
iface->factory_reset_finish = mm_shared_qmi_factory_reset_finish;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@@ -189,6 +189,79 @@ mm_shared_qmi_reset (MMIfaceModem *self,
|
|||||||
qmi_message_dms_set_operating_mode_input_unref (input);
|
qmi_message_dms_set_operating_mode_input_unref (input);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*****************************************************************************/
|
||||||
|
/* Factory reset (Modem interface) */
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
mm_shared_qmi_factory_reset_finish (MMIfaceModem *self,
|
||||||
|
GAsyncResult *res,
|
||||||
|
GError **error)
|
||||||
|
{
|
||||||
|
return g_task_propagate_boolean (G_TASK (res), error);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
dms_restore_factory_defaults_ready (QmiClientDms *client,
|
||||||
|
GAsyncResult *res,
|
||||||
|
GTask *task)
|
||||||
|
{
|
||||||
|
QmiMessageDmsRestoreFactoryDefaultsOutput *output = NULL;
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
output = qmi_client_dms_restore_factory_defaults_finish (client, res, &error);
|
||||||
|
if (!output) {
|
||||||
|
g_prefix_error (&error, "QMI operation failed: ");
|
||||||
|
g_task_return_error (task, error);
|
||||||
|
} else if (!qmi_message_dms_restore_factory_defaults_output_get_result (output, &error)) {
|
||||||
|
g_prefix_error (&error, "Couldn't restore factory defaults: ");
|
||||||
|
g_task_return_error (task, error);
|
||||||
|
} else
|
||||||
|
g_task_return_boolean (task, TRUE);
|
||||||
|
|
||||||
|
if (output)
|
||||||
|
qmi_message_dms_restore_factory_defaults_output_unref (output);
|
||||||
|
|
||||||
|
g_object_unref (task);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
mm_shared_qmi_factory_reset (MMIfaceModem *self,
|
||||||
|
const gchar *code,
|
||||||
|
GAsyncReadyCallback callback,
|
||||||
|
gpointer user_data)
|
||||||
|
{
|
||||||
|
QmiMessageDmsRestoreFactoryDefaultsInput *input;
|
||||||
|
GTask *task;
|
||||||
|
QmiClient *client = NULL;
|
||||||
|
GError *error = NULL;
|
||||||
|
|
||||||
|
if (!mm_shared_qmi_ensure_client (MM_SHARED_QMI (self),
|
||||||
|
QMI_SERVICE_DMS, &client,
|
||||||
|
callback, user_data))
|
||||||
|
return;
|
||||||
|
|
||||||
|
task = g_task_new (self, NULL, callback, user_data);
|
||||||
|
|
||||||
|
input = qmi_message_dms_restore_factory_defaults_input_new ();
|
||||||
|
if (!qmi_message_dms_restore_factory_defaults_input_set_service_programming_code (
|
||||||
|
input,
|
||||||
|
code,
|
||||||
|
&error)) {
|
||||||
|
qmi_message_dms_restore_factory_defaults_input_unref (input);
|
||||||
|
g_task_return_error (task, error);
|
||||||
|
g_object_unref (task);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mm_dbg ("performing a factory reset...");
|
||||||
|
qmi_client_dms_restore_factory_defaults (QMI_CLIENT_DMS (client),
|
||||||
|
input,
|
||||||
|
10,
|
||||||
|
NULL,
|
||||||
|
(GAsyncReadyCallback)dms_restore_factory_defaults_ready,
|
||||||
|
task);
|
||||||
|
}
|
||||||
|
|
||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
/* Location: Set SUPL server */
|
/* Location: Set SUPL server */
|
||||||
|
|
||||||
|
@@ -62,12 +62,19 @@ gboolean mm_shared_qmi_ensure_client (MMSharedQmi *self,
|
|||||||
|
|
||||||
/* Shared QMI device management support */
|
/* Shared QMI device management support */
|
||||||
|
|
||||||
void mm_shared_qmi_reset (MMIfaceModem *self,
|
void mm_shared_qmi_reset (MMIfaceModem *self,
|
||||||
GAsyncReadyCallback callback,
|
GAsyncReadyCallback callback,
|
||||||
gpointer user_data);
|
gpointer user_data);
|
||||||
gboolean mm_shared_qmi_reset_finish (MMIfaceModem *self,
|
gboolean mm_shared_qmi_reset_finish (MMIfaceModem *self,
|
||||||
GAsyncResult *res,
|
GAsyncResult *res,
|
||||||
GError **error);
|
GError **error);
|
||||||
|
void mm_shared_qmi_factory_reset (MMIfaceModem *self,
|
||||||
|
const gchar *code,
|
||||||
|
GAsyncReadyCallback callback,
|
||||||
|
gpointer user_data);
|
||||||
|
gboolean mm_shared_qmi_factory_reset_finish (MMIfaceModem *self,
|
||||||
|
GAsyncResult *res,
|
||||||
|
GError **error);
|
||||||
|
|
||||||
/* Shared QMI location support */
|
/* Shared QMI location support */
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user