Fix IAKERB context export/import [CVE-2015-2698]
The patches for CVE-2015-2696 contained a regression in the newly
added IAKERB iakerb_gss_export_sec_context() function, which could
cause it to corrupt memory. Fix the regression by properly
dereferencing the context_handle pointer before casting it.
Also, the patches did not implement an IAKERB gss_import_sec_context()
function, under the erroneous belief that an exported IAKERB context
would be tagged as a krb5 context. Implement it now to allow IAKERB
contexts to be successfully exported and imported after establishment.
In any MIT krb5 release with the patches for CVE-2015-2696 applied, an
application which calls gss_export_sec_context() may experience memory
corruption if the context was established using the IAKERB mechanism.
Historically, some vulnerabilities of this nature can be translated
into remote code execution, though the necessary exploits must be
tailored to the individual application and are usually quite
CVSSv2 Vector: AV:N/AC:H/Au:S/C:C/I:C/A:C/E:POC/RL:OF/RC:C
(cherry picked from commit 3db8dfec1ef50ddd78d6ba9503185995876a39fd)
(cherry picked from commit 54222de30a89bfac0247dfbc1759556dc9fd2983)
Author: Greg Hudson <firstname.lastname@example.org>
Committer: Tom Yu <email@example.com>
src/lib/gssapi/krb5/gssapiP_krb5.h | 5 ++++
src/lib/gssapi/krb5/gssapi_krb5.c | 2 +-
src/lib/gssapi/krb5/iakerb.c | 42 ++++++++++++++++++++++++++++++------
3 files changed, 41 insertions(+), 8 deletions(-)