Bitcoin Core Fuzz Coverage Report for wallet_tx_can_be_bumped

Coverage Report

Created: 2025-11-19 11:20

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/Users/brunogarcia/projects/bitcoin-core-dev/src/hash.h
Line
Count
Source
1
// Copyright (c) 2009-2010 Satoshi Nakamoto
2
// Copyright (c) 2009-present The Bitcoin Core developers
3
// Distributed under the MIT software license, see the accompanying
4
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
5
6
#ifndef BITCOIN_HASH_H
7
#define BITCOIN_HASH_H
8
9
#include <attributes.h>
10
#include <crypto/common.h>
11
#include <crypto/ripemd160.h>
12
#include <crypto/sha256.h>
13
#include <prevector.h>
14
#include <serialize.h>
15
#include <span.h>
16
#include <uint256.h>
17
18
#include <string>
19
#include <vector>
20
21
typedef uint256 ChainCode;
22
23
/** A hasher class for Bitcoin's 256-bit hash (double SHA-256). */
24
class CHash256 {
25
private:
26
    CSHA256 sha;
27
public:
28
    static const size_t OUTPUT_SIZE = CSHA256::OUTPUT_SIZE;
29
30
501k
    void Finalize(std::span<unsigned char> output) {
31
501k
        assert(output.size() == OUTPUT_SIZE);
32
501k
        unsigned char buf[CSHA256::OUTPUT_SIZE];
33
501k
        sha.Finalize(buf);
34
501k
        sha.Reset().Write(buf, CSHA256::OUTPUT_SIZE).Finalize(output.data());
35
501k
    }
36
37
501k
    CHash256& Write(std::span<const unsigned char> input) {
38
501k
        sha.Write(input.data(), input.size());
39
501k
        return *this;
40
501k
    }
41
42
0
    CHash256& Reset() {
43
0
        sha.Reset();
44
0
        return *this;
45
0
    }
46
};
47
48
/** A hasher class for Bitcoin's 160-bit hash (SHA-256 + RIPEMD-160). */
49
class CHash160 {
50
private:
51
    CSHA256 sha;
52
public:
53
    static const size_t OUTPUT_SIZE = CRIPEMD160::OUTPUT_SIZE;
54
55
1.15M
    void Finalize(std::span<unsigned char> output) {
56
1.15M
        assert(output.size() == OUTPUT_SIZE);
57
1.15M
        unsigned char buf[CSHA256::OUTPUT_SIZE];
58
1.15M
        sha.Finalize(buf);
59
1.15M
        CRIPEMD160().Write(buf, CSHA256::OUTPUT_SIZE).Finalize(output.data());
60
1.15M
    }
61
62
1.15M
    CHash160& Write(std::span<const unsigned char> input) {
63
1.15M
        sha.Write(input.data(), input.size());
64
1.15M
        return *this;
65
1.15M
    }
66
67
0
    CHash160& Reset() {
68
0
        sha.Reset();
69
0
        return *this;
70
0
    }
71
};
72
73
/** Compute the 256-bit hash of an object. */
74
template<typename T>
75
inline uint256 Hash(const T& in1)
76
501k
{
77
501k
    uint256 result;
78
501k
    CHash256().Write(MakeUCharSpan(in1)).Finalize(result);
79
501k
    return result;
80
501k
}
Unexecuted instantiation: uint256 Hash<std::__1::span<unsigned char const, 18446744073709551615ul>>(std::__1::span<unsigned char const, 18446744073709551615ul> const&)
uint256 Hash<std::__1::vector<unsigned char, std::__1::allocator<unsigned char>>>(std::__1::vector<unsigned char, std::__1::allocator<unsigned char>> const&)
Line
Count
Source
76
343k
{
77
343k
    uint256 result;
78
343k
    CHash256().Write(MakeUCharSpan(in1)).Finalize(result);
79
343k
    return result;
80
343k
}
uint256 Hash<std::__1::span<unsigned char, 18446744073709551615ul>>(std::__1::span<unsigned char, 18446744073709551615ul> const&)
Line
Count
Source
76
158k
{
77
158k
    uint256 result;
78
158k
    CHash256().Write(MakeUCharSpan(in1)).Finalize(result);
79
158k
    return result;
80
158k
}
81
82
/** Compute the 256-bit hash of the concatenation of two objects. */
83
template<typename T1, typename T2>
84
0
inline uint256 Hash(const T1& in1, const T2& in2) {
85
0
    uint256 result;
86
0
    CHash256().Write(MakeUCharSpan(in1)).Write(MakeUCharSpan(in2)).Finalize(result);
87
0
    return result;
88
0
}
Unexecuted instantiation: uint256 Hash<uint256, uint256>(uint256 const&, uint256 const&)
Unexecuted instantiation: uint256 Hash<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>, unsigned char [8]>(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const&, unsigned char const (&) [8])
89
90
/** Compute the 160-bit hash an object. */
91
template<typename T1>
92
inline uint160 Hash160(const T1& in1)
93
1.15M
{
94
1.15M
    uint160 result;
95
1.15M
    CHash160().Write(MakeUCharSpan(in1)).Finalize(result);
96
1.15M
    return result;
97
1.15M
}
uint160 Hash160<std::__1::span<unsigned char const, 18446744073709551615ul>>(std::__1::span<unsigned char const, 18446744073709551615ul> const&)
Line
Count
Source
93
1.10M
{
94
1.10M
    uint160 result;
95
1.10M
    CHash160().Write(MakeUCharSpan(in1)).Finalize(result);
96
1.10M
    return result;
97
1.10M
}
Unexecuted instantiation: uint160 Hash160<std::__1::vector<unsigned char, std::__1::allocator<unsigned char>>>(std::__1::vector<unsigned char, std::__1::allocator<unsigned char>> const&)
Unexecuted instantiation: uint160 Hash160<XOnlyPubKey>(XOnlyPubKey const&)
Unexecuted instantiation: uint160 Hash160<CPubKey>(CPubKey const&)
uint160 Hash160<CScript>(CScript const&)
Line
Count
Source
93
49.2k
{
94
49.2k
    uint160 result;
95
49.2k
    CHash160().Write(MakeUCharSpan(in1)).Finalize(result);
96
49.2k
    return result;
97
49.2k
}
98
99
/** A writer stream (for serialization) that computes a 256-bit hash. */
100
class HashWriter
101
{
102
private:
103
    CSHA256 ctx;
104
105
public:
106
    void write(std::span<const std::byte> src)
107
1.76M
    {
108
1.76M
        ctx.Write(UCharCast(src.data()), src.size());
109
1.76M
    }
110
111
    /** Compute the double-SHA256 hash of all data written to this object.
112
     *
113
     * Invalidates this object.
114
     */
115
61.0k
    uint256 GetHash() {
116
61.0k
        uint256 result;
117
61.0k
        ctx.Finalize(result.begin());
118
61.0k
        ctx.Reset().Write(result.begin(), CSHA256::OUTPUT_SIZE).Finalize(result.begin());
119
61.0k
        return result;
120
61.0k
    }
121
122
    /** Compute the SHA256 hash of all data written to this object.
123
     *
124
     * Invalidates this object.
125
     */
126
24.5k
    uint256 GetSHA256() {
127
24.5k
        uint256 result;
128
24.5k
        ctx.Finalize(result.begin());
129
24.5k
        return result;
130
24.5k
    }
131
132
    /**
133
     * Returns the first 64 bits from the resulting hash.
134
     */
135
0
    inline uint64_t GetCheapHash() {
136
0
        uint256 result = GetHash();
137
0
        return ReadLE64(result.begin());
138
0
    }
139
140
    template <typename T>
141
    HashWriter& operator<<(const T& obj)
142
110k
    {
143
110k
        ::Serialize(*this, obj);
144
110k
        return *this;
145
110k
    }
Unexecuted instantiation: HashWriter& HashWriter::operator<<<unsigned int>(unsigned int const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>>>(std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char>> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<std::__1::vector<unsigned char, std::__1::allocator<unsigned char>>>(std::__1::vector<unsigned char, std::__1::allocator<unsigned char>> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<CPubKey>(CPubKey const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<std::__1::span<unsigned char const, 18446744073709551615ul>>(std::__1::span<unsigned char const, 18446744073709551615ul> const&)
HashWriter& HashWriter::operator<<<uint256>(uint256 const&)
Line
Count
Source
142
24.5k
    {
143
24.5k
        ::Serialize(*this, obj);
144
24.5k
        return *this;
145
24.5k
    }
HashWriter& HashWriter::operator<<<std::__1::span<unsigned char const, 32ul>>(std::__1::span<unsigned char const, 32ul> const&)
Line
Count
Source
142
24.5k
    {
143
24.5k
        ::Serialize(*this, obj);
144
24.5k
        return *this;
145
24.5k
    }
Unexecuted instantiation: HashWriter& HashWriter::operator<<<std::__1::span<char, 18446744073709551615ul>>(std::__1::span<char, 18446744073709551615ul> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<unsigned long long>(unsigned long long const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<unsigned char>(unsigned char const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<int>(int const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<std::__1::vector<bool, std::__1::allocator<bool>>>(std::__1::vector<bool, std::__1::allocator<bool>> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<COutPoint>(COutPoint const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<CTxOut>(CTxOut const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<CBlockUndo>(CBlockUndo const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned long long&>>(Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned long long&> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<std::__1::span<unsigned char, 18446744073709551615ul>>(std::__1::span<unsigned char, 18446744073709551615ul> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned int&>>(Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned int&> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<transaction_identifier<true>>(transaction_identifier<true> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<CBlockHeader>(CBlockHeader const&)
HashWriter& HashWriter::operator<<<ParamsWrapper<TransactionSerParams, CMutableTransaction const>>(ParamsWrapper<TransactionSerParams, CMutableTransaction const> const&)
Line
Count
Source
142
7.88k
    {
143
7.88k
        ::Serialize(*this, obj);
144
7.88k
        return *this;
145
7.88k
    }
HashWriter& HashWriter::operator<<<ParamsWrapper<TransactionSerParams, CTransaction const>>(ParamsWrapper<TransactionSerParams, CTransaction const> const&)
Line
Count
Source
142
53.1k
    {
143
53.1k
        ::Serialize(*this, obj);
144
53.1k
        return *this;
145
53.1k
    }
Unexecuted instantiation: HashWriter& HashWriter::operator<<<long long>(long long const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<CScript>(CScript const&)
Unexecuted instantiation: interpreter.cpp:HashWriter& HashWriter::operator<<<(anonymous namespace)::CTransactionSignatureSerializer<CTransaction>>((anonymous namespace)::CTransactionSignatureSerializer<CTransaction> const&)
Unexecuted instantiation: interpreter.cpp:HashWriter& HashWriter::operator<<<(anonymous namespace)::CTransactionSignatureSerializer<CMutableTransaction>>((anonymous namespace)::CTransactionSignatureSerializer<CMutableTransaction> const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<CompactSizeWriter>(CompactSizeWriter const&)
Unexecuted instantiation: HashWriter& HashWriter::operator<<<unsigned char [384]>(unsigned char const (&) [384])
146
};
147
148
/** Reads data from an underlying stream, while hashing the read data. */
149
template <typename Source>
150
class HashVerifier : public HashWriter
151
{
152
private:
153
    Source& m_source;
154
155
public:
156
0
    explicit HashVerifier(Source& source LIFETIMEBOUND) : m_source{source} {}
Unexecuted instantiation: HashVerifier<DataStream>::HashVerifier(DataStream&)
Unexecuted instantiation: HashVerifier<AutoFile>::HashVerifier(AutoFile&)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>::HashVerifier(BufferedReader<AutoFile>&)
157
158
    void read(std::span<std::byte> dst)
159
0
    {
160
0
        m_source.read(dst);
161
0
        this->write(dst);
162
0
    }
Unexecuted instantiation: HashVerifier<DataStream>::read(std::__1::span<std::byte, 18446744073709551615ul>)
Unexecuted instantiation: HashVerifier<AutoFile>::read(std::__1::span<std::byte, 18446744073709551615ul>)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>::read(std::__1::span<std::byte, 18446744073709551615ul>)
163
164
    void ignore(size_t num_bytes)
165
0
    {
166
0
        std::byte data[1024];
167
0
        while (num_bytes > 0) {
168
0
            size_t now = std::min<size_t>(num_bytes, 1024);
169
0
            read({data, now});
170
0
            num_bytes -= now;
171
0
        }
172
0
    }
Unexecuted instantiation: HashVerifier<AutoFile>::ignore(unsigned long)
Unexecuted instantiation: HashVerifier<DataStream>::ignore(unsigned long)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>::ignore(unsigned long)
173
174
    template <typename T>
175
    HashVerifier<Source>& operator>>(T&& obj)
176
0
    {
177
0
        ::Unserialize(*this, obj);
178
0
        return *this;
179
0
    }
Unexecuted instantiation: HashVerifier<DataStream>& HashVerifier<DataStream>::operator>><std::__1::array<unsigned char, 4ul>&>(std::__1::array<unsigned char, 4ul>&)
Unexecuted instantiation: HashVerifier<DataStream>& HashVerifier<DataStream>::operator>><AddrMan&>(AddrMan&)
Unexecuted instantiation: HashVerifier<AutoFile>& HashVerifier<AutoFile>::operator>><std::__1::array<unsigned char, 4ul>&>(std::__1::array<unsigned char, 4ul>&)
Unexecuted instantiation: HashVerifier<AutoFile>& HashVerifier<AutoFile>::operator>><AddrMan&>(AddrMan&)
Unexecuted instantiation: HashVerifier<AutoFile>& HashVerifier<AutoFile>::operator>><ParamsWrapper<CAddress::SerParams, std::__1::vector<CAddress, std::__1::allocator<CAddress>>>&>(ParamsWrapper<CAddress::SerParams, std::__1::vector<CAddress, std::__1::allocator<CAddress>>>&)
Unexecuted instantiation: HashVerifier<AutoFile>& HashVerifier<AutoFile>::operator>><Wrapper<CustomUintFormatter<1, false>, AddrManImpl::Format&>>(Wrapper<CustomUintFormatter<1, false>, AddrManImpl::Format&>&&)
Unexecuted instantiation: HashVerifier<DataStream>& HashVerifier<DataStream>::operator>><Wrapper<CustomUintFormatter<1, false>, AddrManImpl::Format&>>(Wrapper<CustomUintFormatter<1, false>, AddrManImpl::Format&>&&)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>& HashVerifier<BufferedReader<AutoFile>>::operator>><CBlockUndo&>(CBlockUndo&)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>& HashVerifier<BufferedReader<AutoFile>>::operator>><Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned long long&>>(Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned long long&>&&)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>& HashVerifier<BufferedReader<AutoFile>>::operator>><Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned int&>>(Wrapper<VarIntFormatter<(VarIntMode)0>, unsigned int&>&&)
Unexecuted instantiation: HashVerifier<BufferedReader<AutoFile>>& HashVerifier<BufferedReader<AutoFile>>::operator>><std::__1::span<unsigned char, 18446744073709551615ul>>(std::__1::span<unsigned char, 18446744073709551615ul>&&)
180
};
181
182
/** Writes data to an underlying source stream, while hashing the written data. */
183
template <typename Source>
184
class HashedSourceWriter : public HashWriter
185
{
186
private:
187
    Source& m_source;
188
189
public:
190
0
    explicit HashedSourceWriter(Source& source LIFETIMEBOUND) : HashWriter{}, m_source{source} {}
191
192
    void write(std::span<const std::byte> src)
193
0
    {
194
0
        m_source.write(src);
195
0
        HashWriter::write(src);
196
0
    }
197
198
    template <typename T>
199
    HashedSourceWriter& operator<<(const T& obj)
200
0
    {
201
0
        ::Serialize(*this, obj);
202
0
        return *this;
203
0
    }
Unexecuted instantiation: HashedSourceWriter<AutoFile>& HashedSourceWriter<AutoFile>::operator<<<std::__1::array<unsigned char, 4ul>>(std::__1::array<unsigned char, 4ul> const&)
Unexecuted instantiation: HashedSourceWriter<AutoFile>& HashedSourceWriter<AutoFile>::operator<<<AddrMan>(AddrMan const&)
Unexecuted instantiation: HashedSourceWriter<AutoFile>& HashedSourceWriter<AutoFile>::operator<<<ParamsWrapper<CAddress::SerParams, std::__1::vector<CAddress, std::__1::allocator<CAddress>> const>>(ParamsWrapper<CAddress::SerParams, std::__1::vector<CAddress, std::__1::allocator<CAddress>> const> const&)
204
};
205
206
/** Single-SHA256 a 32-byte input (represented as uint256). */
207
[[nodiscard]] uint256 SHA256Uint256(const uint256& input);
208
209
unsigned int MurmurHash3(unsigned int nHashSeed, std::span<const unsigned char> vDataToHash);
210
211
void BIP32Hash(const ChainCode &chainCode, unsigned int nChild, unsigned char header, const unsigned char data[32], unsigned char output[64]);
212
213
/** Return a HashWriter primed for tagged hashes (as specified in BIP 340).
214
 *
215
 * The returned object will have SHA256(tag) written to it twice (= 64 bytes).
216
 * A tagged hash can be computed by feeding the message into this object, and
217
 * then calling HashWriter::GetSHA256().
218
 */
219
HashWriter TaggedHash(const std::string& tag);
220
221
/** Compute the 160-bit RIPEMD-160 hash of an array. */
222
inline uint160 RIPEMD160(std::span<const unsigned char> data)
223
0
{
224
0
    uint160 result;
225
0
    CRIPEMD160().Write(data.data(), data.size()).Finalize(result.begin());
226
0
    return result;
227
0
}
228
229
#endif // BITCOIN_HASH_H