diff options
author | Dan Williams <dcbw@redhat.com> | 2009-09-08 17:31:54 -0700 |
---|---|---|
committer | Dan Williams <dcbw@redhat.com> | 2009-09-08 17:34:04 -0700 |
commit | 14e5c52f78e7ad23b18b111e3271cbecad6acf3f (patch) | |
tree | ee6929c990c63139e4209a94f3e2d8c617547f4a /src/mm-generic-cdma.c | |
parent | 6cf01d2ab698d05eb58bffa7e85f41024f5c0546 (diff) |
core: don't allow concurrent flashes on the same device
Previously, a few operations (like disable) could trigger a modem
flash in parallel with another flash. That's wrong, don't allow
that. At the same time, add in finer-grained error checking on
serial port speed operations, and fix a GSM generic bug that would
send the POWER_UP string on disable.
Diffstat (limited to 'src/mm-generic-cdma.c')
-rw-r--r-- | src/mm-generic-cdma.c | 34 |
1 files changed, 26 insertions, 8 deletions
diff --git a/src/mm-generic-cdma.c b/src/mm-generic-cdma.c index d81c1b18..be1ad8e9 100644 --- a/src/mm-generic-cdma.c +++ b/src/mm-generic-cdma.c @@ -218,8 +218,17 @@ init_done (MMSerialPort *port, } static void -flash_done (MMSerialPort *port, gpointer user_data) +flash_done (MMSerialPort *port, GError *error, gpointer user_data) { + MMCallbackInfo *info = (MMCallbackInfo *) user_data; + + if (error) { + /* Flash failed for some reason */ + info->error = g_error_copy (error); + mm_callback_info_schedule (info); + return; + } + mm_serial_port_queue_command (port, "Z E0 V1 X4 &C1", 3, init_done, user_data); } @@ -240,11 +249,13 @@ enable (MMModem *modem, return; } - if (mm_serial_port_open (priv->primary, &info->error)) - mm_serial_port_flash (priv->primary, 100, flash_done, info); - - if (info->error) + if (!mm_serial_port_open (priv->primary, &info->error)) { + g_assert (info->error); mm_callback_info_schedule (info); + return; + } + + mm_serial_port_flash (priv->primary, 100, flash_done, info); } static void @@ -283,12 +294,19 @@ connect (MMModem *modem, } static void -disconnect_flash_done (MMSerialPort *port, gpointer user_data) +disconnect_flash_done (MMSerialPort *port, + GError *error, + gpointer user_data) { MMCallbackInfo *info = (MMCallbackInfo *) user_data; - MMGenericCdmaPrivate *priv; + MMGenericCdmaPrivate *priv = MM_GENERIC_CDMA_GET_PRIVATE (info->modem); + + if (error) { + info->error = g_error_copy (error); + mm_callback_info_schedule (info); + return; + } - priv = MM_GENERIC_CDMA_GET_PRIVATE (info->modem); mm_port_set_connected (priv->data, FALSE); mm_callback_info_schedule (info); } |