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

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

krb5 commit: Fix leak in gss_display_name() for non-MN names

daemon@ATHENA.MIT.EDU (Greg Hudson)
Wed Aug 10 13:53:58 2016

Date: Wed, 10 Aug 2016 13:51:37 -0400
From: Greg Hudson <ghudson@mit.edu>
Message-Id: <201608101751.u7AHpbcu009368@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/20fcbf2cb820df0d31e66bb11f64fb50a31008f5
commit 20fcbf2cb820df0d31e66bb11f64fb50a31008f5
Author: Greg Hudson <ghudson@mit.edu>
Date:   Tue Jun 28 12:28:11 2016 -0400

    Fix leak in gss_display_name() for non-MN names
    
    RFC 2744 states that the gss_display_name() output_name_type result is
    "a pointer into static storage, and should be treated as read-only by
    the caller (in particular, the application should not attempt to free
    it)".  For non-mechanism names, we were making a copy of the name type
    from the union name structure, causing a memory leak; stop doing that.
    
    ticket: 8439 (new)
    target_version: 1.14-next
    target_version: 1.13-next
    tags: pullup

 src/lib/gssapi/mechglue/g_dsp_name.c |   27 ++++-----------------------
 1 files changed, 4 insertions(+), 23 deletions(-)

diff --git a/src/lib/gssapi/mechglue/g_dsp_name.c b/src/lib/gssapi/mechglue/g_dsp_name.c
index 825bf4d..21867c8 100644
--- a/src/lib/gssapi/mechglue/g_dsp_name.c
+++ b/src/lib/gssapi/mechglue/g_dsp_name.c
@@ -102,36 +102,17 @@ gss_OID *		output_name_type;
 					    output_name_type));
     }
 
-    /*
-     * copy the value of the external_name component of the union
-     * name into the output_name_buffer and point the output_name_type
-     * to the name_type component of union_name
-     */
-    if (output_name_type != NULL &&
-	union_name->name_type != GSS_C_NULL_OID) {
-	major_status = generic_gss_copy_oid(minor_status,
-					    union_name->name_type,
-					    output_name_type);
-	if (major_status != GSS_S_COMPLETE) {
-	    map_errcode(minor_status);
-	    return (major_status);
-	}
-    }
-
     if ((output_name_buffer->value =
-	 gssalloc_malloc(union_name->external_name->length + 1)) == NULL) {
-	if (output_name_type && *output_name_type != GSS_C_NULL_OID) {
-	    (void) generic_gss_release_oid(minor_status,
-					   output_name_type);
-	    *output_name_type = NULL;
-	}
+	 gssalloc_malloc(union_name->external_name->length + 1)) == NULL)
 	return (GSS_S_FAILURE);
-    }
     output_name_buffer->length = union_name->external_name->length;
     (void) memcpy(output_name_buffer->value,
 		  union_name->external_name->value,
 		  union_name->external_name->length);
     ((char *)output_name_buffer->value)[output_name_buffer->length] = '\0';
 
+    if (output_name_type != NULL)
+	*output_name_type = union_name->name_type;
+
     return(GSS_S_COMPLETE);
 }
_______________________________________________
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