blob: d946907c675d7afaba0d734ddf9f6c31f8c82ccb [file] [log] [blame]
Dmitry Shmidt40b07202015-01-27 13:40:23 -08001/*
2 * SHA384 hash implementation and interface functions
Dmitry Shmidtd2986c22017-10-23 14:22:09 -07003 * Copyright (c) 2015-2017, Jouni Malinen <j@w1.fi>
Dmitry Shmidt40b07202015-01-27 13:40:23 -08004 *
5 * This software may be distributed under the terms of the BSD license.
6 * See README for more details.
7 */
8
9#ifndef SHA384_H
10#define SHA384_H
11
12#define SHA384_MAC_LEN 48
13
14int hmac_sha384_vector(const u8 *key, size_t key_len, size_t num_elem,
15 const u8 *addr[], const size_t *len, u8 *mac);
16int hmac_sha384(const u8 *key, size_t key_len, const u8 *data,
17 size_t data_len, u8 *mac);
Dmitry Shmidtd2986c22017-10-23 14:22:09 -070018int sha384_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);
20int sha384_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);
Hai Shalomc3565922019-10-28 11:58:20 -070023int tls_prf_sha384(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 Shmidtd2986c22017-10-23 14:22:09 -070026int hmac_sha384_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 Shmidt40b07202015-01-27 13:40:23 -080029
30#endif /* SHA384_H */