Branch data Line data Source code
1 : : // Copyright (c) 2019-2022 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 : 316348 : SaltedTxidHasher::SaltedTxidHasher() :
11 : 316348 : k0{FastRandomContext().rand64()},
12 : 316348 : k1{FastRandomContext().rand64()} {}
13 : :
14 : 765786 : SaltedOutpointHasher::SaltedOutpointHasher(bool deterministic) :
15 [ - + ]: 765786 : k0{deterministic ? 0x8e819f2607a18de6 : FastRandomContext().rand64()},
16 [ + - ]: 765786 : k1{deterministic ? 0xf4020d2e3983b0eb : FastRandomContext().rand64()}
17 : 765786 : {}
18 : :
19 : 1581 : SaltedSipHasher::SaltedSipHasher() :
20 : 1581 : m_k0{FastRandomContext().rand64()},
21 : 1581 : m_k1{FastRandomContext().rand64()} {}
22 : :
23 : 2088547 : size_t SaltedSipHasher::operator()(const Span<const unsigned char>& script) const
24 : : {
25 : 2088547 : return CSipHasher(m_k0, m_k1).Write(script).Finalize();
26 : : }
|