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 <crypto/siphash.h>
6 : : #include <random.h>
7 : : #include <span.h>
8 : : #include <util/hasher.h>
9 : :
10 : 8 : SaltedUint256Hasher::SaltedUint256Hasher() : m_hasher{
11 : 4 : FastRandomContext().rand64(),
12 : 8 : FastRandomContext().rand64()}
13 : 4 : {}
14 : :
15 : 70390 : SaltedTxidHasher::SaltedTxidHasher() : m_hasher{
16 : 35195 : FastRandomContext().rand64(),
17 : 70390 : FastRandomContext().rand64()}
18 : 35195 : {}
19 : :
20 : 53848 : SaltedWtxidHasher::SaltedWtxidHasher() : m_hasher{
21 : 26924 : FastRandomContext().rand64(),
22 : 53848 : FastRandomContext().rand64()}
23 : 26924 : {}
24 : :
25 [ + - ]: 167744 : SaltedOutpointHasher::SaltedOutpointHasher(bool deterministic) : m_hasher{
26 [ - + ]: 503232 : deterministic ? 0x8e819f2607a18de6 : FastRandomContext().rand64(),
27 [ + - ]: 335488 : deterministic ? 0xf4020d2e3983b0eb : FastRandomContext().rand64()}
28 : 167744 : {}
29 : :
30 : 109 : SaltedSipHasher::SaltedSipHasher() :
31 : 109 : m_k0{FastRandomContext().rand64()},
32 : 109 : m_k1{FastRandomContext().rand64()}
33 : 109 : {}
34 : :
35 : 403511 : size_t SaltedSipHasher::operator()(const std::span<const unsigned char>& script) const
36 : : {
37 : 403511 : return CSipHasher(m_k0, m_k1).Write(script).Finalize();
38 : : }
|