aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDan Williams <dcbw@redhat.com>2011-12-07 17:07:46 -0600
committerDan Williams <dcbw@redhat.com>2011-12-07 17:07:46 -0600
commit2af1a612e9187c0e2bf3a8e3d007f04aa023add9 (patch)
treef3a864e6521e8459bf1bb76840e534bb01f002e3 /src
parentc1e64f1a33b8b877945e59bda58b1969cdc27614 (diff)
core: don't crash on error if response is NULL
Various bits of the code didn't check if response was valid or not during error conditions, and when an error occurs sometimes it'll be NULL (since not all errors are translated errors from the modem, some are serial or general ones). We have to make sure we don't try to use response->str when response doesn't exist. Found in the generic CDMA code likely as a result of d5d9eec2b52363a7460aeec0c020b1c6a7af6b03 but was a bug long before that commit happened anyway.
Diffstat (limited to 'src')
-rw-r--r--src/mm-generic-cdma.c5
-rw-r--r--src/mm-generic-gsm.c2
-rw-r--r--src/mm-modem-base.c3
3 files changed, 6 insertions, 4 deletions
diff --git a/src/mm-generic-cdma.c b/src/mm-generic-cdma.c
index 371cd66e..58ced39b 100644
--- a/src/mm-generic-cdma.c
+++ b/src/mm-generic-cdma.c
@@ -988,7 +988,6 @@ get_signal_quality_done (MMAtSerialPort *port,
{
MMGenericCdmaPrivate *priv;
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
- char *reply = response->str;
/* If the modem has already been removed, return without
* scheduling callback */
@@ -1008,6 +1007,7 @@ get_signal_quality_done (MMAtSerialPort *port,
return;
}
} else {
+ const char *reply = response->str;
int quality, ber;
/* Got valid reply */
@@ -1273,7 +1273,7 @@ serving_system_done (MMAtSerialPort *port,
gpointer user_data)
{
MMCallbackInfo *info = (MMCallbackInfo *) user_data;
- char *reply = response->str;
+ char *reply;
int class = 0, sid = 99999, num;
unsigned char band = 'Z';
gboolean success = FALSE;
@@ -1288,6 +1288,7 @@ serving_system_done (MMAtSerialPort *port,
goto out;
}
+ reply = response->str;
if (strstr (reply, "+CSS: "))
reply += 6;
diff --git a/src/mm-generic-gsm.c b/src/mm-generic-gsm.c
index c41e9f2a..6c7b938c 100644
--- a/src/mm-generic-gsm.c
+++ b/src/mm-generic-gsm.c
@@ -350,7 +350,7 @@ pin_check_done (MMAtSerialPort *port,
info->error = g_error_new (MM_MODEM_ERROR,
MM_MODEM_ERROR_GENERAL,
"Could not parse PIN request response '%s'",
- response->str);
+ response ? response->str : "(unknown)");
}
}
diff --git a/src/mm-modem-base.c b/src/mm-modem-base.c
index 526eb51e..372367a9 100644
--- a/src/mm-modem-base.c
+++ b/src/mm-modem-base.c
@@ -553,9 +553,10 @@ info_item_done (MMCallbackInfo *info,
const char *tag2,
const char *desc)
{
- const char *p = response->str;
+ const char *p;
if (!error) {
+ p = response->str;
if (tag)
p = mm_strip_tag (p, tag);
if (tag2)