Bitcoin Core 28.0.0
P2P Digital Currency
Loading...
Searching...
No Matches
txmempool.h
Go to the documentation of this file.
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_TXMEMPOOL_H
7#define BITCOIN_TXMEMPOOL_H
8
9#include <coins.h>
10#include <consensus/amount.h>
11#include <indirectmap.h>
12#include <kernel/cs_main.h>
13#include <kernel/mempool_entry.h> // IWYU pragma: export
14#include <kernel/mempool_limits.h> // IWYU pragma: export
15#include <kernel/mempool_options.h> // IWYU pragma: export
16#include <kernel/mempool_removal_reason.h> // IWYU pragma: export
17#include <policy/feerate.h>
18#include <policy/packages.h>
20#include <sync.h>
21#include <util/epochguard.h>
22#include <util/hasher.h>
23#include <util/result.h>
24#include <util/feefrac.h>
25
26#include <boost/multi_index/hashed_index.hpp>
27#include <boost/multi_index/identity.hpp>
28#include <boost/multi_index/indexed_by.hpp>
29#include <boost/multi_index/ordered_index.hpp>
30#include <boost/multi_index/sequenced_index.hpp>
31#include <boost/multi_index/tag.hpp>
32#include <boost/multi_index_container.hpp>
33
34#include <atomic>
35#include <map>
36#include <optional>
37#include <set>
38#include <string>
39#include <string_view>
40#include <utility>
41#include <vector>
42
43class CChain;
45
46struct bilingual_str;
47
49static const uint32_t MEMPOOL_HEIGHT = 0x7FFFFFFF;
50
55
56// extracts a transaction hash from CTxMemPoolEntry or CTransactionRef
58{
61 {
62 return entry.GetTx().GetHash();
63 }
64
66 {
67 return tx->GetHash();
68 }
69};
70
71// extracts a transaction witness-hash from CTxMemPoolEntry or CTransactionRef
73{
76 {
77 return entry.GetTx().GetWitnessHash();
78 }
79
81 {
82 return tx->GetWitnessHash();
83 }
84};
85
86
92{
93public:
94 bool operator()(const CTxMemPoolEntry& a, const CTxMemPoolEntry& b) const
95 {
96 double a_mod_fee, a_size, b_mod_fee, b_size;
97
98 GetModFeeAndSize(a, a_mod_fee, a_size);
99 GetModFeeAndSize(b, b_mod_fee, b_size);
100
101 // Avoid division by rewriting (a/b > c/d) as (a*d > c*b).
102 double f1 = a_mod_fee * b_size;
103 double f2 = a_size * b_mod_fee;
104
105 if (f1 == f2) {
106 return a.GetTime() >= b.GetTime();
107 }
108 return f1 < f2;
109 }
110
111 // Return the fee/size we're using for sorting this entry.
112 void GetModFeeAndSize(const CTxMemPoolEntry &a, double &mod_fee, double &size) const
113 {
114 // Compare feerate with descendants to feerate of the transaction, and
115 // return the fee/size for the max.
116 double f1 = (double)a.GetModifiedFee() * a.GetSizeWithDescendants();
117 double f2 = (double)a.GetModFeesWithDescendants() * a.GetTxSize();
118
119 if (f2 > f1) {
120 mod_fee = a.GetModFeesWithDescendants();
121 size = a.GetSizeWithDescendants();
122 } else {
123 mod_fee = a.GetModifiedFee();
124 size = a.GetTxSize();
125 }
126 }
127};
128
137{
138public:
139 bool operator()(const CTxMemPoolEntry& a, const CTxMemPoolEntry& b) const
140 {
141 double f1 = (double)a.GetFee() * b.GetTxSize();
142 double f2 = (double)b.GetFee() * a.GetTxSize();
143 if (f1 == f2) {
144 return b.GetTx().GetHash() < a.GetTx().GetHash();
145 }
146 return f1 > f2;
147 }
148};
149
151{
152public:
153 bool operator()(const CTxMemPoolEntry& a, const CTxMemPoolEntry& b) const
154 {
155 return a.GetTime() < b.GetTime();
156 }
157};
158
164{
165public:
166 template<typename T>
167 bool operator()(const T& a, const T& b) const
168 {
169 double a_mod_fee, a_size, b_mod_fee, b_size;
170
171 GetModFeeAndSize(a, a_mod_fee, a_size);
172 GetModFeeAndSize(b, b_mod_fee, b_size);
173
174 // Avoid division by rewriting (a/b > c/d) as (a*d > c*b).
175 double f1 = a_mod_fee * b_size;
176 double f2 = a_size * b_mod_fee;
177
178 if (f1 == f2) {
179 return a.GetTx().GetHash() < b.GetTx().GetHash();
180 }
181 return f1 > f2;
182 }
183
184 // Return the fee/size we're using for sorting this entry.
185 template <typename T>
186 void GetModFeeAndSize(const T &a, double &mod_fee, double &size) const
187 {
188 // Compare feerate with ancestors to feerate of the transaction, and
189 // return the fee/size for the min.
190 double f1 = (double)a.GetModifiedFee() * a.GetSizeWithAncestors();
191 double f2 = (double)a.GetModFeesWithAncestors() * a.GetTxSize();
192
193 if (f1 > f2) {
194 mod_fee = a.GetModFeesWithAncestors();
195 size = a.GetSizeWithAncestors();
196 } else {
197 mod_fee = a.GetModifiedFee();
198 size = a.GetTxSize();
199 }
200 }
201};
202
203// Multi_index tag names
205struct entry_time {};
208
213{
216
218 std::chrono::seconds m_time;
219
222
224 int32_t vsize;
225
227 int64_t nFeeDelta;
228};
229
304{
305protected:
306 std::atomic<unsigned int> nTransactionsUpdated{0};
307
308 uint64_t totalTxSize GUARDED_BY(cs){0};
309 CAmount m_total_fee GUARDED_BY(cs){0};
310 uint64_t cachedInnerUsage GUARDED_BY(cs){0};
311
312 mutable int64_t lastRollingFeeUpdate GUARDED_BY(cs){GetTime()};
313 mutable bool blockSinceLastRollingFeeBump GUARDED_BY(cs){false};
314 mutable double rollingMinimumFeeRate GUARDED_BY(cs){0};
316
317 // In-memory counter for external mempool tracking purposes.
318 // This number is incremented once every time a transaction
319 // is added or removed from the mempool for any reason.
320 mutable uint64_t m_sequence_number GUARDED_BY(cs){1};
321
323
324 bool m_load_tried GUARDED_BY(cs){false};
325
326 CFeeRate GetMinFee(size_t sizelimit) const;
327
328public:
329
330 static const int ROLLING_FEE_HALFLIFE = 60 * 60 * 12; // public only for testing
331
332 struct CTxMemPoolEntry_Indices final : boost::multi_index::indexed_by<
333 // sorted by txid
334 boost::multi_index::hashed_unique<mempoolentry_txid, SaltedTxidHasher>,
335 // sorted by wtxid
336 boost::multi_index::hashed_unique<
337 boost::multi_index::tag<index_by_wtxid>,
338 mempoolentry_wtxid,
339 SaltedTxidHasher
340 >,
341 // sorted by fee rate
342 boost::multi_index::ordered_non_unique<
343 boost::multi_index::tag<descendant_score>,
344 boost::multi_index::identity<CTxMemPoolEntry>,
345 CompareTxMemPoolEntryByDescendantScore
346 >,
347 // sorted by entry time
348 boost::multi_index::ordered_non_unique<
349 boost::multi_index::tag<entry_time>,
350 boost::multi_index::identity<CTxMemPoolEntry>,
351 CompareTxMemPoolEntryByEntryTime
352 >,
353 // sorted by fee rate with ancestors
354 boost::multi_index::ordered_non_unique<
355 boost::multi_index::tag<ancestor_score>,
356 boost::multi_index::identity<CTxMemPoolEntry>,
357 CompareTxMemPoolEntryByAncestorFee
358 >
359 >
360 {};
361 typedef boost::multi_index_container<
365
392
393 using txiter = indexed_transaction_set::nth_index<0>::type::const_iterator;
394 std::vector<CTransactionRef> txns_randomized GUARDED_BY(cs);
395
396 typedef std::set<txiter, CompareIteratorByHash> setEntries;
397
399
401private:
402 typedef std::map<txiter, setEntries, CompareIteratorByHash> cacheMap;
403
404
405 void UpdateParent(txiter entry, txiter parent, bool add) EXCLUSIVE_LOCKS_REQUIRED(cs);
406 void UpdateChild(txiter entry, txiter child, bool add) EXCLUSIVE_LOCKS_REQUIRED(cs);
407
408 std::vector<indexed_transaction_set::const_iterator> GetSortedDepthAndScore() const EXCLUSIVE_LOCKS_REQUIRED(cs);
409
413 std::set<uint256> m_unbroadcast_txids GUARDED_BY(cs);
414
415
427 util::Result<setEntries> CalculateAncestorsAndCheckLimits(int64_t entry_size,
428 size_t entry_count,
429 CTxMemPoolEntry::Parents &staged_ancestors,
430 const Limits& limits
432
433public:
435 std::map<uint256, CAmount> mapDeltas GUARDED_BY(cs);
436
437 using Options = kernel::MemPoolOptions;
438
440
446 explicit CTxMemPool(Options opts, bilingual_str& error);
447
454 void check(const CCoinsViewCache& active_coins_tip, int64_t spendheight) const EXCLUSIVE_LOCKS_REQUIRED(::cs_main);
455
456 // addUnchecked must updated state for all ancestors of a given transaction,
457 // to track size/count of descendant transactions. First version of
458 // addUnchecked can be used to have it call CalculateMemPoolAncestors(), and
459 // then invoke the second version.
460 // Note that addUnchecked is ONLY called from ATMP outside of tests
461 // and any other callers may break wallet's in-mempool tracking (due to
462 // lack of CValidationInterface::TransactionAddedToMempool callbacks).
465
474 void removeForReorg(CChain& chain, std::function<bool(txiter)> filter_final_and_mature) EXCLUSIVE_LOCKS_REQUIRED(cs, cs_main);
476 void removeForBlock(const std::vector<CTransactionRef>& vtx, unsigned int nBlockHeight) EXCLUSIVE_LOCKS_REQUIRED(cs);
477
478 bool CompareDepthAndScore(const uint256& hasha, const uint256& hashb, bool wtxid=false);
479 bool isSpent(const COutPoint& outpoint) const;
480 unsigned int GetTransactionsUpdated() const;
481 void AddTransactionsUpdated(unsigned int n);
487
489 void PrioritiseTransaction(const uint256& hash, const CAmount& nFeeDelta);
490 void ApplyDelta(const uint256& hash, CAmount &nFeeDelta) const EXCLUSIVE_LOCKS_REQUIRED(cs);
492
493 struct delta_info {
495 const bool in_mempool;
499 std::optional<CAmount> modified_fee;
502 };
504 std::vector<delta_info> GetPrioritisedTransactions() const EXCLUSIVE_LOCKS_REQUIRED(!cs);
505
507 const CTransaction* GetConflictTx(const COutPoint& prevout) const EXCLUSIVE_LOCKS_REQUIRED(cs);
508
510 std::optional<txiter> GetIter(const uint256& txid) const EXCLUSIVE_LOCKS_REQUIRED(cs);
511
515 setEntries GetIterSet(const std::set<Txid>& hashes) const EXCLUSIVE_LOCKS_REQUIRED(cs);
516
520 std::vector<txiter> GetIterVec(const std::vector<uint256>& txids) const EXCLUSIVE_LOCKS_REQUIRED(cs);
521
529 void RemoveStaged(setEntries& stage, bool updateDescendants, MemPoolRemovalReason reason) EXCLUSIVE_LOCKS_REQUIRED(cs);
530
545
559 const Limits& limits,
560 bool fSearchForParents = true) const EXCLUSIVE_LOCKS_REQUIRED(cs);
561
577 std::string_view calling_fn_name,
578 const CTxMemPoolEntry &entry,
579 const Limits& limits,
580 bool fSearchForParents = true) const EXCLUSIVE_LOCKS_REQUIRED(cs);
581
586 std::vector<txiter> GatherClusters(const std::vector<uint256>& txids) const EXCLUSIVE_LOCKS_REQUIRED(cs);
587
600 util::Result<void> CheckPackageLimits(const Package& package,
601 int64_t total_vsize) const EXCLUSIVE_LOCKS_REQUIRED(cs);
602
607
616 }
617
622 void TrimToSize(size_t sizelimit, std::vector<COutPoint>* pvNoSpendsRemaining = nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs);
623
625 int Expire(std::chrono::seconds time) EXCLUSIVE_LOCKS_REQUIRED(cs);
626
633 void GetTransactionAncestry(const uint256& txid, size_t& ancestors, size_t& descendants, size_t* ancestorsize = nullptr, CAmount* ancestorfees = nullptr) const;
634
639 bool GetLoadTried() const;
640
645 void SetLoadTried(bool load_tried);
646
647 unsigned long size() const
648 {
649 LOCK(cs);
650 return mapTx.size();
651 }
652
654 {
656 return totalTxSize;
657 }
658
660 {
662 return m_total_fee;
663 }
664
665 bool exists(const GenTxid& gtxid) const
666 {
667 LOCK(cs);
668 if (gtxid.IsWtxid()) {
669 return (mapTx.get<index_by_wtxid>().count(gtxid.GetHash()) != 0);
670 }
671 return (mapTx.count(gtxid.GetHash()) != 0);
672 }
673
675
676 CTransactionRef get(const uint256& hash) const;
678 {
680 return mapTx.project<0>(mapTx.get<index_by_wtxid>().find(wtxid));
681 }
682 TxMempoolInfo info(const GenTxid& gtxid) const;
683
685 TxMempoolInfo info_for_relay(const GenTxid& gtxid, uint64_t last_sequence) const;
686
687 std::vector<CTxMemPoolEntryRef> entryAll() const EXCLUSIVE_LOCKS_REQUIRED(cs);
688 std::vector<TxMempoolInfo> infoAll() const;
689
690 size_t DynamicMemoryUsage() const;
691
693 void AddUnbroadcastTx(const uint256& txid)
694 {
695 LOCK(cs);
696 // Sanity check the transaction is in the mempool & insert into
697 // unbroadcast set.
698 if (exists(GenTxid::Txid(txid))) m_unbroadcast_txids.insert(txid);
699 };
700
702 void RemoveUnbroadcastTx(const uint256& txid, const bool unchecked = false);
703
705 std::set<uint256> GetUnbroadcastTxs() const
706 {
707 LOCK(cs);
708 return m_unbroadcast_txids;
709 }
710
713 {
715 return m_unbroadcast_txids.count(txid) != 0;
716 }
717
720 return m_sequence_number++;
721 }
722
724 return m_sequence_number;
725 }
726
742 util::Result<std::pair<std::vector<FeeFrac>, std::vector<FeeFrac>>> CalculateChunksForRBF(CAmount replacement_fees, int64_t replacement_vsize, const setEntries& direct_conflicts, const setEntries& all_conflicts) EXCLUSIVE_LOCKS_REQUIRED(cs);
743
744 /* Check that all direct conflicts are in a cluster size of two or less. Each
745 * direct conflict may be in a separate cluster.
746 */
747 std::optional<std::string> CheckConflictTopology(const setEntries& direct_conflicts);
748
749private:
778 void UpdateForDescendants(txiter updateIt, cacheMap& cachedDescendants,
779 const std::set<uint256>& setExclude, std::set<uint256>& descendants_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs);
781 void UpdateAncestorsOf(bool add, txiter hash, setEntries &setAncestors) EXCLUSIVE_LOCKS_REQUIRED(cs);
787 void UpdateForRemoveFromMempool(const setEntries &entriesToRemove, bool updateDescendants) EXCLUSIVE_LOCKS_REQUIRED(cs);
790
800public:
810 {
811 return m_epoch.visited(it->m_epoch_marker);
812 }
813
814 bool visited(std::optional<txiter> it) const EXCLUSIVE_LOCKS_REQUIRED(cs, m_epoch)
815 {
816 assert(m_epoch.guarded()); // verify guard even when it==nullopt
817 return !it || visited(*it);
818 }
819};
820
835{
840 std::unordered_map<COutPoint, Coin, SaltedOutpointHasher> m_temp_added;
841
846 mutable std::unordered_set<COutPoint, SaltedOutpointHasher> m_non_base_coins;
847protected:
849
850public:
851 CCoinsViewMemPool(CCoinsView* baseIn, const CTxMemPool& mempoolIn);
854 bool GetCoin(const COutPoint &outpoint, Coin &coin) const override;
859 std::unordered_set<COutPoint, SaltedOutpointHasher> GetNonBaseCoins() const { return m_non_base_coins; }
861 void Reset();
862};
863#endif // BITCOIN_TXMEMPOOL_H
int64_t CAmount
Amount in satoshis (Can be negative)
Definition amount.h:12
#define LIFETIMEBOUND
Definition attributes.h:16
An in-memory indexed chain of blocks.
Definition chain.h:417
CCoinsView backed by another CCoinsView.
Definition coins.h:341
CCoinsView that adds a memory cache for transactions to another CCoinsView.
Definition coins.h:360
Abstract view on the open txout dataset.
Definition coins.h:304
CCoinsView that brings transactions from a mempool into view.
Definition txmempool.h:835
bool GetCoin(const COutPoint &outpoint, Coin &coin) const override
GetCoin, returning whether it exists and is not spent.
std::unordered_set< COutPoint, SaltedOutpointHasher > GetNonBaseCoins() const
Get all coins in m_non_base_coins.
Definition txmempool.h:859
void Reset()
Clear m_temp_added and m_non_base_coins.
std::unordered_map< COutPoint, Coin, SaltedOutpointHasher > m_temp_added
Coins made available by transactions being validated.
Definition txmempool.h:840
CCoinsViewMemPool(CCoinsView *baseIn, const CTxMemPool &mempoolIn)
std::unordered_set< COutPoint, SaltedOutpointHasher > m_non_base_coins
Set of all coins that have been fetched from mempool or created using PackageAddTransaction (not base...
Definition txmempool.h:846
void PackageAddTransaction(const CTransactionRef &tx)
Add the coins created by this transaction.
const CTxMemPool & mempool
Definition txmempool.h:848
Fee rate in satoshis per kilovirtualbyte: CAmount / kvB.
Definition feerate.h:33
An outpoint - a combination of a transaction hash and an index n into its vout.
Definition transaction.h:29
The basic transaction that is broadcasted on the network and contained in blocks.
const Wtxid & GetWitnessHash() const LIFETIMEBOUND
const Txid & GetHash() const LIFETIMEBOUND
CTxMemPoolEntry stores data about the corresponding transaction, as well as data about all in-mempool...
int64_t GetSizeWithDescendants() const
std::chrono::seconds GetTime() const
const CTransaction & GetTx() const
CAmount GetModFeesWithDescendants() const
int32_t GetTxSize() const
const CAmount & GetFee() const
CAmount GetModifiedFee() const
CTxMemPool stores valid-according-to-the-current-best-chain transactions that may be included in the ...
Definition txmempool.h:304
void removeConflicts(const CTransaction &tx) EXCLUSIVE_LOCKS_REQUIRED(cs)
std::atomic< unsigned int > nTransactionsUpdated
Used by getblocktemplate to trigger CreateNewBlock() invocation.
Definition txmempool.h:306
void RemoveUnbroadcastTx(const uint256 &txid, const bool unchecked=false)
Removes a transaction from the unbroadcast set.
void PrioritiseTransaction(const uint256 &hash, const CAmount &nFeeDelta)
Affect CreateNewBlock prioritisation of transactions.
setEntries AssumeCalculateMemPoolAncestors(std::string_view calling_fn_name, const CTxMemPoolEntry &entry, const Limits &limits, bool fSearchForParents=true) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Same as CalculateMemPoolAncestors, but always returns a (non-optional) setEntries.
bool HasNoInputsOf(const CTransaction &tx) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Check that none of this transactions inputs are in the mempool, and thus the tx is not dependent on o...
std::set< uint256 > GetUnbroadcastTxs() const
Returns transactions in unbroadcast set.
Definition txmempool.h:705
setEntries GetIterSet(const std::set< Txid > &hashes) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Translate a set of hashes into a set of pool iterators to avoid repeated lookups.
void AddUnbroadcastTx(const uint256 &txid)
Adds a transaction to the unbroadcast set.
Definition txmempool.h:693
std::vector< txiter > GetIterVec(const std::vector< uint256 > &txids) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Translate a list of hashes into a list of mempool iterators to avoid repeated lookups.
uint64_t cachedInnerUsage GUARDED_BY(cs)
sum of all mempool tx's fees (NOT modified fee)
Definition txmempool.h:310
void UpdateEntryForAncestors(txiter it, const setEntries &setAncestors) EXCLUSIVE_LOCKS_REQUIRED(cs)
Set ancestor state for an entry.
bool GetLoadTried() const
bool visited(const txiter it) const EXCLUSIVE_LOCKS_REQUIRED(cs
visited marks a CTxMemPoolEntry as having been traversed during the lifetime of the most recently cre...
bool visited(std::optional< txiter > it) const EXCLUSIVE_LOCKS_REQUIRED(cs
CFeeRate GetMinFee() const
The minimum fee to get into the mempool, which may itself not be enough for larger-sized transactions...
Definition txmempool.h:614
RecursiveMutex cs
This mutex needs to be locked when accessing mapTx or other members that are guarded by it.
Definition txmempool.h:390
void ClearPrioritisation(const uint256 &hash) EXCLUSIVE_LOCKS_REQUIRED(cs)
void trackPackageRemoved(const CFeeRate &rate) EXCLUSIVE_LOCKS_REQUIRED(cs)
util::Result< setEntries > CalculateMemPoolAncestors(const CTxMemPoolEntry &entry, const Limits &limits, bool fSearchForParents=true) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Try to calculate all in-mempool ancestors of entry.
void removeRecursive(const CTransaction &tx, MemPoolRemovalReason reason) EXCLUSIVE_LOCKS_REQUIRED(cs)
bool blockSinceLastRollingFeeBump GUARDED_BY(cs)
Definition txmempool.h:313
void TrimToSize(size_t sizelimit, std::vector< COutPoint > *pvNoSpendsRemaining=nullptr) EXCLUSIVE_LOCKS_REQUIRED(cs)
Remove transactions from the mempool until its dynamic size is <= sizelimit.
std::vector< CTransactionRef > txns_randomized GUARDED_BY(cs)
All transactions in mapTx, in random order.
void UpdateTransactionsFromBlock(const std::vector< uint256 > &vHashesToUpdate) EXCLUSIVE_LOCKS_REQUIRED(cs
UpdateTransactionsFromBlock is called when adding transactions from a disconnected block back to the ...
return !it visited * it
Definition txmempool.h:817
void AddTransactionsUpdated(unsigned int n)
void UpdateChildrenForRemoval(txiter entry) EXCLUSIVE_LOCKS_REQUIRED(cs)
Sever link between specified transaction and direct children.
std::optional< txiter > GetIter(const uint256 &txid) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Returns an iterator to the given hash, if found.
util::Result< setEntries > CalculateAncestorsAndCheckLimits(int64_t entry_size, size_t entry_count, CTxMemPoolEntry::Parents &staged_ancestors, const Limits &limits) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Helper function to calculate all in-mempool ancestors of staged_ancestors and apply ancestor and desc...
CTransactionRef get(const uint256 &hash) const
size_t DynamicMemoryUsage() const
const Options m_opts
Definition txmempool.h:439
void check(const CCoinsViewCache &active_coins_tip, int64_t spendheight) const EXCLUSIVE_LOCKS_REQUIRED(voi addUnchecked)(const CTxMemPoolEntry &entry) EXCLUSIVE_LOCKS_REQUIRED(cs
If sanity-checking is turned on, check makes sure the pool is consistent (does not contain two transa...
Definition txmempool.h:463
Epoch m_epoch GUARDED_BY(cs)
minimum fee to get into the pool, decreases exponentially
Definition txmempool.h:315
std::vector< TxMempoolInfo > infoAll() const
void GetTransactionAncestry(const uint256 &txid, size_t &ancestors, size_t &descendants, size_t *ancestorsize=nullptr, CAmount *ancestorfees=nullptr) const
Calculate the ancestor and descendant count for the given transaction.
indexed_transaction_set mapTx GUARDED_BY(cs)
void check(const CCoinsViewCache &active_coins_tip, int64_t spendheight) const EXCLUSIVE_LOCKS_REQUIRED(voi cs_main)
Definition txmempool.h:463
bool IsUnbroadcastTx(const uint256 &txid) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Returns whether a txid is in the unbroadcast set.
Definition txmempool.h:712
void UpdateParent(txiter entry, txiter parent, bool add) EXCLUSIVE_LOCKS_REQUIRED(cs)
void removeUnchecked(txiter entry, MemPoolRemovalReason reason) EXCLUSIVE_LOCKS_REQUIRED(cs)
Before calling removeUnchecked for a given transaction, UpdateForRemoveFromMempool must be called on ...
uint64_t totalTxSize GUARDED_BY(cs)
Definition txmempool.h:308
int Expire(std::chrono::seconds time) EXCLUSIVE_LOCKS_REQUIRED(cs)
Expire all transaction (and their dependencies) in the mempool older than time.
txiter get_iter_from_wtxid(const uint256 &wtxid) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Definition txmempool.h:677
void UpdateAncestorsOf(bool add, txiter hash, setEntries &setAncestors) EXCLUSIVE_LOCKS_REQUIRED(cs)
Update ancestors of hash to add/remove it as a descendant transaction.
void removeForReorg(CChain &chain, std::function< bool(txiter)> filter_final_and_mature) EXCLUSIVE_LOCKS_REQUIRED(cs
After reorg, filter the entries that would no longer be valid in the next block, and update the entri...
util::Result< void > CheckPackageLimits(const Package &package, int64_t total_vsize) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Calculate all in-mempool ancestors of a set of transactions not already in the mempool and check ance...
TxMempoolInfo info(const GenTxid &gtxid) const
std::vector< txiter > GatherClusters(const std::vector< uint256 > &txids) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Collect the entire cluster of connected transactions for each transaction in txids.
void ApplyDelta(const uint256 &hash, CAmount &nFeeDelta) const EXCLUSIVE_LOCKS_REQUIRED(cs)
int64_t lastRollingFeeUpdate GUARDED_BY(cs)
sum of dynamic memory usage of all the map elements (NOT the maps themselves)
Definition txmempool.h:312
void UpdateForDescendants(txiter updateIt, cacheMap &cachedDescendants, const std::set< uint256 > &setExclude, std::set< uint256 > &descendants_to_remove) EXCLUSIVE_LOCKS_REQUIRED(cs)
UpdateForDescendants is used by UpdateTransactionsFromBlock to update the descendants for a single tr...
Definition txmempool.cpp:54
util::Result< std::pair< std::vector< FeeFrac >, std::vector< FeeFrac > > > CalculateChunksForRBF(CAmount replacement_fees, int64_t replacement_vsize, const setEntries &direct_conflicts, const setEntries &all_conflicts) EXCLUSIVE_LOCKS_REQUIRED(cs)
Calculate the sorted chunks for the old and new mempool relating to the clusters that would be affect...
bool m_load_tried GUARDED_BY(cs)
Definition txmempool.h:324
static const int ROLLING_FEE_HALFLIFE
Definition txmempool.h:330
std::vector< indexed_transaction_set::const_iterator > GetSortedDepthAndScore() const EXCLUSIVE_LOCKS_REQUIRED(cs)
void RemoveStaged(setEntries &stage, bool updateDescendants, MemPoolRemovalReason reason) EXCLUSIVE_LOCKS_REQUIRED(cs)
Remove a set of transactions from the mempool.
void removeForBlock(const std::vector< CTransactionRef > &vtx, unsigned int nBlockHeight) EXCLUSIVE_LOCKS_REQUIRED(cs)
Called when a block is connected.
std::vector< delta_info > GetPrioritisedTransactions() const EXCLUSIVE_LOCKS_REQUIRED(!cs)
Return a vector of all entries in mapDeltas with their corresponding delta_info.
uint64_t GetSequence() const EXCLUSIVE_LOCKS_REQUIRED(cs)
Definition txmempool.h:723
indexed_transaction_set::nth_index< 0 >::type::const_iterator txiter
Definition txmempool.h:393
uint64_t GetAndIncrementSequence() const EXCLUSIVE_LOCKS_REQUIRED(cs)
Guards this internal counter for external reporting.
Definition txmempool.h:719
void UpdateChild(txiter entry, txiter child, bool add) EXCLUSIVE_LOCKS_REQUIRED(cs)
TxMempoolInfo info_for_relay(const GenTxid &gtxid, uint64_t last_sequence) const
Returns info for a transaction if its entry_sequence < last_sequence.
double rollingMinimumFeeRate GUARDED_BY(cs)
Definition txmempool.h:314
bool exists(const GenTxid &gtxid) const
Definition txmempool.h:665
bool m_epoch
Definition txmempool.h:810
std::set< txiter, CompareIteratorByHash > setEntries
Definition txmempool.h:396
boost::multi_index_container< CTxMemPoolEntry, CTxMemPoolEntry_Indices > indexed_transaction_set
Definition txmempool.h:364
const CTransaction * GetConflictTx(const COutPoint &prevout) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Get the transaction in the pool that spends the same prevout.
bool CompareDepthAndScore(const uint256 &hasha, const uint256 &hashb, bool wtxid=false)
void CalculateDescendants(txiter it, setEntries &setDescendants) const EXCLUSIVE_LOCKS_REQUIRED(cs)
Populate setDescendants with all in-mempool descendants of hash.
unsigned long size() const
Definition txmempool.h:647
std::optional< std::string > CheckConflictTopology(const setEntries &direct_conflicts)
uint64_t m_sequence_number GUARDED_BY(cs)
Definition txmempool.h:320
void SetLoadTried(bool load_tried)
Set whether or not an initial attempt to load the persisted mempool was made (regardless of whether t...
void UpdateForRemoveFromMempool(const setEntries &entriesToRemove, bool updateDescendants) EXCLUSIVE_LOCKS_REQUIRED(cs)
For each transaction being removed, update ancestors and any direct children.
std::vector< CTxMemPoolEntryRef > entryAll() const EXCLUSIVE_LOCKS_REQUIRED(cs)
CAmount GetTotalFee() const EXCLUSIVE_LOCKS_REQUIRED(cs)
Definition txmempool.h:659
uint64_t CalculateDescendantMaximum(txiter entry) const EXCLUSIVE_LOCKS_REQUIRED(cs)
uint64_t GetTotalTxSize() const EXCLUSIVE_LOCKS_REQUIRED(cs)
Definition txmempool.h:653
bool isSpent(const COutPoint &outpoint) const
const CTxMemPoolEntry * GetEntry(const Txid &txid) const LIFETIMEBOUND EXCLUSIVE_LOCKS_REQUIRED(cs)
std::map< txiter, setEntries, CompareIteratorByHash > cacheMap
Definition txmempool.h:402
unsigned int GetTransactionsUpdated() const
CAmount m_total_fee GUARDED_BY(cs)
sum of all mempool tx's virtual sizes. Differs from serialized tx size since witness data is discount...
Definition txmempool.h:309
A UTXO entry.
Definition coins.h:33
Definition txmempool.h:164
bool operator()(const T &a, const T &b) const
Definition txmempool.h:167
void GetModFeeAndSize(const T &a, double &mod_fee, double &size) const
Definition txmempool.h:186
Sort an entry by max(score/size of entry's tx, score/size with all descendants).
Definition txmempool.h:92
bool operator()(const CTxMemPoolEntry &a, const CTxMemPoolEntry &b) const
Definition txmempool.h:94
void GetModFeeAndSize(const CTxMemPoolEntry &a, double &mod_fee, double &size) const
Definition txmempool.h:112
Definition txmempool.h:151
bool operator()(const CTxMemPoolEntry &a, const CTxMemPoolEntry &b) const
Definition txmempool.h:153
Sort by feerate of entry (fee/size) in descending order This is only used for transaction relay,...
Definition txmempool.h:137
bool operator()(const CTxMemPoolEntry &a, const CTxMemPoolEntry &b) const
Definition txmempool.h:139
Epoch: RAII-style guard for using epoch-based graph traversal algorithms.
Definition epochguard.h:35
A generic txid reference (txid or wtxid).
bool IsWtxid() const
const uint256 & GetHash() const LIFETIMEBOUND
static GenTxid Txid(const uint256 &hash)
256-bit opaque blob.
Definition uint256.h:178
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.
Definition cs_main.cpp:8
#define T(expected, seed, data)
LockPoints lp
MemPoolRemovalReason
Reason why a transaction was removed from the mempool, this is passed to the notification signal.
std::vector< CTransactionRef > Package
A package is an ordered list of transactions.
Definition packages.h:50
std::shared_ptr< const CTransaction > CTransactionRef
Definition txmempool.h:360
const CAmount delta
The fee delta added using PrioritiseTransaction().
Definition txmempool.h:497
const bool in_mempool
Whether this transaction is in the mempool.
Definition txmempool.h:495
std::optional< CAmount > modified_fee
The modified fee (base fee + delta) of this entry.
Definition txmempool.h:499
const uint256 txid
The prioritised transaction's txid.
Definition txmempool.h:501
Information about a mempool transaction.
Definition txmempool.h:213
int64_t nFeeDelta
The fee delta.
Definition txmempool.h:227
int32_t vsize
Virtual size of the transaction.
Definition txmempool.h:224
CAmount fee
Fee of the transaction.
Definition txmempool.h:221
CTransactionRef tx
The transaction itself.
Definition txmempool.h:215
std::chrono::seconds m_time
Time the transaction entered the mempool.
Definition txmempool.h:218
Bilingual messages:
Definition translation.h:18
Options struct containing limit options for a CTxMemPool.
Options struct containing options for constructing a CTxMemPool.
uint256 result_type
Definition txmempool.h:59
result_type operator()(const CTxMemPoolEntry &entry) const
Definition txmempool.h:60
uint256 result_type
Definition txmempool.h:74
result_type operator()(const CTxMemPoolEntry &entry) const
Definition txmempool.h:75
#define LOCK(cs)
Definition sync.h:257
#define AssertLockHeld(cs)
Definition sync.h:142
#define EXCLUSIVE_LOCKS_REQUIRED(...)
#define GUARDED_BY(x)
#define LOCKS_EXCLUDED(...)
int64_t GetTime()
DEPRECATED Use either ClockType::now() or Now<TimePointType>() if a cast is needed.
Definition time.cpp:44
static const uint32_t MEMPOOL_HEIGHT
Fake height value used in Coin to signify they are only in the memory pool (since 0....
Definition txmempool.h:49
bool TestLockPointValidity(CChain &active_chain, const LockPoints &lp) EXCLUSIVE_LOCKS_REQUIRED(cs_main)
Test whether the LockPoints height and time are still valid on the current chain.
Definition txmempool.cpp:37
assert(!tx.IsCoinBase())