]> git.ipfire.org Git - thirdparty/krb5.git/commitdiff
Fix krb5_cccol_have_content() bad pointer free
authorIlya Gladyshev <ilya.v.gladyshev@gmail.com>
Wed, 30 Aug 2023 20:19:59 +0000 (21:19 +0100)
committerGreg Hudson <ghudson@mit.edu>
Sun, 3 Sep 2023 02:21:40 +0000 (22:21 -0400)
krb5_cccol_have_content() calls krb5_cc_get_principal() within a loop,
and frees the resulting principal on success or failure.  Set princ to
null before each call to ensure we don't free a dangling pointer.

[ghudson@mit.edu: rewrote commit message; moved assignment for greater
clarity]

ticket: 9103
tags: pullup
target_version: 1.21-next
target_version: 1.20-next

src/lib/krb5/ccache/cccursor.c

index 4bcb66b712c3b988cfe0b88b6948519d5e602035..926873f2a2e69b2fbe611909e6dd2ea41b4982f8 100644 (file)
@@ -249,6 +249,7 @@ krb5_cccol_have_content(krb5_context context)
         save_first_error(context, ret, &errsave);
         if (ret || cache == NULL)
             break;
+        princ = NULL;
         ret = krb5_cc_get_principal(context, cache, &princ);
         save_first_error(context, ret, &errsave);
         if (!ret)