diff options
author | Koop Mast <kwm@rainbow-runner.nl> | 2017-08-25 21:44:43 +0800 |
---|---|---|
committer | Koop Mast <kwm@rainbow-runner.nl> | 2017-08-25 21:44:43 +0800 |
commit | a1199eb9cee2f56cbe27f0ca2d6c3919db16036f (patch) | |
tree | 0031c7f551683dccee6e2b42ae1ae1d6d0731a2c /devel/libsoup | |
parent | cf22aa62ca36265974b6cb75dbcbdc3c4a7c9830 (diff) | |
parent | bdd4bb492264adca9021a338059e9df74cac724e (diff) | |
download | freebsd-ports-gnome-a1199eb9cee2f56cbe27f0ca2d6c3919db16036f.tar.gz freebsd-ports-gnome-a1199eb9cee2f56cbe27f0ca2d6c3919db16036f.tar.zst freebsd-ports-gnome-a1199eb9cee2f56cbe27f0ca2d6c3919db16036f.zip |
Merge branch 'master' into gnome-3.24
Diffstat (limited to 'devel/libsoup')
-rw-r--r-- | devel/libsoup/files/patch-libsoup_soup-filter-input-stream.c | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/devel/libsoup/files/patch-libsoup_soup-filter-input-stream.c b/devel/libsoup/files/patch-libsoup_soup-filter-input-stream.c new file mode 100644 index 000000000000..8d44c38ba9c1 --- /dev/null +++ b/devel/libsoup/files/patch-libsoup_soup-filter-input-stream.c @@ -0,0 +1,58 @@ +From 03c91c76daf70ee227f38304c5e45a155f45073d Mon Sep 17 00:00:00 2001 +From: Dan Winship <danw@gnome.org> +Date: Thu, 3 Aug 2017 09:56:43 -0400 +Subject: Fix chunked decoding buffer overrun (CVE-2017-2885) + +https://bugzilla.gnome.org/show_bug.cgi?id=785774 +--- + libsoup/soup-filter-input-stream.c | 22 +++++++++++----------- + 1 file changed, 11 insertions(+), 11 deletions(-) + +diff --git a/libsoup/soup-filter-input-stream.c b/libsoup/soup-filter-input-stream.c +index cde4d12..2c30bf9 100644 +--- libsoup/soup-filter-input-stream.c ++++ libsoup/soup-filter-input-stream.c +@@ -198,7 +198,7 @@ soup_filter_input_stream_read_until (SoupFilterInputStream *fstream, + GCancellable *cancellable, + GError **error) + { +- gssize nread; ++ gssize nread, read_length; + guint8 *p, *buf, *end; + gboolean eof = FALSE; + GError *my_error = NULL; +@@ -251,10 +251,11 @@ soup_filter_input_stream_read_until (SoupFilterInputStream *fstream, + } else + buf = fstream->priv->buf->data; + +- /* Scan for the boundary */ +- end = buf + fstream->priv->buf->len; +- if (!eof) +- end -= boundary_length; ++ /* Scan for the boundary within the range we can possibly return. */ ++ if (include_boundary) ++ end = buf + MIN (fstream->priv->buf->len, length) - boundary_length; ++ else ++ end = buf + MIN (fstream->priv->buf->len - boundary_length, length); + for (p = buf; p <= end; p++) { + if (*p == *(guint8*)boundary && + !memcmp (p, boundary, boundary_length)) { +@@ -268,10 +269,9 @@ soup_filter_input_stream_read_until (SoupFilterInputStream *fstream, + if (!*got_boundary && fstream->priv->buf->len < length && !eof) + goto fill_buffer; + +- /* Return everything up to 'p' (which is either just after the boundary if +- * include_boundary is TRUE, just before the boundary if include_boundary is +- * FALSE, @boundary_len - 1 bytes before the end of the buffer, or end-of- +- * file). +- */ +- return read_from_buf (fstream, buffer, p - buf); ++ if (eof && !*got_boundary) ++ read_length = MIN (fstream->priv->buf->len, length); ++ else ++ read_length = p - buf; ++ return read_from_buf (fstream, buffer, read_length); + } +-- +cgit v0.12 + |