Branch data Line data Source code
1 : : // Copyright (c) 2019-present The Bitcoin Core developers
2 : : // Distributed under the MIT software license, see the accompanying
3 : : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
4 : :
5 : : #include <util/hasher.h>
6 : :
7 : : #include <crypto/siphash.h>
8 : : #include <random.h>
9 : :
10 : 1908 : SaltedUint256Hasher::SaltedUint256Hasher() : m_hasher{
11 : 954 : FastRandomContext().rand64(),
12 : 1908 : FastRandomContext().rand64()}
13 : 954 : {}
14 : :
15 : 11072140 : SaltedTxidHasher::SaltedTxidHasher() : m_hasher{
16 : 5536070 : FastRandomContext().rand64(),
17 : 11072140 : FastRandomContext().rand64()}
18 : 5536070 : {}
19 : :
20 : 7540542 : SaltedWtxidHasher::SaltedWtxidHasher() : m_hasher{
21 : 3770271 : FastRandomContext().rand64(),
22 : 7540542 : FastRandomContext().rand64()}
23 : 3770271 : {}
24 : :
25 [ + + ]: 13939976 : SaltedOutpointHasher::SaltedOutpointHasher(bool deterministic) : m_hasher{
26 [ + + ]: 33202092 : deterministic ? 0x8e819f2607a18de6 : FastRandomContext().rand64(),
27 [ + + ]: 23571034 : deterministic ? 0xf4020d2e3983b0eb : FastRandomContext().rand64()}
28 : 13939976 : {}
29 : :
30 : 37039 : SaltedSipHasher::SaltedSipHasher() :
31 : 37039 : m_k0{FastRandomContext().rand64()},
32 : 37039 : m_k1{FastRandomContext().rand64()}
33 : 37039 : {}
34 : :
35 : 557952 : size_t SaltedSipHasher::operator()(const std::span<const unsigned char>& script) const
36 : : {
37 : 557952 : return CSipHasher(m_k0, m_k1).Write(script).Finalize();
38 : : }
|