Home | History | Annotate | Line # | Download | only in opencrypto
gmac.h revision 1.1.2.2
      1 /* $NetBSD: gmac.h,v 1.1.2.2 2011/05/31 03:05:10 rmind Exp $ */
      2 /* OpenBSD: gmac.h,v 1.1 2010/09/22 11:54:23 mikeb Exp */
      3 
      4 /*
      5  * Copyright (c) 2010 Mike Belopuhov <mike (at) vantronix.net>
      6  *
      7  * Permission to use, copy, modify, and distribute this software for any
      8  * purpose with or without fee is hereby granted, provided that the above
      9  * copyright notice and this permission notice appear in all copies.
     10  *
     11  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
     12  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
     13  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
     14  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
     15  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
     16  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
     17  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
     18  */
     19 
     20 #ifndef _GMAC_H_
     21 #define _GMAC_H_
     22 
     23 #include <crypto/rijndael/rijndael.h>
     24 
     25 #define GMAC_BLOCK_LEN		16
     26 #define GMAC_DIGEST_LEN		16
     27 
     28 typedef struct _GHASH_CTX {
     29 	uint32_t	H[GMAC_BLOCK_LEN/4];		/* hash subkey */
     30 	uint32_t	S[GMAC_BLOCK_LEN/4];		/* state */
     31 	uint32_t	Z[GMAC_BLOCK_LEN/4];		/* initial state */
     32 } GHASH_CTX;
     33 
     34 typedef struct _AES_GMAC_CTX {
     35 	GHASH_CTX	ghash;
     36 	uint32_t	K[4*(RIJNDAEL_MAXNR + 1)];
     37 	uint8_t		J[GMAC_BLOCK_LEN];		/* counter block */
     38 	int		rounds;
     39 } AES_GMAC_CTX;
     40 
     41 #include <sys/cdefs.h>
     42 
     43 __BEGIN_DECLS
     44 void	AES_GMAC_Init(AES_GMAC_CTX *);
     45 void	AES_GMAC_Setkey(AES_GMAC_CTX *, const uint8_t *, uint16_t);
     46 void	AES_GMAC_Reinit(AES_GMAC_CTX *, const uint8_t *, uint16_t);
     47 int	AES_GMAC_Update(AES_GMAC_CTX *, const uint8_t *, uint16_t);
     48 void	AES_GMAC_Final(uint8_t [GMAC_DIGEST_LEN], AES_GMAC_CTX *);
     49 __END_DECLS
     50 
     51 #endif /* _GMAC_H_ */
     52