[29071] in CVS-changelog-for-Kerberos-V5

home help back first fref pref prev next nref lref last post

krb5 commit: Fix minor utf8-to-ucs2s read overrun bug

daemon@ATHENA.MIT.EDU (Greg Hudson)
Tue Sep 29 14:19:51 2015

Date: Tue, 29 Sep 2015 14:19:46 -0400
From: Greg Hudson <ghudson@mit.edu>
Message-Id: <201509291819.t8TIJksh023523@drugstore.mit.edu>
To: cvs-krb5@mit.edu
Reply-To: krbdev@mit.edu
MIME-Version: 1.0
Content-Type: text/plain; charset="us-ascii"
Content-Transfer-Encoding: 7bit
Errors-To: cvs-krb5-bounces@mit.edu

https://github.com/krb5/krb5/commit/eb52da21d72faa3d00b1205a5a0fdbabc45c9e6d
commit eb52da21d72faa3d00b1205a5a0fdbabc45c9e6d
Author: Greg Hudson <ghudson@mit.edu>
Date:   Fri Sep 25 17:31:53 2015 -0400

    Fix minor utf8-to-ucs2s read overrun bug
    
    k5_utf8s_to_ucs2s() reads and ignores one extra byte from the input
    string before terminating its loop, possibly overrunning the input
    buffer of its caller.  This overrun is typically without consequence,
    but can show up in tools like asan or valgrind during RC4
    string-to-key operations.  Fix the bug by swapping the order of the
    loop conditions.
    
    ticket: 8253 (new)
    target_version: 1.14
    tags: pullup

 src/util/support/utf8_conv.c |    2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diff --git a/src/util/support/utf8_conv.c b/src/util/support/utf8_conv.c
index 1f6cc8f..80ca90b 100644
--- a/src/util/support/utf8_conv.c
+++ b/src/util/support/utf8_conv.c
@@ -84,7 +84,7 @@ k5_utf8s_to_ucs2s(krb5_ucs2 *ucs2str,
     }
 
     /* Examine next UTF-8 character.  */
-    while (*utf8str && ucs2len < count) {
+    while (ucs2len < count && *utf8str != '\0') {
         /* Get UTF-8 sequence length from 1st byte */
         utflen = KRB5_UTF8_CHARLEN2(utf8str, utflen);
 
_______________________________________________
cvs-krb5 mailing list
cvs-krb5@mit.edu
https://mailman.mit.edu/mailman/listinfo/cvs-krb5

home help back first fref pref prev next nref lref last post