(krb5_crypto_init): clear return pointer on failure
git-svn-id: svn://svn.h5l.se/heimdal/trunk/heimdal@13752 ec53bebd-3082-4978-b11e-865c3cabbd6b
This commit is contained in:
@@ -3677,18 +3677,21 @@ krb5_crypto_init(krb5_context context,
|
||||
(*crypto)->et = _find_enctype(etype);
|
||||
if((*crypto)->et == NULL || ((*crypto)->et->flags & F_DISABLED)) {
|
||||
free(*crypto);
|
||||
*crypto = NULL;
|
||||
krb5_set_error_string (context, "encryption type %d not supported",
|
||||
etype);
|
||||
return KRB5_PROG_ETYPE_NOSUPP;
|
||||
}
|
||||
if((*crypto)->et->keytype->size != key->keyvalue.length) {
|
||||
free(*crypto);
|
||||
*crypto = NULL;
|
||||
krb5_set_error_string (context, "encryption key has bad length");
|
||||
return KRB5_BAD_KEYSIZE;
|
||||
}
|
||||
ret = krb5_copy_keyblock(context, key, &(*crypto)->key.key);
|
||||
if(ret) {
|
||||
free(*crypto);
|
||||
*crypto = NULL;
|
||||
return ret;
|
||||
}
|
||||
(*crypto)->key.schedule = NULL;
|
||||
|
Reference in New Issue
Block a user