]> granicus.if.org Git - postgresql/commitdiff
Fix buffer overrun in to_ascii(), per report from Guido Notari.
authorTom Lane <tgl@sss.pgh.pa.us>
Wed, 2 Apr 2003 21:07:59 +0000 (21:07 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Wed, 2 Apr 2003 21:07:59 +0000 (21:07 +0000)
src/backend/utils/adt/ascii.c

index 0a2820721dcc7dcdebaf61f9b4abb5f99ac888ce..9595876286b86dd6feb08767eb79a04b7f7f89c8 100644 (file)
@@ -1,7 +1,7 @@
 /* -----------------------------------------------------------------------
  * ascii.c
  *
- * $Header: /cvsroot/pgsql/src/backend/utils/adt/ascii.c,v 1.13 2002/08/29 07:22:26 ishii Exp $
+ * $Header: /cvsroot/pgsql/src/backend/utils/adt/ascii.c,v 1.14 2003/04/02 21:07:59 tgl Exp $
  *
  *      Portions Copyright (c) 1999-2000, PostgreSQL Global Development Group
  *
@@ -27,9 +27,9 @@ static text *encode_to_ascii(text *data, int enc);
 char *
 pg_to_ascii(unsigned char *src, unsigned char *src_end, unsigned char *desc, int enc)
 {
-       unsigned char *x = NULL;
-       unsigned char *ascii = NULL;
-       int                     range = 0;
+       unsigned char *x;
+       unsigned char *ascii;
+       int                     range;
 
        /*
         * relevant start for an encoding
@@ -66,12 +66,13 @@ pg_to_ascii(unsigned char *src, unsigned char *src_end, unsigned char *desc, int
        {
                elog(ERROR, "pg_to_ascii(): unsupported encoding from %s",
                         pg_encoding_to_char(enc));
+               return NULL;                    /* keep compiler quiet */
        }
 
        /*
         * Encode
         */
-       for (x = src; x <= src_end; x++)
+       for (x = src; x < src_end; x++)
        {
                if (*x < 128)
                        *desc++ = *x;