ab874cce28
a consistent interface to h/w and s/w crypto algorithms for use by the kernel and (for h/w at least) by user-mode apps. Access for user-level code is through a /dev/crypto device that'll eventually be used by openssl to (potentially) accelerate many applications. Coming soon is an IPsec that makes use of this service to accelerate ESP, AH, and IPCOMP protocols. Included here is the "core" crypto support, /dev/crypto driver, various crypto algorithms that are not already present in the KAME crypto area, and support routines used by crypto device drivers. Obtained from: openbsd
66 lines
1.9 KiB
C
66 lines
1.9 KiB
C
/* $FreeBSD$ */
|
|
/* $OpenBSD: cryptosoft.h,v 1.10 2002/04/22 23:10:09 deraadt Exp $ */
|
|
|
|
/*
|
|
* The author of this code is Angelos D. Keromytis (angelos@cis.upenn.edu)
|
|
*
|
|
* This code was written by Angelos D. Keromytis in Athens, Greece, in
|
|
* February 2000. Network Security Technologies Inc. (NSTI) kindly
|
|
* supported the development of this code.
|
|
*
|
|
* Copyright (c) 2000 Angelos D. Keromytis
|
|
*
|
|
* Permission to use, copy, and modify this software with or without fee
|
|
* is hereby granted, provided that this entire notice is included in
|
|
* all source code copies of any software which is or includes a copy or
|
|
* modification of this software.
|
|
*
|
|
* THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR
|
|
* IMPLIED WARRANTY. IN PARTICULAR, NONE OF THE AUTHORS MAKES ANY
|
|
* REPRESENTATION OR WARRANTY OF ANY KIND CONCERNING THE
|
|
* MERCHANTABILITY OF THIS SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR
|
|
* PURPOSE.
|
|
*/
|
|
|
|
#ifndef _CRYPTO_CRYPTOSOFT_H_
|
|
#define _CRYPTO_CRYPTOSOFT_H_
|
|
|
|
/* Software session entry */
|
|
struct swcr_data {
|
|
int sw_alg; /* Algorithm */
|
|
union {
|
|
struct {
|
|
u_int8_t *SW_ictx;
|
|
u_int8_t *SW_octx;
|
|
u_int32_t SW_klen;
|
|
struct auth_hash *SW_axf;
|
|
} SWCR_AUTH;
|
|
struct {
|
|
u_int8_t *SW_kschedule;
|
|
struct enc_xform *SW_exf;
|
|
} SWCR_ENC;
|
|
struct {
|
|
u_int32_t SW_size;
|
|
struct comp_algo *SW_cxf;
|
|
} SWCR_COMP;
|
|
} SWCR_UN;
|
|
|
|
#define sw_ictx SWCR_UN.SWCR_AUTH.SW_ictx
|
|
#define sw_octx SWCR_UN.SWCR_AUTH.SW_octx
|
|
#define sw_klen SWCR_UN.SWCR_AUTH.SW_klen
|
|
#define sw_axf SWCR_UN.SWCR_AUTH.SW_axf
|
|
#define sw_kschedule SWCR_UN.SWCR_ENC.SW_kschedule
|
|
#define sw_exf SWCR_UN.SWCR_ENC.SW_exf
|
|
#define sw_size SWCR_UN.SWCR_COMP.SW_size
|
|
#define sw_cxf SWCR_UN.SWCR_COMP.SW_cxf
|
|
|
|
struct swcr_data *sw_next;
|
|
};
|
|
|
|
#ifdef _KERNEL
|
|
extern u_int8_t hmac_ipad_buffer[64];
|
|
extern u_int8_t hmac_opad_buffer[64];
|
|
#endif /* _KERNEL */
|
|
|
|
#endif /* _CRYPTO_CRYPTO_H_ */
|