broadband-modem-mbim: implement reset in Intel-based devices

This commit is contained in:
Aleksander Morgado
2019-11-28 22:25:36 +01:00
parent 9ef658f697
commit a28f88b684

View File

@@ -102,6 +102,7 @@ struct _MMBroadbandModemMbimPrivate {
gboolean is_ussd_supported; gboolean is_ussd_supported;
gboolean is_atds_location_supported; gboolean is_atds_location_supported;
gboolean is_atds_signal_supported; gboolean is_atds_signal_supported;
gboolean is_intel_reset_supported;
/* Process unsolicited notifications */ /* Process unsolicited notifications */
guint notification_id; guint notification_id;
@@ -1712,6 +1713,111 @@ modem_load_signal_quality (MMIfaceModem *self,
mbim_message_unref (message); mbim_message_unref (message);
} }
/*****************************************************************************/
/* Reset */
static gboolean
modem_reset_finish (MMIfaceModem *self,
GAsyncResult *res,
GError **error)
{
return g_task_propagate_boolean (G_TASK (res), error);
}
#if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED
static void
shared_qmi_reset_ready (MMIfaceModem *self,
GAsyncResult *res,
GTask *task)
{
GError *error = NULL;
if (!mm_shared_qmi_reset_finish (self, res, &error))
g_task_return_error (task, error);
else
g_task_return_boolean (task, TRUE);
g_object_unref (task);
}
static void
modem_reset_shared_qmi (GTask *task)
{
mm_shared_qmi_reset (MM_IFACE_MODEM (g_task_get_source_object (task)),
(GAsyncReadyCallback)shared_qmi_reset_ready,
task);
}
#endif
static void
intel_firmware_update_modem_reboot_set_ready (MbimDevice *device,
GAsyncResult *res,
GTask *task)
{
MbimMessage *response;
GError *error = NULL;
response = mbim_device_command_finish (device, res, &error);
if (!response || !mbim_message_response_get_result (response, MBIM_MESSAGE_TYPE_COMMAND_DONE, &error)) {
#if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED
/* We don't really expect the Intel firmware update service to be
* available in QMI modems, but doesn't harm to fallback to the QMI
* implementation here */
mm_dbg ("Couldn't run intel reset: %s", error->message);
g_error_free (error);
modem_reset_shared_qmi (task);
#else
g_task_return_error (task, error);
g_object_unref (task);
#endif
} else {
g_task_return_boolean (task, TRUE);
g_object_unref (task);
}
if (response)
mbim_message_unref (response);
}
static void
modem_reset (MMIfaceModem *_self,
GAsyncReadyCallback callback,
gpointer user_data)
{
MMBroadbandModemMbim *self = MM_BROADBAND_MODEM_MBIM (_self);
GTask *task;
MbimDevice *device;
MbimMessage *message;
if (!peek_device (self, &device, callback, user_data))
return;
task = g_task_new (self, NULL, callback, user_data);
if (!self->priv->is_intel_reset_supported) {
#if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED
modem_reset_shared_qmi (task);
#else
g_task_return_new_error (task, MM_CORE_ERROR, MM_CORE_ERROR_UNSUPPORTED,
"modem reset operation is not supported");
g_object_unref (task);
#endif
return;
}
/* This message is defined in the Intel Firmware Update service, but it
* really is just a standard modem reboot. */
message = mbim_message_intel_firmware_update_modem_reboot_set_new (NULL);
mbim_device_command (device,
message,
10,
NULL,
(GAsyncReadyCallback)intel_firmware_update_modem_reboot_set_ready,
task);
mbim_message_unref (message);
}
/*****************************************************************************/ /*****************************************************************************/
/* Create Bearer (Modem interface) */ /* Create Bearer (Modem interface) */
@@ -2055,6 +2161,14 @@ query_device_services_ready (MbimDevice *device,
} }
} }
break; break;
case MBIM_SERVICE_INTEL_FIRMWARE_UPDATE:
for (j = 0; j < device_services[i]->cids_count; j++) {
if (device_services[i]->cids[j] == MBIM_CID_INTEL_FIRMWARE_UPDATE_MODEM_REBOOT) {
mm_dbg ("Intel reset is supported");
self->priv->is_intel_reset_supported = TRUE;
}
}
break;
default: default:
break; break;
} }
@@ -5272,6 +5386,8 @@ iface_modem_init (MMIfaceModem *iface)
iface->modem_power_up_finish = power_up_finish; iface->modem_power_up_finish = power_up_finish;
iface->modem_power_down = modem_power_down; iface->modem_power_down = modem_power_down;
iface->modem_power_down_finish = power_down_finish; iface->modem_power_down_finish = power_down_finish;
iface->reset = modem_reset;
iface->reset_finish = modem_reset_finish;
iface->load_supported_ip_families = modem_load_supported_ip_families; iface->load_supported_ip_families = modem_load_supported_ip_families;
iface->load_supported_ip_families_finish = modem_load_supported_ip_families_finish; iface->load_supported_ip_families_finish = modem_load_supported_ip_families_finish;
@@ -5318,8 +5434,6 @@ iface_modem_init (MMIfaceModem *iface)
/* Other actions */ /* Other actions */
#if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED #if defined WITH_QMI && QMI_MBIM_QMUX_SUPPORTED
iface->reset = mm_shared_qmi_reset;
iface->reset_finish = mm_shared_qmi_reset_finish;
iface->factory_reset = mm_shared_qmi_factory_reset; iface->factory_reset = mm_shared_qmi_factory_reset;
iface->factory_reset_finish = mm_shared_qmi_factory_reset_finish; iface->factory_reset_finish = mm_shared_qmi_factory_reset_finish;
#endif #endif