diff options
author | Tambet Ingo <tambet@gmail.com> | 2008-09-11 16:55:44 +0300 |
---|---|---|
committer | Tambet Ingo <tambet@gmail.com> | 2008-09-11 16:55:44 +0300 |
commit | 567278d19dc95880d1091794fd9fa0c3f77fb99d (patch) | |
tree | b4eed40a0242101e86c04a9464a3be8107f41e8a /src | |
parent | 675964a6b278d5fcbef19b3518e519dfd2e544de (diff) |
Make sure the response buffer doesn't grow without bounds.
Diffstat (limited to 'src')
-rw-r--r-- | src/mm-serial.c | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/src/mm-serial.c b/src/mm-serial.c index 621f6bcc..d3f74dca 100644 --- a/src/mm-serial.c +++ b/src/mm-serial.c @@ -477,11 +477,15 @@ data_available (GIOChannel *source, g_string_append_len (priv->response, buf, bytes_read); } + /* Make sure the string doesn't grow too long */ + if (priv->response->len > SERIAL_BUF_SIZE) { + g_warning ("%s (%s): response buffer filled before repsonse received", + G_STRFUNC, mm_serial_get_device (self)); + g_string_erase (priv->response, 0, (SERIAL_BUF_SIZE / 2)); + } + if (parse_response (self, priv->response, &err)) mm_serial_got_response (self, err); - - /* FIXME: Make sure the string doesn't grow too long */ - } while (bytes_read == SERIAL_BUF_SIZE || status == G_IO_STATUS_AGAIN); return TRUE; |