blob: 9364f79937b814d27f1f49d9c113048263cb322b [file] [log] [blame]
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +01001// SPDX-License-Identifier: GPL-2.0 OR MIT
2/*
3 * Copyright (C) 2015-2019 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
4 *
5 * This is an implementation of the BLAKE2s hash and PRF functions.
6 *
7 * Information: https://blake2.net/
8 *
9 */
10
11#include <crypto/internal/blake2s.h>
12#include <linux/types.h>
13#include <linux/string.h>
14#include <linux/kernel.h>
15#include <linux/module.h>
16#include <linux/init.h>
17#include <linux/bug.h>
Eric Biggers057edc92020-12-23 00:09:53 -080018
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +010019void blake2s_update(struct blake2s_state *state, const u8 *in, size_t inlen)
20{
Eric Biggers057edc92020-12-23 00:09:53 -080021 __blake2s_update(state, in, inlen, blake2s_compress);
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +010022}
23EXPORT_SYMBOL(blake2s_update);
24
25void blake2s_final(struct blake2s_state *state, u8 *out)
26{
27 WARN_ON(IS_ENABLED(DEBUG) && !out);
Eric Biggers057edc92020-12-23 00:09:53 -080028 __blake2s_final(state, out, blake2s_compress);
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +010029 memzero_explicit(state, sizeof(*state));
30}
31EXPORT_SYMBOL(blake2s_final);
32
Randy Dunlapf03a3ca2021-07-11 15:31:45 -070033static int __init blake2s_mod_init(void)
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +010034{
35 if (!IS_ENABLED(CONFIG_CRYPTO_MANAGER_DISABLE_TESTS) &&
36 WARN_ON(!blake2s_selftest()))
37 return -ENODEV;
38 return 0;
39}
40
Randy Dunlapf03a3ca2021-07-11 15:31:45 -070041static void __exit blake2s_mod_exit(void)
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +010042{
43}
44
Randy Dunlapf03a3ca2021-07-11 15:31:45 -070045module_init(blake2s_mod_init);
46module_exit(blake2s_mod_exit);
Jason A. Donenfeld66d7fb92019-11-08 13:22:28 +010047MODULE_LICENSE("GPL v2");
48MODULE_DESCRIPTION("BLAKE2s hash function");
49MODULE_AUTHOR("Jason A. Donenfeld <Jason@zx2c4.com>");