Bitcoin Core  31.0.0
P2P Digital Currency
kernel_notifications.h
Go to the documentation of this file.
1 // Copyright (c) 2023-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 #ifndef BITCOIN_NODE_KERNEL_NOTIFICATIONS_H
6 #define BITCOIN_NODE_KERNEL_NOTIFICATIONS_H
7 
9 
10 #include <sync.h>
11 #include <threadsafety.h>
12 #include <uint256.h>
13 
14 #include <atomic>
15 #include <cstdint>
16 #include <functional>
17 
18 class ArgsManager;
19 class CBlockIndex;
20 enum class SynchronizationState;
21 struct bilingual_str;
22 
23 namespace kernel {
24 enum class Warning;
25 } // namespace kernel
26 
27 namespace node {
28 
29 class Warnings;
30 static constexpr int DEFAULT_STOPATHEIGHT{0};
31 
39 struct KernelState {
40  bool chainstate_loaded{false};
41  std::optional<uint256> tip_block;
42 };
43 
45 {
46 public:
47  KernelNotifications(const std::function<bool()>& shutdown_request, std::atomic<int>& exit_status, node::Warnings& warnings)
48  : m_shutdown_request(shutdown_request), m_exit_status{exit_status}, m_warnings{warnings} {}
49 
50  [[nodiscard]] kernel::InterruptResult blockTip(SynchronizationState state, const CBlockIndex& index, double verification_progress) override EXCLUSIVE_LOCKS_REQUIRED(!m_tip_block_mutex);
51 
52  void headerTip(SynchronizationState state, int64_t height, int64_t timestamp, bool presync) override;
53 
54  void progress(const bilingual_str& title, int progress_percent, bool resume_possible) override;
55 
56  void warningSet(kernel::Warning id, const bilingual_str& message) override;
57 
58  void warningUnset(kernel::Warning id) override;
59 
60  void flushError(const bilingual_str& message) override;
61 
62  void fatalError(const bilingual_str& message) override;
63 
66  if (!chainstate_loaded) m_state = {};
67  m_state.chainstate_loaded = chainstate_loaded;
68  m_tip_block_cv.notify_all();
69  }
70 
75 
77  std::condition_variable m_tip_block_cv GUARDED_BY(m_tip_block_mutex);
82  std::optional<uint256> TipBlock() EXCLUSIVE_LOCKS_REQUIRED(m_tip_block_mutex);
83 
84 private:
85  const std::function<bool()>& m_shutdown_request;
86  std::atomic<int>& m_exit_status;
88 };
89 
90 void ReadNotificationArgs(const ArgsManager& args, KernelNotifications& notifications);
91 
92 } // namespace node
93 
94 #endif // BITCOIN_NODE_KERNEL_NOTIFICATIONS_H
std::optional< uint256 > TipBlock() EXCLUSIVE_LOCKS_REQUIRED(m_tip_block_mutex)
The block for which the last blockTip notification was received.
void ReadNotificationArgs(const ArgsManager &args, KernelNotifications &notifications)
SynchronizationState
Current sync state passed to tip changed callbacks.
Definition: validation.h:93
Bilingual messages:
Definition: translation.h:24
KernelNotifications(const std::function< bool()> &shutdown_request, std::atomic< int > &exit_status, node::Warnings &warnings)
Manages warning messages within a node.
Definition: warnings.h:39
kernel::InterruptResult blockTip(SynchronizationState state, const CBlockIndex &index, double verification_progress) override EXCLUSIVE_LOCKS_REQUIRED(!m_tip_block_mutex)
std::variant< std::monostate, Interrupted > InterruptResult
Simple result type for functions that need to propagate an interrupt status and don&#39;t have other retu...
static constexpr int DEFAULT_STOPATHEIGHT
const std::function< bool()> & m_shutdown_request
void progress(const bilingual_str &title, int progress_percent, bool resume_possible) override
Definition: common.h:29
Warning
Definition: warning.h:9
void flushError(const bilingual_str &message) override
The flush error notification is sent to notify the user that an error occurred while flushing block d...
void warningUnset(kernel::Warning id) override
State tracked by the KernelNotifications interface meant to be used by mining code, index code, RPCs, and other code sitting above the validation layer.
ArgsManager & args
Definition: bitcoind.cpp:277
void fatalError(const bilingual_str &message) override
The fatal error notification is sent to notify the user when an error occurs in kernel code that can&#39;...
#define LOCK(cs)
Definition: sync.h:258
void warningSet(kernel::Warning id, const bilingual_str &message) override
A base class defining functions for notifying about certain kernel events.
std::optional< uint256 > tip_block
Definition: messages.h:21
#define EXCLUSIVE_LOCKS_REQUIRED(...)
Definition: threadsafety.h:51
std::condition_variable m_tip_block_cv GUARDED_BY(m_tip_block_mutex)
void headerTip(SynchronizationState state, int64_t height, int64_t timestamp, bool presync) override
The block chain is a tree shaped structure starting with the genesis block at the root...
Definition: chain.h:93
std::atomic< int > & m_exit_status
int exit_status
int m_stop_at_height
Block height after which blockTip notification will return Interrupted{}, if >0.
void setChainstateLoaded(bool chainstate_loaded) EXCLUSIVE_LOCKS_REQUIRED(!m_tip_block_mutex)
bool m_shutdown_on_fatal_error
Useful for tests, can be set to false to avoid shutdown on fatal error.