blob: b15f51158f3262e6fac9e564f3ac05869ae06d6e [file] [log] [blame]
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07001/*
2 * SHA256 hash implementation and interface functions
Dmitry Shmidtfb45fd52015-01-05 13:08:17 -08003 * Copyright (c) 2003-2014, Jouni Malinen <j@w1.fi>
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07004 *
Dmitry Shmidtc5ec7f52012-03-06 16:33:24 -08005 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -07007 */
8
9#ifndef SHA256_H
10#define SHA256_H
11
12#define SHA256_MAC_LEN 32
13
Dmitry Shmidt61d9df32012-08-29 16:22:06 -070014int hmac_sha256_vector(const u8 *key, size_t key_len, size_t num_elem,
15 const u8 *addr[], const size_t *len, u8 *mac);
16int hmac_sha256(const u8 *key, size_t key_len, const u8 *data,
17 size_t data_len, u8 *mac);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070018void sha256_prf(const u8 *key, size_t key_len, const char *label,
19 const u8 *data, size_t data_len, u8 *buf, size_t buf_len);
Dmitry Shmidta54fa5f2013-01-15 13:53:35 -080020void sha256_prf_bits(const u8 *key, size_t key_len, const char *label,
21 const u8 *data, size_t data_len, u8 *buf,
22 size_t buf_len_bits);
Dmitry Shmidt1f69aa52012-01-24 16:10:04 -080023void tls_prf_sha256(const u8 *secret, size_t secret_len,
24 const char *label, const u8 *seed, size_t seed_len,
25 u8 *out, size_t outlen);
Dmitry Shmidtfb45fd52015-01-05 13:08:17 -080026int hmac_sha256_kdf(const u8 *secret, size_t secret_len,
27 const char *label, const u8 *seed, size_t seed_len,
28 u8 *out, size_t outlen);
Dmitry Shmidt8d520ff2011-05-09 14:06:53 -070029
30#endif /* SHA256_H */