Coverage Report

Created: 2024-08-21 05:08

/workdir/bitcoin/src/txdb.h
Line
Count
Source (jump to first uncovered line)
1
// Copyright (c) 2009-2010 Satoshi Nakamoto
2
// Copyright (c) 2009-2022 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_TXDB_H
7
#define BITCOIN_TXDB_H
8
9
#include <coins.h>
10
#include <dbwrapper.h>
11
#include <kernel/cs_main.h>
12
#include <sync.h>
13
#include <util/fs.h>
14
15
#include <cstddef>
16
#include <cstdint>
17
#include <memory>
18
#include <optional>
19
#include <vector>
20
21
class COutPoint;
22
class uint256;
23
24
//! -dbcache default (MiB)
25
static const int64_t nDefaultDbCache = 450;
26
//! -dbbatchsize default (bytes)
27
static const int64_t nDefaultDbBatchSize = 16 << 20;
28
//! max. -dbcache (MiB)
29
static const int64_t nMaxDbCache = sizeof(void*) > 4 ? 16384 : 1024;
30
//! min. -dbcache (MiB)
31
static const int64_t nMinDbCache = 4;
32
//! Max memory allocated to block tree DB specific cache, if no -txindex (MiB)
33
static const int64_t nMaxBlockDBCache = 2;
34
//! Max memory allocated to block tree DB specific cache, if -txindex (MiB)
35
// Unlike for the UTXO database, for the txindex scenario the leveldb cache make
36
// a meaningful difference: https://github.com/bitcoin/bitcoin/pull/8273#issuecomment-229601991
37
static const int64_t nMaxTxIndexCache = 1024;
38
//! Max memory allocated to all block filter index caches combined in MiB.
39
static const int64_t max_filter_index_cache = 1024;
40
//! Max memory allocated to coin DB specific cache (MiB)
41
static const int64_t nMaxCoinsDBCache = 8;
42
43
//! User-controlled performance and debug options.
44
struct CoinsViewOptions {
45
    //! Maximum database write batch size in bytes.
46
    size_t batch_write_bytes = nDefaultDbBatchSize;
47
    //! If non-zero, randomly exit when the database is flushed with (1/ratio)
48
    //! probability.
49
    int simulate_crash_ratio = 0;
50
};
51
52
/** CCoinsView backed by the coin database (chainstate/) */
53
class CCoinsViewDB final : public CCoinsView
54
{
55
protected:
56
    DBParams m_db_params;
57
    CoinsViewOptions m_options;
58
    std::unique_ptr<CDBWrapper> m_db;
59
public:
60
    explicit CCoinsViewDB(DBParams db_params, CoinsViewOptions options);
61
62
    bool GetCoin(const COutPoint &outpoint, Coin &coin) const override;
63
    bool HaveCoin(const COutPoint &outpoint) const override;
64
    uint256 GetBestBlock() const override;
65
    std::vector<uint256> GetHeadBlocks() const override;
66
    bool BatchWrite(CoinsViewCacheCursor& cursor, const uint256 &hashBlock) override;
67
    std::unique_ptr<CCoinsViewCursor> Cursor() const override;
68
69
    //! Whether an unsupported database format is used.
70
    bool NeedsUpgrade();
71
    size_t EstimateSize() const override;
72
73
    //! Dynamically alter the underlying leveldb cache size.
74
    void ResizeCache(size_t new_cache_size) EXCLUSIVE_LOCKS_REQUIRED(cs_main);
75
76
    //! @returns filesystem path to on-disk storage or std::nullopt if in memory.
77
0
    std::optional<fs::path> StoragePath() { return m_db->StoragePath(); }
78
};
79
80
#endif // BITCOIN_TXDB_H