Electroneum
Toggle main menu visibility
Loading...
Searching...
No Matches
blake256.h
Go to the documentation of this file.
1
// Copyrights(c) 2017-2021, The Electroneum Project
2
// Copyrights(c) 2014-2019, The Monero Project
3
//
4
// All rights reserved.
5
//
6
// Redistribution and use in source and binary forms, with or without modification, are
7
// permitted provided that the following conditions are met:
8
//
9
// 1. Redistributions of source code must retain the above copyright notice, this list of
10
// conditions and the following disclaimer.
11
//
12
// 2. Redistributions in binary form must reproduce the above copyright notice, this list
13
// of conditions and the following disclaimer in the documentation and/or other
14
// materials provided with the distribution.
15
//
16
// 3. Neither the name of the copyright holder nor the names of its contributors may be
17
// used to endorse or promote products derived from this software without specific
18
// prior written permission.
19
//
20
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
21
// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
22
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
23
// THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
27
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF
28
// THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
//
30
// Parts of this file are originally copyright (c) 2012-2013 The Cryptonote developers
31
32
#ifndef _BLAKE256_H_
33
#define _BLAKE256_H_
34
35
#include <
stdint.h
>
36
37
typedef
struct
{
38
uint32_t
h
[8],
s
[4],
t
[2];
39
int
buflen
,
nullt
;
40
uint8_t
buf
[64];
41
}
state
;
42
43
typedef
struct
{
44
state
inner
;
45
state
outer
;
46
}
hmac_state
;
47
48
void
blake256_init
(
state
*);
49
void
blake224_init
(
state
*);
50
51
void
blake256_update
(
state
*,
const
uint8_t
*,
uint64_t
);
52
void
blake224_update
(
state
*,
const
uint8_t
*,
uint64_t
);
53
54
void
blake256_final
(
state
*,
uint8_t
*);
55
void
blake224_final
(
state
*,
uint8_t
*);
56
57
void
blake256_hash
(
uint8_t
*,
const
uint8_t
*,
uint64_t
);
58
void
blake224_hash
(
uint8_t
*,
const
uint8_t
*,
uint64_t
);
59
60
/* HMAC functions: */
61
62
void
hmac_blake256_init
(
hmac_state
*,
const
uint8_t
*,
uint64_t
);
63
void
hmac_blake224_init
(
hmac_state
*,
const
uint8_t
*,
uint64_t
);
64
65
void
hmac_blake256_update
(
hmac_state
*,
const
uint8_t
*,
uint64_t
);
66
void
hmac_blake224_update
(
hmac_state
*,
const
uint8_t
*,
uint64_t
);
67
68
void
hmac_blake256_final
(
hmac_state
*,
uint8_t
*);
69
void
hmac_blake224_final
(
hmac_state
*,
uint8_t
*);
70
71
void
hmac_blake256_hash
(
uint8_t
*,
const
uint8_t
*,
uint64_t
,
const
uint8_t
*,
uint64_t
);
72
void
hmac_blake224_hash
(
uint8_t
*,
const
uint8_t
*,
uint64_t
,
const
uint8_t
*,
uint64_t
);
73
74
#endif
/* _BLAKE256_H_ */
blake256_update
void blake256_update(state *, const uint8_t *, uint64_t)
hmac_blake224_final
void hmac_blake224_final(hmac_state *, uint8_t *)
hmac_blake224_init
void hmac_blake224_init(hmac_state *, const uint8_t *, uint64_t)
blake224_final
void blake224_final(state *, uint8_t *)
blake224_init
void blake224_init(state *)
hmac_blake256_init
void hmac_blake256_init(hmac_state *, const uint8_t *, uint64_t)
blake256_init
void blake256_init(state *)
hmac_blake224_update
void hmac_blake224_update(hmac_state *, const uint8_t *, uint64_t)
hmac_blake224_hash
void hmac_blake224_hash(uint8_t *, const uint8_t *, uint64_t, const uint8_t *, uint64_t)
blake224_update
void blake224_update(state *, const uint8_t *, uint64_t)
blake256_final
void blake256_final(state *, uint8_t *)
blake224_hash
void blake224_hash(uint8_t *, const uint8_t *, uint64_t)
hmac_blake256_final
void hmac_blake256_final(hmac_state *, uint8_t *)
blake256_hash
void blake256_hash(uint8_t *, const uint8_t *, uint64_t)
hmac_blake256_hash
void hmac_blake256_hash(uint8_t *, const uint8_t *, uint64_t, const uint8_t *, uint64_t)
hmac_blake256_update
void hmac_blake256_update(hmac_state *, const uint8_t *, uint64_t)
stdint.h
uint32_t
unsigned int uint32_t
Definition
stdint.h:126
uint8_t
unsigned char uint8_t
Definition
stdint.h:124
uint64_t
unsigned __int64 uint64_t
Definition
stdint.h:136
hmac_state
Definition
blake256.h:43
hmac_state::inner
state inner
Definition
blake256.h:44
hmac_state::outer
state outer
Definition
blake256.h:45
state
Definition
blake256.h:37
state::buf
uint8_t buf[64]
Definition
blake256.h:40
state::s
uint32_t s[4]
Definition
blake256.h:38
state::t
uint32_t t[2]
Definition
blake256.h:38
state::buflen
int buflen
Definition
blake256.h:39
state::h
uint32_t h[8]
Definition
blake256.h:38
state::nullt
int nullt
Definition
blake256.h:39
src
crypto
blake256.h
Generated on
for Electroneum by
1.17.0