components/curl/patches/023-CVE-2016-9586.patch
author Yiteng Zhang <yiteng.zhang@oracle.com>
Tue, 10 Jan 2017 17:35:21 -0800
changeset 7552 17fdfad41903
permissions -rw-r--r--
25241371 problem in LIBRARY/CURL 25241378 problem in LIBRARY/CURL 25241832 problem in LIBRARY/CURL 25241839 problem in LIBRARY/CURL 25241853 problem in LIBRARY/CURL 25241867 problem in LIBRARY/CURL 25241881 problem in LIBRARY/CURL 25241889 problem in LIBRARY/CURL 25241894 problem in LIBRARY/CURL 25241900 problem in LIBRARY/CURL 25306385 problem in LIBRARY/CURL
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
7552
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     1
commit 3ab3c16db6a5674f53cf23d56512a405fde0b2c9
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     2
Author: Daniel Stenberg <[email protected]>
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     3
Date:   Tue Nov 8 15:32:37 2016 +0100
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     4
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     5
    printf: fix floating point buffer overflow issues
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     6
    
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     7
    ... and add a bunch of floating point printf tests
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     8
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
     9
This patch is modified to adapt to curl 7.45.0 in Solaris.
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    10
--- lib/mprintf.c
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    11
+++ lib/mprintf.c
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    12
@@ -90,11 +90,12 @@
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    13
 #else
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    14
 #  define mp_intmax_t long
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    15
 #  define mp_uintmax_t unsigned long
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    16
 #endif
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    17
 
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    18
-#define BUFFSIZE 256 /* buffer for long-to-str and float-to-str calcs */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    19
+#define BUFFSIZE 326 /* buffer for long-to-str and float-to-str calcs, should
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    20
+                        fit negative DBL_MAX (317 letters) */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    21
 #define MAX_PARAMETERS 128 /* lame static limit */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    22
 
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    23
 #ifdef __AMIGA__
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    24
 # undef FORMAT_INT
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    25
 #endif
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    26
@@ -914,16 +915,29 @@ static int dprintf_formatf(
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    27
           *fptr++ = '#';
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    28
 
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    29
         *fptr = 0;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    30
 
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    31
         if(width >= 0) {
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    32
+          if(width >= (long)sizeof(work))
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    33
+            width = sizeof(work)-1;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    34
           /* RECURSIVE USAGE */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    35
           len = curl_msnprintf(fptr, left, "%ld", width);
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    36
           fptr += len;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    37
           left -= len;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    38
         }
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    39
         if(prec >= 0) {
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    40
+          /* for each digit in the integer part, we can have one less
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    41
+             precision */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    42
+          size_t maxprec = sizeof(work) - 2;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    43
+          double val = p->data.dnum;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    44
+          while(val >= 10.0) {
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    45
+            val /= 10;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    46
+            maxprec--;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    47
+          }
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    48
+
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    49
+          if(prec > (long)maxprec)
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    50
+            prec = maxprec-1;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    51
           /* RECURSIVE USAGE */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    52
           len = curl_msnprintf(fptr, left, ".%ld", prec);
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    53
           fptr += len;
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    54
         }
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    55
         if(p->flags & FLAGS_LONG)
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    56
@@ -939,11 +953,13 @@ static int dprintf_formatf(
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    57
         *fptr = 0; /* and a final zero termination */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    58
 
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    59
         /* NOTE NOTE NOTE!! Not all sprintf implementations return number of
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    60
            output characters */
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    61
         (sprintf)(work, formatbuf, p->data.dnum);
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    62
-
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    63
+#ifdef CURLDEBUG
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    64
+        assert(strlen(work) <= sizeof(work));
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    65
+#endif
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    66
         for(fptr=work; *fptr; fptr++)
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    67
           OUTCHAR(*fptr);
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    68
       }
17fdfad41903 25241371 problem in LIBRARY/CURL
Yiteng Zhang <yiteng.zhang@oracle.com>
parents:
diff changeset
    69
       break;