aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDan Williams <dcbw@redhat.com>2009-12-01 15:58:11 -0800
committerDan Williams <dcbw@redhat.com>2009-12-01 15:58:11 -0800
commit02c7db7fcfc7af226c2677793685528928d6f7f5 (patch)
treeffe1e914c18b2140ff4fb22e4cdd4d0e93508d56 /src
parenta295afdd2ddd99dea8435d95a72f02d0ade2b2b7 (diff)
cdma: handle interim enabling/disabling states better
Have to fall back to the previous state if the enable/disable operation fails since we cannot assume anything about the new modem state when a failure occurs.
Diffstat (limited to 'src')
-rw-r--r--src/mm-generic-cdma.c36
-rw-r--r--src/mm-generic-cdma.h2
2 files changed, 36 insertions, 2 deletions
diff --git a/src/mm-generic-cdma.c b/src/mm-generic-cdma.c
index e948e32a..e29b1e9a 100644
--- a/src/mm-generic-cdma.c
+++ b/src/mm-generic-cdma.c
@@ -370,6 +370,10 @@ init_done (MMSerialPort *port,
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
if (error) {
+ mm_modem_set_state (MM_MODEM (info->modem),
+ MM_MODEM_STATE_DISABLED,
+ MM_MODEM_STATE_REASON_NONE);
+
info->error = g_error_copy (error);
mm_callback_info_schedule (info);
} else {
@@ -388,6 +392,10 @@ flash_done (MMSerialPort *port, GError *error, gpointer user_data)
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
if (error) {
+ mm_modem_set_state (MM_MODEM (info->modem),
+ MM_MODEM_STATE_DISABLED,
+ MM_MODEM_STATE_REASON_NONE);
+
/* Flash failed for some reason */
info->error = g_error_copy (error);
mm_callback_info_schedule (info);
@@ -414,6 +422,10 @@ enable (MMModem *modem,
return;
}
+ mm_modem_set_state (MM_MODEM (info->modem),
+ MM_MODEM_STATE_ENABLING,
+ MM_MODEM_STATE_REASON_NONE);
+
mm_serial_port_flash (priv->primary, 100, flash_done, info);
}
@@ -425,9 +437,17 @@ disable_flash_done (MMSerialPort *port,
MMCallbackInfo *info = user_data;
MMGenericCdmaPrivate *priv = MM_GENERIC_CDMA_GET_PRIVATE (info->modem);
- if (error)
+ if (error) {
+ MMModemState prev_state;
+
+ /* Reset old state since the operation failed */
+ prev_state = GPOINTER_TO_UINT (mm_callback_info_get_data (info, MM_GENERIC_GSM_PREV_STATE_TAG));
+ mm_modem_set_state (MM_MODEM (info->modem),
+ prev_state,
+ MM_MODEM_STATE_REASON_NONE);
+
info->error = g_error_copy (error);
- else {
+ } else {
mm_serial_port_close (port);
mm_modem_set_state (MM_MODEM (info->modem),
MM_MODEM_STATE_DISABLED,
@@ -448,15 +468,27 @@ disable (MMModem *modem,
MMGenericCdma *self = MM_GENERIC_CDMA (modem);
MMGenericCdmaPrivate *priv = MM_GENERIC_CDMA_GET_PRIVATE (self);
MMCallbackInfo *info;
+ MMModemState state;
/* Tear down any ongoing registration */
registration_cleanup (self, MM_MODEM_ERROR, MM_MODEM_ERROR_GENERAL);
info = mm_callback_info_new (modem, callback, user_data);
+ /* Cache the previous state so we can reset it if the operation fails */
+ state = mm_modem_get_state (modem);
+ mm_callback_info_set_data (info,
+ MM_GENERIC_GSM_PREV_STATE_TAG,
+ GUINT_TO_POINTER (state),
+ NULL);
+
if (priv->secondary)
mm_serial_port_close (priv->secondary);
+ mm_modem_set_state (MM_MODEM (info->modem),
+ MM_MODEM_STATE_DISABLING,
+ MM_MODEM_STATE_REASON_NONE);
+
if (mm_port_get_connected (MM_PORT (priv->primary)))
mm_serial_port_flash (priv->primary, 1000, disable_flash_done, info);
else
diff --git a/src/mm-generic-cdma.h b/src/mm-generic-cdma.h
index 8d85cb38..f870c35e 100644
--- a/src/mm-generic-cdma.h
+++ b/src/mm-generic-cdma.h
@@ -55,6 +55,8 @@ MMModem *mm_generic_cdma_new (const char *device,
/* Private, for subclasses */
+#define MM_GENERIC_GSM_PREV_STATE_TAG "prev-state"
+
MMPort * mm_generic_cdma_grab_port (MMGenericCdma *self,
const char *subsys,
const char *name,