Fix of prefix bio filter (bf_prefix.c): rely on the given length
authorRichard Levitte <levitte@openssl.org>
Thu, 1 Feb 2018 20:28:59 +0000 (21:28 +0100)
committerRichard Levitte <levitte@openssl.org>
Thu, 1 Feb 2018 21:09:41 +0000 (22:09 +0100)
The assumption that the received buffer has to be NUL-terminated was
faulty.

Fault found in #5224

Reviewed-by: Rich Salz <rsalz@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/5239)

apps/bf_prefix.c

index 4d5e3a31c155590f5bba680f020f12514ab2a288..bae3c91bf8b385494ec0ffba1a6ee92b5266a052 100644 (file)
@@ -96,7 +96,7 @@ static int prefix_write(BIO *b, const char *out, size_t outl,
 
     *numwritten = 0;
 
-    while (*out != '\0') {
+    while (outl > 0) {
         size_t i;
         char c;
 
@@ -111,7 +111,7 @@ static int prefix_write(BIO *b, const char *out, size_t outl,
         }
 
         /* Now, go look for the next LF, or the end of the string */
-        for (i = 0; (c = out[i]) != '\n' && c != '\0'; i++)
+        for (i = 0, c = '\0'; i < outl && (c = out[i]) != '\n'; i++)
             continue;
         if (c == '\n')
             i++;
@@ -123,6 +123,7 @@ static int prefix_write(BIO *b, const char *out, size_t outl,
             if (!BIO_write_ex(BIO_next(b), out, i, &num))
                 return 0;
             out += num;
+            outl -= num;
             *numwritten += num;
             i -= num;
         }