]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
2723. [bug] isc_base32_totext(), isc_base32hex_totext(), and
authorEvan Hunt <each@isc.org>
Wed, 21 Oct 2009 01:22:29 +0000 (01:22 +0000)
committerEvan Hunt <each@isc.org>
Wed, 21 Oct 2009 01:22:29 +0000 (01:22 +0000)
isc_base64_totext(), didn't always mark regions of
memory as fully consumed after conversion.  [RT #20445]

CHANGES
lib/isc/base32.c
lib/isc/base64.c

diff --git a/CHANGES b/CHANGES
index 8aa8017a1f31aa43eb726fc05f44ac1dba92d5f5..c43a87829fe8c26651115de23006e5aac0c9e1c2 100644 (file)
--- a/CHANGES
+++ b/CHANGES
@@ -1,3 +1,7 @@
+2723.  [bug]           isc_base32_totext(), isc_base32hex_totext(), and
+                       isc_base64_totext(), didn't always mark regions of
+                       memory as fully consumed after conversion.  [RT #20445]
+
 2722.  [bug]           Ensure that the memory associated with the name of
                        a node in a rbt tree is not altered during the life
                        of the node. [RT #20431]
index 67398c6b8c7f9ada106b69c286f6bfd8000fb001..d25e3c4716bbe3ffec344b7d16279c809c04ac48 100644 (file)
@@ -14,7 +14,7 @@
  * PERFORMANCE OF THIS SOFTWARE.
  */
 
-/* $Id: base32.c,v 1.5 2009/01/18 23:48:14 tbox Exp $ */
+/* $Id: base32.c,v 1.6 2009/10/21 01:22:29 each Exp $ */
 
 /*! \file */
 
@@ -112,6 +112,8 @@ base32_totext(isc_region_t *source, int wordlength, const char *wordbreak,
                        RETERR(str_totext(wordbreak, target));
                }
        }
+       if (source->length > 0)
+               isc_region_consume(source, source->length);
        return (ISC_R_SUCCESS);
 }
 
index 13ed6b5c5c170af346359046dd4240965497891b..e5f44856e04cd84b0f097f9d9d9b1bbc032956b5 100644 (file)
@@ -15,7 +15,7 @@
  * PERFORMANCE OF THIS SOFTWARE.
  */
 
-/* $Id: base64.c,v 1.32 2007/06/19 23:47:17 tbox Exp $ */
+/* $Id: base64.c,v 1.33 2009/10/21 01:22:29 each Exp $ */
 
 /*! \file */
 
@@ -85,11 +85,13 @@ isc_base64_totext(isc_region_t *source, int wordlength,
                buf[2] = base64[((source->base[1]<<2)&0x3c)];
                buf[3] = '=';
                RETERR(str_totext(buf, target));
+               isc_region_consume(source, 2);
        } else if (source->length == 1) {
                buf[0] = base64[(source->base[0]>>2)&0x3f];
                buf[1] = base64[((source->base[0]<<4)&0x30)];
                buf[2] = buf[3] = '=';
                RETERR(str_totext(buf, target));
+               isc_region_consume(source, 1);
        }
        return (ISC_R_SUCCESS);
 }