gcm-aes.c 1.83 KB
Newer Older
Niels Möller's avatar
Niels Möller committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/* gcm_aes.c
 *
 * Galois counter mode using AES as the underlying cipher.
 */

/* nettle, low-level cryptographics library
 *
 * Copyright (C) 2011 Niels Möller
 *
 * The nettle library is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation; either version 2.1 of the License, or (at your
 * option) any later version.
 * 
 * The nettle library is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public
 * License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public License
 * along with the nettle library; see the file COPYING.LIB.  If not, write to
22 23
 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
 * MA 02111-1301, USA.
Niels Möller's avatar
Niels Möller committed
24 25
 */

Niels Möller's avatar
Niels Möller committed
26 27 28 29
#if HAVE_CONFIG_H
# include "config.h"
#endif

Niels Möller's avatar
Niels Möller committed
30 31 32
#include "gcm.h"

void
33
gcm_aes_set_key(struct gcm_aes_ctx *ctx, size_t length, const uint8_t *key)
Niels Möller's avatar
Niels Möller committed
34
{
35
  GCM_SET_KEY(ctx, aes_set_encrypt_key, aes_encrypt, length, key);
Niels Möller's avatar
Niels Möller committed
36 37 38 39
}

void
gcm_aes_set_iv(struct gcm_aes_ctx *ctx,
40
	       size_t length, const uint8_t *iv)
Niels Möller's avatar
Niels Möller committed
41
{
42
  GCM_SET_IV(ctx, length, iv);
Niels Möller's avatar
Niels Möller committed
43 44 45
}

void
46
gcm_aes_update(struct gcm_aes_ctx *ctx, unsigned length, const uint8_t *data)
Niels Möller's avatar
Niels Möller committed
47
{
48
  GCM_UPDATE(ctx, length, data);
Niels Möller's avatar
Niels Möller committed
49 50 51 52
}

void
gcm_aes_encrypt(struct gcm_aes_ctx *ctx,
53
		size_t length, uint8_t *dst, const uint8_t *src)
Niels Möller's avatar
Niels Möller committed
54
{
55
  GCM_ENCRYPT(ctx, aes_encrypt, length, dst, src);
Niels Möller's avatar
Niels Möller committed
56 57 58 59
}

void
gcm_aes_decrypt(struct gcm_aes_ctx *ctx,
60
		size_t length, uint8_t *dst, const uint8_t *src)
Niels Möller's avatar
Niels Möller committed
61
{
62
  GCM_DECRYPT(ctx, aes_encrypt, length, dst, src);
Niels Möller's avatar
Niels Möller committed
63 64 65 66 67 68
}

void
gcm_aes_digest(struct gcm_aes_ctx *ctx,
	       unsigned length, uint8_t *digest)
{
69
  GCM_DIGEST(ctx, aes_encrypt, length, digest);
Niels Möller's avatar
Niels Möller committed
70 71
  
}