/*
* Copyright 2008 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/*
* Copyright (C) 1998 by the FundsXpress, INC.
*
* All rights reserved.
*
* Export of this software from the United States of America may require
* a specific license from the United States Government. It is the
* responsibility of any person or organization contemplating export to
* obtain such a license before exporting.
*
* WITHIN THAT CONSTRAINT, permission to use, copy, modify, and
* distribute this software and its documentation for any purpose and
* without fee is hereby granted, provided that the above copyright
* notice appear in all copies and that both that copyright notice and
* this permission notice appear in supporting documentation, and that
* the name of FundsXpress. not be used in advertising or publicity pertaining
* to distribution of the software without specific, written prior
* permission. FundsXpress makes no representations about the suitability of
* this software for any purpose. It is provided "as is" without express
* or implied warranty.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
*/
#include "k5-int.h"
#include "etypes.h"
#include "dk.h"
/*
* Derive the key for checksum calculation.
* This is only called (currently) for SHA1-DES3
* checksum types.
*
* The primary benefit here is that a KEF template
* is created for use when doing the HMAC operation which
* saves ALOT of computation cycles and improves performance.
*/
static krb5_error_code
struct krb5_enc_provider *enc,
const krb5_keyblock *key,
{
(krb5_keyblock *)key);
if (cached_key)
*outkey = cached_key;
else {
return (ENOMEM);
if (ret) {
return (ret);
}
#ifdef _KERNEL
/*
* By default, derived keys get the "mech_type"
* that was associated with their parent.
* we need to switch the mech_type to correspond
* to the checksum mech type.
*/
if (ret == 0 &&
}
}
#endif /* _KERNEL */
if (ret == 0)
*outkey);
}
return (ret);
}
/* ARGSUSED */
{
int i;
for (i=0; i<krb5_enctypes_length; i++) {
break;
}
if (i == krb5_enctypes_length) {
return(KRB5_BAD_ENCTYPE);
}
#ifdef _KERNEL
(krb5_keyblock *)key)))
goto cleanup;
#endif
if (ret != 0)
goto cleanup;
#ifdef _KERNEL
}
#else
}
#endif /* _KERNEL */
return(ret);
}