e206af5319
- Fix CVE-2015-8629: krb5: xdr_nullstring() doesn't check for terminating null character with patch 0104-Verify-decoded-kadmin-C-strings-CVE-2015-8629.patch (bsc#963968) - Fix CVE-2015-8631: krb5: Memory leak caused by supplying a null principal name in request with patch 0105-Fix-leaks-in-kadmin-server-stubs-CVE-2015-8631.patch (bsc#963975) - Fix CVE-2015-8630: krb5: krb5 doesn't check for null policy when KADM5_POLICY is set in the mask with patch 0106-Check-for-null-kadm5-policy-name-CVE-2015-8630.patch (bsc#963964) OBS-URL: https://build.opensuse.org/request/show/357309 OBS-URL: https://build.opensuse.org/package/show/network/krb5?expand=0&rev=158
46 lines
1.4 KiB
Diff
46 lines
1.4 KiB
Diff
From df17a1224a3406f57477bcd372c61e04c0e5a5bb Mon Sep 17 00:00:00 2001
|
|
From: Greg Hudson <ghudson@mit.edu>
|
|
Date: Fri, 8 Jan 2016 12:45:25 -0500
|
|
Subject: [PATCH] Verify decoded kadmin C strings [CVE-2015-8629]
|
|
|
|
In xdr_nullstring(), check that the decoded string is terminated with
|
|
a zero byte and does not contain any internal zero bytes.
|
|
|
|
CVE-2015-8629:
|
|
|
|
In all versions of MIT krb5, an authenticated attacker can cause
|
|
kadmind to read beyond the end of allocated memory by sending a string
|
|
without a terminating zero byte. Information leakage may be possible
|
|
for an attacker with permission to modify the database.
|
|
|
|
CVSSv2 Vector: AV:N/AC:H/Au:S/C:P/I:N/A:N/E:POC/RL:OF/RC:C
|
|
|
|
ticket: 8341 (new)
|
|
target_version: 1.14-next
|
|
target_version: 1.13-next
|
|
tags: pullup
|
|
|
|
diff --git a/src/lib/kadm5/kadm_rpc_xdr.c b/src/lib/kadm5/kadm_rpc_xdr.c
|
|
index 2bef858..ba67084 100644
|
|
--- a/src/lib/kadm5/kadm_rpc_xdr.c
|
|
+++ b/src/lib/kadm5/kadm_rpc_xdr.c
|
|
@@ -64,7 +64,14 @@ bool_t xdr_nullstring(XDR *xdrs, char **objp)
|
|
return FALSE;
|
|
}
|
|
}
|
|
- return (xdr_opaque(xdrs, *objp, size));
|
|
+ if (!xdr_opaque(xdrs, *objp, size))
|
|
+ return FALSE;
|
|
+ /* Check that the unmarshalled bytes are a C string. */
|
|
+ if ((*objp)[size - 1] != '\0')
|
|
+ return FALSE;
|
|
+ if (memchr(*objp, '\0', size - 1) != NULL)
|
|
+ return FALSE;
|
|
+ return TRUE;
|
|
|
|
case XDR_ENCODE:
|
|
if (size != 0)
|
|
--
|
|
2.7.0
|
|
|