Merge pull request #148 from fsb4000/MultisigDialog
[novacoin.git] / src / scrypt.cpp
1 #include <stdlib.h>
2
3 #include "scrypt.h"
4 #include "pbkdf2.h"
5
6 #include "util.h"
7 #include "net.h"
8
9 #define SCRYPT_BUFFER_SIZE (131072 + 63)
10
11 extern "C" void scrypt_core(uint32_t *X, uint32_t *V);
12
13 /* cpu and memory intensive function to transform a 80 byte buffer into a 32 byte output
14    scratchpad size needs to be at least 63 + (128 * r * p) + (256 * r + 64) + (128 * r * N) bytes
15    r = 1, p = 1, N = 1024
16  */
17
18 uint256 scrypt_blockhash(const uint8_t* input)
19 {
20     uint8_t scratchpad[SCRYPT_BUFFER_SIZE];
21     uint32_t X[32];
22     uint256 result = 0;
23
24     uint32_t *V = (uint32_t *)(((uintptr_t)(scratchpad) + 63) & ~ (uintptr_t)(63));
25
26     PBKDF2_SHA256(input, 80, input, 80, 1, (uint8_t *)X, 128);
27     scrypt_core(X, V);
28     PBKDF2_SHA256(input, 80, (uint8_t *)X, 128, 1, (uint8_t*)&result, 32);
29
30     return result;
31 }