]> Git Repo - cpuminer-multi.git/blob - lyra2/Lyra2.h
update build.sh
[cpuminer-multi.git] / lyra2 / Lyra2.h
1 /**
2  * Header file for the Lyra2 Password Hashing Scheme (PHS).
3  *
4  * Author: The Lyra PHC team (http://www.lyra-kdf.net/) -- 2014.
5  *
6  * This software is hereby placed in the public domain.
7  *
8  * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ''AS IS'' AND ANY EXPRESS
9  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
10  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
11  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE
12  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
13  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
14  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
15  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
16  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
17  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
18  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
19  */
20 #ifndef LYRA2_H_
21 #define LYRA2_H_
22
23 #include <stdint.h>
24
25 typedef unsigned char byte;
26
27 //Block length required so Blake2's Initialization Vector (IV) is not overwritten (THIS SHOULD NOT BE MODIFIED)
28 #define BLOCK_LEN_BLAKE2_SAFE_INT64 8                                   //512 bits (=64 bytes, =8 uint64_t)
29 #define BLOCK_LEN_BLAKE2_SAFE_BYTES (BLOCK_LEN_BLAKE2_SAFE_INT64 * 8)   //same as above, in bytes
30
31
32 #ifdef BLOCK_LEN_BITS
33         #define BLOCK_LEN_INT64 (BLOCK_LEN_BITS/64)      //Block length: 768 bits (=96 bytes, =12 uint64_t)
34         #define BLOCK_LEN_BYTES (BLOCK_LEN_BITS/8)       //Block length, in bytes
35 #else   //default block lenght: 768 bits
36         #define BLOCK_LEN_INT64 12                       //Block length: 768 bits (=96 bytes, =12 uint64_t)
37         #define BLOCK_LEN_BYTES (BLOCK_LEN_INT64 * 8)    //Block length, in bytes
38 #endif
39
40 int LYRA2(void *K, int64_t kLen, const void *pwd, int32_t pwdlen, const void *salt, int32_t saltlen, int64_t timeCost, const int16_t nRows, const int16_t nCols);
41
42 int LYRA2_3(void *K, int64_t kLen, const void *pwd, int32_t pwdlen, const void *salt, int32_t saltlen, int64_t timeCost, const int16_t nRows, const int16_t nCols);
43
44 #endif /* LYRA2_H_ */
This page took 0.02723 seconds and 4 git commands to generate.