1 /* $OpenBSD: hash.h,v 1.7 2004/04/15 18:39:25 deraadt Exp $	 */
2 /* $EOM: hash.h,v 1.6 1998/07/25 22:04:36 niklas Exp $	 */
3 
4 /*
5  * Copyright (c) 1998 Niels Provos.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26  */
27 
28 /*
29  * This code was written under funding by Ericsson Radio Systems.
30  */
31 
32 #ifndef _HASH_H_
33 #define _HASH_H_
34 
35 /* Normal mode hash encapsulation */
36 
37 #define MD5_SIZE	16
38 #define SHA1_SIZE	20
39 #define HASH_MAX	SHA1_SIZE
40 
41 enum hashes {
42 	HASH_MD5 = 0,
43 	HASH_SHA1
44 };
45 
46 struct hash {
47 	enum hashes     type;
48 	int             id;	/* ISAKMP/Oakley ID */
49 	u_int8_t        hashsize;	/* Size of the hash */
50 	void           *ctx;	/* Pointer to a context, for HMAC ictx */
51 	unsigned char  *digest;	/* Pointer to a digest */
52 	int             ctxsize;
53 	void           *ctx2;	/* Pointer to a 2nd context, for HMAC octx */
54 	void            (*Init) (void *);
55 	void            (*Update) (void *, unsigned char *, unsigned int);
56 	void            (*Final) (unsigned char *, void *);
57 	void            (*HMACInit) (struct hash *, unsigned char *, unsigned int);
58 	void            (*HMACFinal) (unsigned char *, struct hash *);
59 };
60 
61 /* HMAC Hash Encapsulation */
62 
63 #define HMAC_IPAD_VAL	0x36
64 #define HMAC_OPAD_VAL	0x5C
65 #define HMAC_BLOCKLEN	64
66 
67 extern struct hash *hash_get(enum hashes);
68 extern void     hmac_init(struct hash *, unsigned char *, unsigned int);
69 
70 #endif				/* _HASH_H_ */
71