aboutsummaryrefslogtreecommitdiffstats
path: root/src/libutil/str_util.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-09-25 09:46:47 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-09-25 09:46:47 +0100
commit0295d3ba5d02bf65370db6bdd197bdd8f50a0f91 (patch)
tree1abcfa4bec6512192f4882a2bf7263366335c60a /src/libutil/str_util.c
parente4dbb877a320ad27592fb3cbfec0f45085c01012 (diff)
downloadrspamd-0295d3ba5d02bf65370db6bdd197bdd8f50a0f91.tar.gz
rspamd-0295d3ba5d02bf65370db6bdd197bdd8f50a0f91.zip
[Fix] Fix out-of-bound read in qp decode
Diffstat (limited to 'src/libutil/str_util.c')
-rw-r--r--src/libutil/str_util.c30
1 files changed, 27 insertions, 3 deletions
diff --git a/src/libutil/str_util.c b/src/libutil/str_util.c
index 91199aec1..f5cd8be1a 100644
--- a/src/libutil/str_util.c
+++ b/src/libutil/str_util.c
@@ -2088,6 +2088,10 @@ rspamd_decode_qp_buf (const gchar *in, gsize inlen,
if (end - o > 0) {
*o++ = *p;
}
+ else {
+ /* Buffer overflow */
+ return (-1);
+ }
break;
}
@@ -2149,9 +2153,29 @@ decode:
processed = pos - o;
remain -= processed;
p += processed;
- o = pos - 1;
- /* Skip comparison, as we know that we have found match */
- goto decode;
+
+ if (remain > 0) {
+ o = pos - 1;
+ /*
+ * Skip comparison and jump inside decode branch,
+ * as we know that we have found match
+ */
+ goto decode;
+ }
+ else {
+ /* Last '=' character, bugon */
+ o = pos;
+
+ if (end - o > 0) {
+ *o = '=';
+ }
+ else {
+ /* Buffer overflow */
+ return (-1);
+ }
+
+ break;
+ }
}
}
else {