create crypto_pow, in preparation for #3795
[oweals/gnunet.git] / src / util / crypto_pow.c
1 /*
2      This file is part of GNUnet.
3      Copyright (C) 2012, 2013, 2019 GNUnet e.V.
4
5      GNUnet is free software: you can redistribute it and/or modify it
6      under the terms of the GNU Affero General Public License as published
7      by the Free Software Foundation, either version 3 of the License,
8      or (at your option) any later version.
9
10      GNUnet is distributed in the hope that it will be useful, but
11      WITHOUT ANY WARRANTY; without even the implied warranty of
12      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13      Affero General Public License for more details.
14
15      You should have received a copy of the GNU Affero General Public License
16      along with this program.  If not, see <http://www.gnu.org/licenses/>.
17
18      SPDX-License-Identifier: AGPL3.0-or-later
19  */
20 /**
21  * @file util/crypto_pow.c
22  * @brief proof-of-work hashing
23  * @author Christian Grothoff
24  * @author Bart Polot
25  */
26
27 #include "platform.h"
28 #include "gnunet_crypto_lib.h"
29 #include <gcrypt.h>
30
31
32 /**
33  * Calculate the 'proof-of-work' hash (an expensive hash).
34  * We're using a non-standard formula to avoid issues with
35  * ASICs appearing (see #3795).
36  *
37  * @param buf data to hash
38  * @param buf_len number of bytes in @a buf
39  * @param result where to write the resulting hash
40  */
41 void
42 GNUNET_CRYPTO_pow_hash (const void *buf, size_t buf_len, struct
43                         GNUNET_HashCode *result)
44 {
45   GNUNET_break (
46     0 == gcry_kdf_derive (buf,
47                           buf_len,
48                           GCRY_KDF_SCRYPT,
49                           1 /* subalgo */,
50                           "gnunet-proof-of-work",
51                           strlen ("gnunet-proof-of-work"),
52                           2 /* iterations; keep cost of individual op small */,
53                           sizeof(struct GNUNET_HashCode),
54                           result));
55 }
56
57
58 /* end of crypto_pow.c */