mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-05-03 00:10:52 +02:00
refactor: Move CTxMemPoolEntry
class to its own module
This change nukes the policy/fees->mempool circular dependency. Easy to review using `diff --color-moved=dimmed-zebra`.
This commit is contained in:
parent
3f1f5f6f1e
commit
75bbe594e5
@ -261,6 +261,7 @@ BITCOIN_CORE_H = \
|
|||||||
torcontrol.h \
|
torcontrol.h \
|
||||||
txdb.h \
|
txdb.h \
|
||||||
txmempool.h \
|
txmempool.h \
|
||||||
|
txmempool_entry.h \
|
||||||
txorphanage.h \
|
txorphanage.h \
|
||||||
txrequest.h \
|
txrequest.h \
|
||||||
undo.h \
|
undo.h \
|
||||||
@ -425,6 +426,7 @@ libbitcoin_node_a_SOURCES = \
|
|||||||
torcontrol.cpp \
|
torcontrol.cpp \
|
||||||
txdb.cpp \
|
txdb.cpp \
|
||||||
txmempool.cpp \
|
txmempool.cpp \
|
||||||
|
txmempool_entry.cpp \
|
||||||
txorphanage.cpp \
|
txorphanage.cpp \
|
||||||
txrequest.cpp \
|
txrequest.cpp \
|
||||||
validation.cpp \
|
validation.cpp \
|
||||||
@ -930,6 +932,7 @@ libbitcoinkernel_la_SOURCES = \
|
|||||||
threadinterrupt.cpp \
|
threadinterrupt.cpp \
|
||||||
txdb.cpp \
|
txdb.cpp \
|
||||||
txmempool.cpp \
|
txmempool.cpp \
|
||||||
|
txmempool_entry.cpp \
|
||||||
uint256.cpp \
|
uint256.cpp \
|
||||||
util/check.cpp \
|
util/check.cpp \
|
||||||
util/getuniquepath.cpp \
|
util/getuniquepath.cpp \
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include <policy/policy.h>
|
#include <policy/policy.h>
|
||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
|
|
||||||
|
|
||||||
static void AddTx(const CTransactionRef& tx, const CAmount& nFee, CTxMemPool& pool) EXCLUSIVE_LOCKS_REQUIRED(cs_main, pool.cs)
|
static void AddTx(const CTransactionRef& tx, const CAmount& nFee, CTxMemPool& pool) EXCLUSIVE_LOCKS_REQUIRED(cs_main, pool.cs)
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
#include <policy/policy.h>
|
#include <policy/policy.h>
|
||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <validation.h>
|
#include <validation.h>
|
||||||
|
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
@ -7,6 +7,7 @@
|
|||||||
#include <rpc/mempool.h>
|
#include <rpc/mempool.h>
|
||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
|
|
||||||
#include <univalue.h>
|
#include <univalue.h>
|
||||||
|
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include <timedata.h>
|
#include <timedata.h>
|
||||||
#include <tinyformat.h>
|
#include <tinyformat.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <txorphanage.h>
|
#include <txorphanage.h>
|
||||||
#include <txrequest.h>
|
#include <txrequest.h>
|
||||||
#include <util/check.h> // For NDEBUG compile time check
|
#include <util/check.h> // For NDEBUG compile time check
|
||||||
|
@ -37,6 +37,7 @@
|
|||||||
#include <support/allocators/secure.h>
|
#include <support/allocators/secure.h>
|
||||||
#include <sync.h>
|
#include <sync.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <uint256.h>
|
#include <uint256.h>
|
||||||
#include <univalue.h>
|
#include <univalue.h>
|
||||||
#include <util/check.h>
|
#include <util/check.h>
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
#include <streams.h>
|
#include <streams.h>
|
||||||
#include <sync.h>
|
#include <sync.h>
|
||||||
#include <tinyformat.h>
|
#include <tinyformat.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool_entry.h>
|
||||||
#include <uint256.h>
|
#include <uint256.h>
|
||||||
#include <util/serfloat.h>
|
#include <util/serfloat.h>
|
||||||
#include <util/system.h>
|
#include <util/system.h>
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#include <sync.h>
|
#include <sync.h>
|
||||||
#include <tinyformat.h>
|
#include <tinyformat.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <uint256.h>
|
#include <uint256.h>
|
||||||
#include <util/moneystr.h>
|
#include <util/moneystr.h>
|
||||||
#include <util/rbf.h>
|
#include <util/rbf.h>
|
||||||
|
@ -18,6 +18,7 @@
|
|||||||
#include <rpc/server_util.h>
|
#include <rpc/server_util.h>
|
||||||
#include <rpc/util.h>
|
#include <rpc/util.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <univalue.h>
|
#include <univalue.h>
|
||||||
#include <util/moneystr.h>
|
#include <util/moneystr.h>
|
||||||
#include <util/time.h>
|
#include <util/time.h>
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include <test/fuzz/util/mempool.h>
|
#include <test/fuzz/util/mempool.h>
|
||||||
#include <test/util/setup_common.h>
|
#include <test/util/setup_common.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
|
|
||||||
#include <cstdint>
|
#include <cstdint>
|
||||||
#include <optional>
|
#include <optional>
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
#include <test/fuzz/FuzzedDataProvider.h>
|
#include <test/fuzz/FuzzedDataProvider.h>
|
||||||
#include <test/fuzz/util.h>
|
#include <test/fuzz/util.h>
|
||||||
#include <test/fuzz/util/mempool.h>
|
#include <test/fuzz/util/mempool.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool_entry.h>
|
||||||
|
|
||||||
#include <limits>
|
#include <limits>
|
||||||
|
|
||||||
|
@ -39,6 +39,7 @@
|
|||||||
#include <timedata.h>
|
#include <timedata.h>
|
||||||
#include <txdb.h>
|
#include <txdb.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <util/strencodings.h>
|
#include <util/strencodings.h>
|
||||||
#include <util/string.h>
|
#include <util/string.h>
|
||||||
#include <util/thread.h>
|
#include <util/thread.h>
|
||||||
|
@ -41,42 +41,6 @@ bool TestLockPointValidity(CChain& active_chain, const LockPoints& lp)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
CTxMemPoolEntry::CTxMemPoolEntry(const CTransactionRef& tx, CAmount fee,
|
|
||||||
int64_t time, unsigned int entry_height,
|
|
||||||
bool spends_coinbase, int64_t sigops_cost, LockPoints lp)
|
|
||||||
: tx{tx},
|
|
||||||
nFee{fee},
|
|
||||||
nTxWeight(GetTransactionWeight(*tx)),
|
|
||||||
nUsageSize{RecursiveDynamicUsage(tx)},
|
|
||||||
nTime{time},
|
|
||||||
entryHeight{entry_height},
|
|
||||||
spendsCoinbase{spends_coinbase},
|
|
||||||
sigOpCost{sigops_cost},
|
|
||||||
m_modified_fee{nFee},
|
|
||||||
lockPoints{lp},
|
|
||||||
nSizeWithDescendants{GetTxSize()},
|
|
||||||
nModFeesWithDescendants{nFee},
|
|
||||||
nSizeWithAncestors{GetTxSize()},
|
|
||||||
nModFeesWithAncestors{nFee},
|
|
||||||
nSigOpCostWithAncestors{sigOpCost} {}
|
|
||||||
|
|
||||||
void CTxMemPoolEntry::UpdateModifiedFee(CAmount fee_diff)
|
|
||||||
{
|
|
||||||
nModFeesWithDescendants = SaturatingAdd(nModFeesWithDescendants, fee_diff);
|
|
||||||
nModFeesWithAncestors = SaturatingAdd(nModFeesWithAncestors, fee_diff);
|
|
||||||
m_modified_fee = SaturatingAdd(m_modified_fee, fee_diff);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CTxMemPoolEntry::UpdateLockPoints(const LockPoints& lp)
|
|
||||||
{
|
|
||||||
lockPoints = lp;
|
|
||||||
}
|
|
||||||
|
|
||||||
size_t CTxMemPoolEntry::GetTxSize() const
|
|
||||||
{
|
|
||||||
return GetVirtualTransactionSize(nTxWeight, sigOpCost, ::nBytesPerSigOp);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CTxMemPool::UpdateForDescendants(txiter updateIt, cacheMap& cachedDescendants,
|
void CTxMemPool::UpdateForDescendants(txiter updateIt, cacheMap& cachedDescendants,
|
||||||
const std::set<uint256>& setExclude, std::set<uint256>& descendants_to_remove)
|
const std::set<uint256>& setExclude, std::set<uint256>& descendants_to_remove)
|
||||||
{
|
{
|
||||||
|
122
src/txmempool.h
122
src/txmempool.h
@ -25,6 +25,7 @@
|
|||||||
#include <primitives/transaction.h>
|
#include <primitives/transaction.h>
|
||||||
#include <random.h>
|
#include <random.h>
|
||||||
#include <sync.h>
|
#include <sync.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <util/epochguard.h>
|
#include <util/epochguard.h>
|
||||||
#include <util/hasher.h>
|
#include <util/hasher.h>
|
||||||
|
|
||||||
@ -41,132 +42,11 @@ extern RecursiveMutex cs_main;
|
|||||||
/** Fake height value used in Coin to signify they are only in the memory pool (since 0.8) */
|
/** Fake height value used in Coin to signify they are only in the memory pool (since 0.8) */
|
||||||
static const uint32_t MEMPOOL_HEIGHT = 0x7FFFFFFF;
|
static const uint32_t MEMPOOL_HEIGHT = 0x7FFFFFFF;
|
||||||
|
|
||||||
struct LockPoints {
|
|
||||||
// Will be set to the blockchain height and median time past
|
|
||||||
// values that would be necessary to satisfy all relative locktime
|
|
||||||
// constraints (BIP68) of this tx given our view of block chain history
|
|
||||||
int height{0};
|
|
||||||
int64_t time{0};
|
|
||||||
// As long as the current chain descends from the highest height block
|
|
||||||
// containing one of the inputs used in the calculation, then the cached
|
|
||||||
// values are still valid even after a reorg.
|
|
||||||
CBlockIndex* maxInputBlock{nullptr};
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test whether the LockPoints height and time are still valid on the current chain
|
* Test whether the LockPoints height and time are still valid on the current chain
|
||||||
*/
|
*/
|
||||||
bool TestLockPointValidity(CChain& active_chain, const LockPoints& lp) EXCLUSIVE_LOCKS_REQUIRED(cs_main);
|
bool TestLockPointValidity(CChain& active_chain, const LockPoints& lp) EXCLUSIVE_LOCKS_REQUIRED(cs_main);
|
||||||
|
|
||||||
struct CompareIteratorByHash {
|
|
||||||
// SFINAE for T where T is either a pointer type (e.g., a txiter) or a reference_wrapper<T>
|
|
||||||
// (e.g. a wrapped CTxMemPoolEntry&)
|
|
||||||
template <typename T>
|
|
||||||
bool operator()(const std::reference_wrapper<T>& a, const std::reference_wrapper<T>& b) const
|
|
||||||
{
|
|
||||||
return a.get().GetTx().GetHash() < b.get().GetTx().GetHash();
|
|
||||||
}
|
|
||||||
template <typename T>
|
|
||||||
bool operator()(const T& a, const T& b) const
|
|
||||||
{
|
|
||||||
return a->GetTx().GetHash() < b->GetTx().GetHash();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
/** \class CTxMemPoolEntry
|
|
||||||
*
|
|
||||||
* CTxMemPoolEntry stores data about the corresponding transaction, as well
|
|
||||||
* as data about all in-mempool transactions that depend on the transaction
|
|
||||||
* ("descendant" transactions).
|
|
||||||
*
|
|
||||||
* When a new entry is added to the mempool, we update the descendant state
|
|
||||||
* (nCountWithDescendants, nSizeWithDescendants, and nModFeesWithDescendants) for
|
|
||||||
* all ancestors of the newly added transaction.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
|
|
||||||
class CTxMemPoolEntry
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
typedef std::reference_wrapper<const CTxMemPoolEntry> CTxMemPoolEntryRef;
|
|
||||||
// two aliases, should the types ever diverge
|
|
||||||
typedef std::set<CTxMemPoolEntryRef, CompareIteratorByHash> Parents;
|
|
||||||
typedef std::set<CTxMemPoolEntryRef, CompareIteratorByHash> Children;
|
|
||||||
|
|
||||||
private:
|
|
||||||
const CTransactionRef tx;
|
|
||||||
mutable Parents m_parents;
|
|
||||||
mutable Children m_children;
|
|
||||||
const CAmount nFee; //!< Cached to avoid expensive parent-transaction lookups
|
|
||||||
const size_t nTxWeight; //!< ... and avoid recomputing tx weight (also used for GetTxSize())
|
|
||||||
const size_t nUsageSize; //!< ... and total memory usage
|
|
||||||
const int64_t nTime; //!< Local time when entering the mempool
|
|
||||||
const unsigned int entryHeight; //!< Chain height when entering the mempool
|
|
||||||
const bool spendsCoinbase; //!< keep track of transactions that spend a coinbase
|
|
||||||
const int64_t sigOpCost; //!< Total sigop cost
|
|
||||||
CAmount m_modified_fee; //!< Used for determining the priority of the transaction for mining in a block
|
|
||||||
LockPoints lockPoints; //!< Track the height and time at which tx was final
|
|
||||||
|
|
||||||
// Information about descendants of this transaction that are in the
|
|
||||||
// mempool; if we remove this transaction we must remove all of these
|
|
||||||
// descendants as well.
|
|
||||||
uint64_t nCountWithDescendants{1}; //!< number of descendant transactions
|
|
||||||
uint64_t nSizeWithDescendants; //!< ... and size
|
|
||||||
CAmount nModFeesWithDescendants; //!< ... and total fees (all including us)
|
|
||||||
|
|
||||||
// Analogous statistics for ancestor transactions
|
|
||||||
uint64_t nCountWithAncestors{1};
|
|
||||||
uint64_t nSizeWithAncestors;
|
|
||||||
CAmount nModFeesWithAncestors;
|
|
||||||
int64_t nSigOpCostWithAncestors;
|
|
||||||
|
|
||||||
public:
|
|
||||||
CTxMemPoolEntry(const CTransactionRef& tx, CAmount fee,
|
|
||||||
int64_t time, unsigned int entry_height,
|
|
||||||
bool spends_coinbase,
|
|
||||||
int64_t sigops_cost, LockPoints lp);
|
|
||||||
|
|
||||||
const CTransaction& GetTx() const { return *this->tx; }
|
|
||||||
CTransactionRef GetSharedTx() const { return this->tx; }
|
|
||||||
const CAmount& GetFee() const { return nFee; }
|
|
||||||
size_t GetTxSize() const;
|
|
||||||
size_t GetTxWeight() const { return nTxWeight; }
|
|
||||||
std::chrono::seconds GetTime() const { return std::chrono::seconds{nTime}; }
|
|
||||||
unsigned int GetHeight() const { return entryHeight; }
|
|
||||||
int64_t GetSigOpCost() const { return sigOpCost; }
|
|
||||||
CAmount GetModifiedFee() const { return m_modified_fee; }
|
|
||||||
size_t DynamicMemoryUsage() const { return nUsageSize; }
|
|
||||||
const LockPoints& GetLockPoints() const { return lockPoints; }
|
|
||||||
|
|
||||||
// Adjusts the descendant state.
|
|
||||||
void UpdateDescendantState(int64_t modifySize, CAmount modifyFee, int64_t modifyCount);
|
|
||||||
// Adjusts the ancestor state
|
|
||||||
void UpdateAncestorState(int64_t modifySize, CAmount modifyFee, int64_t modifyCount, int64_t modifySigOps);
|
|
||||||
// Updates the modified fees with descendants/ancestors.
|
|
||||||
void UpdateModifiedFee(CAmount fee_diff);
|
|
||||||
// Update the LockPoints after a reorg
|
|
||||||
void UpdateLockPoints(const LockPoints& lp);
|
|
||||||
|
|
||||||
uint64_t GetCountWithDescendants() const { return nCountWithDescendants; }
|
|
||||||
uint64_t GetSizeWithDescendants() const { return nSizeWithDescendants; }
|
|
||||||
CAmount GetModFeesWithDescendants() const { return nModFeesWithDescendants; }
|
|
||||||
|
|
||||||
bool GetSpendsCoinbase() const { return spendsCoinbase; }
|
|
||||||
|
|
||||||
uint64_t GetCountWithAncestors() const { return nCountWithAncestors; }
|
|
||||||
uint64_t GetSizeWithAncestors() const { return nSizeWithAncestors; }
|
|
||||||
CAmount GetModFeesWithAncestors() const { return nModFeesWithAncestors; }
|
|
||||||
int64_t GetSigOpCostWithAncestors() const { return nSigOpCostWithAncestors; }
|
|
||||||
|
|
||||||
const Parents& GetMemPoolParentsConst() const { return m_parents; }
|
|
||||||
const Children& GetMemPoolChildrenConst() const { return m_children; }
|
|
||||||
Parents& GetMemPoolParents() const { return m_parents; }
|
|
||||||
Children& GetMemPoolChildren() const { return m_children; }
|
|
||||||
|
|
||||||
mutable size_t vTxHashesIdx; //!< Index in mempool's vTxHashes
|
|
||||||
mutable Epoch::Marker m_epoch_marker; //!< epoch when last touched, useful for graph algorithms
|
|
||||||
};
|
|
||||||
|
|
||||||
// extracts a transaction hash from CTxMemPoolEntry or CTransactionRef
|
// extracts a transaction hash from CTxMemPoolEntry or CTransactionRef
|
||||||
struct mempoolentry_txid
|
struct mempoolentry_txid
|
||||||
{
|
{
|
||||||
|
49
src/txmempool_entry.cpp
Normal file
49
src/txmempool_entry.cpp
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
// Copyright (c) 2009-2022 The Bitcoin Core developers
|
||||||
|
// Distributed under the MIT software license, see the accompanying
|
||||||
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
#include <txmempool_entry.h>
|
||||||
|
|
||||||
|
#include <consensus/amount.h>
|
||||||
|
#include <consensus/validation.h>
|
||||||
|
#include <core_memusage.h>
|
||||||
|
#include <policy/policy.h>
|
||||||
|
#include <policy/settings.h>
|
||||||
|
#include <primitives/transaction.h>
|
||||||
|
#include <util/overflow.h>
|
||||||
|
|
||||||
|
CTxMemPoolEntry::CTxMemPoolEntry(const CTransactionRef& tx, CAmount fee,
|
||||||
|
int64_t time, unsigned int entry_height,
|
||||||
|
bool spends_coinbase, int64_t sigops_cost, LockPoints lp)
|
||||||
|
: tx{tx},
|
||||||
|
nFee{fee},
|
||||||
|
nTxWeight(GetTransactionWeight(*tx)),
|
||||||
|
nUsageSize{RecursiveDynamicUsage(tx)},
|
||||||
|
nTime{time},
|
||||||
|
entryHeight{entry_height},
|
||||||
|
spendsCoinbase{spends_coinbase},
|
||||||
|
sigOpCost{sigops_cost},
|
||||||
|
m_modified_fee{nFee},
|
||||||
|
lockPoints{lp},
|
||||||
|
nSizeWithDescendants{GetTxSize()},
|
||||||
|
nModFeesWithDescendants{nFee},
|
||||||
|
nSizeWithAncestors{GetTxSize()},
|
||||||
|
nModFeesWithAncestors{nFee},
|
||||||
|
nSigOpCostWithAncestors{sigOpCost} {}
|
||||||
|
|
||||||
|
void CTxMemPoolEntry::UpdateModifiedFee(CAmount fee_diff)
|
||||||
|
{
|
||||||
|
nModFeesWithDescendants = SaturatingAdd(nModFeesWithDescendants, fee_diff);
|
||||||
|
nModFeesWithAncestors = SaturatingAdd(nModFeesWithAncestors, fee_diff);
|
||||||
|
m_modified_fee = SaturatingAdd(m_modified_fee, fee_diff);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CTxMemPoolEntry::UpdateLockPoints(const LockPoints& lp)
|
||||||
|
{
|
||||||
|
lockPoints = lp;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t CTxMemPoolEntry::GetTxSize() const
|
||||||
|
{
|
||||||
|
return GetVirtualTransactionSize(nTxWeight, sigOpCost, ::nBytesPerSigOp);
|
||||||
|
}
|
142
src/txmempool_entry.h
Normal file
142
src/txmempool_entry.h
Normal file
@ -0,0 +1,142 @@
|
|||||||
|
// Copyright (c) 2009-2022 The Bitcoin Core developers
|
||||||
|
// Distributed under the MIT software license, see the accompanying
|
||||||
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
#ifndef BITCOIN_TXMEMPOOL_ENTRY_H
|
||||||
|
#define BITCOIN_TXMEMPOOL_ENTRY_H
|
||||||
|
|
||||||
|
#include <consensus/amount.h>
|
||||||
|
#include <primitives/transaction.h>
|
||||||
|
#include <util/epochguard.h>
|
||||||
|
|
||||||
|
#include <chrono>
|
||||||
|
#include <functional>
|
||||||
|
#include <memory>
|
||||||
|
#include <set>
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
class CBlockIndex;
|
||||||
|
|
||||||
|
struct LockPoints {
|
||||||
|
// Will be set to the blockchain height and median time past
|
||||||
|
// values that would be necessary to satisfy all relative locktime
|
||||||
|
// constraints (BIP68) of this tx given our view of block chain history
|
||||||
|
int height{0};
|
||||||
|
int64_t time{0};
|
||||||
|
// As long as the current chain descends from the highest height block
|
||||||
|
// containing one of the inputs used in the calculation, then the cached
|
||||||
|
// values are still valid even after a reorg.
|
||||||
|
CBlockIndex* maxInputBlock{nullptr};
|
||||||
|
};
|
||||||
|
|
||||||
|
struct CompareIteratorByHash {
|
||||||
|
// SFINAE for T where T is either a pointer type (e.g., a txiter) or a reference_wrapper<T>
|
||||||
|
// (e.g. a wrapped CTxMemPoolEntry&)
|
||||||
|
template <typename T>
|
||||||
|
bool operator()(const std::reference_wrapper<T>& a, const std::reference_wrapper<T>& b) const
|
||||||
|
{
|
||||||
|
return a.get().GetTx().GetHash() < b.get().GetTx().GetHash();
|
||||||
|
}
|
||||||
|
template <typename T>
|
||||||
|
bool operator()(const T& a, const T& b) const
|
||||||
|
{
|
||||||
|
return a->GetTx().GetHash() < b->GetTx().GetHash();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/** \class CTxMemPoolEntry
|
||||||
|
*
|
||||||
|
* CTxMemPoolEntry stores data about the corresponding transaction, as well
|
||||||
|
* as data about all in-mempool transactions that depend on the transaction
|
||||||
|
* ("descendant" transactions).
|
||||||
|
*
|
||||||
|
* When a new entry is added to the mempool, we update the descendant state
|
||||||
|
* (nCountWithDescendants, nSizeWithDescendants, and nModFeesWithDescendants) for
|
||||||
|
* all ancestors of the newly added transaction.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
class CTxMemPoolEntry
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
typedef std::reference_wrapper<const CTxMemPoolEntry> CTxMemPoolEntryRef;
|
||||||
|
// two aliases, should the types ever diverge
|
||||||
|
typedef std::set<CTxMemPoolEntryRef, CompareIteratorByHash> Parents;
|
||||||
|
typedef std::set<CTxMemPoolEntryRef, CompareIteratorByHash> Children;
|
||||||
|
|
||||||
|
private:
|
||||||
|
const CTransactionRef tx;
|
||||||
|
mutable Parents m_parents;
|
||||||
|
mutable Children m_children;
|
||||||
|
const CAmount nFee; //!< Cached to avoid expensive parent-transaction lookups
|
||||||
|
const size_t nTxWeight; //!< ... and avoid recomputing tx weight (also used for GetTxSize())
|
||||||
|
const size_t nUsageSize; //!< ... and total memory usage
|
||||||
|
const int64_t nTime; //!< Local time when entering the mempool
|
||||||
|
const unsigned int entryHeight; //!< Chain height when entering the mempool
|
||||||
|
const bool spendsCoinbase; //!< keep track of transactions that spend a coinbase
|
||||||
|
const int64_t sigOpCost; //!< Total sigop cost
|
||||||
|
CAmount m_modified_fee; //!< Used for determining the priority of the transaction for mining in a block
|
||||||
|
LockPoints lockPoints; //!< Track the height and time at which tx was final
|
||||||
|
|
||||||
|
// Information about descendants of this transaction that are in the
|
||||||
|
// mempool; if we remove this transaction we must remove all of these
|
||||||
|
// descendants as well.
|
||||||
|
uint64_t nCountWithDescendants{1}; //!< number of descendant transactions
|
||||||
|
uint64_t nSizeWithDescendants; //!< ... and size
|
||||||
|
CAmount nModFeesWithDescendants; //!< ... and total fees (all including us)
|
||||||
|
|
||||||
|
// Analogous statistics for ancestor transactions
|
||||||
|
uint64_t nCountWithAncestors{1};
|
||||||
|
uint64_t nSizeWithAncestors;
|
||||||
|
CAmount nModFeesWithAncestors;
|
||||||
|
int64_t nSigOpCostWithAncestors;
|
||||||
|
|
||||||
|
public:
|
||||||
|
CTxMemPoolEntry(const CTransactionRef& tx, CAmount fee,
|
||||||
|
int64_t time, unsigned int entry_height,
|
||||||
|
bool spends_coinbase,
|
||||||
|
int64_t sigops_cost, LockPoints lp);
|
||||||
|
|
||||||
|
const CTransaction& GetTx() const { return *this->tx; }
|
||||||
|
CTransactionRef GetSharedTx() const { return this->tx; }
|
||||||
|
const CAmount& GetFee() const { return nFee; }
|
||||||
|
size_t GetTxSize() const;
|
||||||
|
size_t GetTxWeight() const { return nTxWeight; }
|
||||||
|
std::chrono::seconds GetTime() const { return std::chrono::seconds{nTime}; }
|
||||||
|
unsigned int GetHeight() const { return entryHeight; }
|
||||||
|
int64_t GetSigOpCost() const { return sigOpCost; }
|
||||||
|
CAmount GetModifiedFee() const { return m_modified_fee; }
|
||||||
|
size_t DynamicMemoryUsage() const { return nUsageSize; }
|
||||||
|
const LockPoints& GetLockPoints() const { return lockPoints; }
|
||||||
|
|
||||||
|
// Adjusts the descendant state.
|
||||||
|
void UpdateDescendantState(int64_t modifySize, CAmount modifyFee, int64_t modifyCount);
|
||||||
|
// Adjusts the ancestor state
|
||||||
|
void UpdateAncestorState(int64_t modifySize, CAmount modifyFee, int64_t modifyCount, int64_t modifySigOps);
|
||||||
|
// Updates the modified fees with descendants/ancestors.
|
||||||
|
void UpdateModifiedFee(CAmount fee_diff);
|
||||||
|
// Update the LockPoints after a reorg
|
||||||
|
void UpdateLockPoints(const LockPoints& lp);
|
||||||
|
|
||||||
|
uint64_t GetCountWithDescendants() const { return nCountWithDescendants; }
|
||||||
|
uint64_t GetSizeWithDescendants() const { return nSizeWithDescendants; }
|
||||||
|
CAmount GetModFeesWithDescendants() const { return nModFeesWithDescendants; }
|
||||||
|
|
||||||
|
bool GetSpendsCoinbase() const { return spendsCoinbase; }
|
||||||
|
|
||||||
|
uint64_t GetCountWithAncestors() const { return nCountWithAncestors; }
|
||||||
|
uint64_t GetSizeWithAncestors() const { return nSizeWithAncestors; }
|
||||||
|
CAmount GetModFeesWithAncestors() const { return nModFeesWithAncestors; }
|
||||||
|
int64_t GetSigOpCostWithAncestors() const { return nSigOpCostWithAncestors; }
|
||||||
|
|
||||||
|
const Parents& GetMemPoolParentsConst() const { return m_parents; }
|
||||||
|
const Children& GetMemPoolChildrenConst() const { return m_children; }
|
||||||
|
Parents& GetMemPoolParents() const { return m_parents; }
|
||||||
|
Children& GetMemPoolChildren() const { return m_children; }
|
||||||
|
|
||||||
|
mutable size_t vTxHashesIdx; //!< Index in mempool's vTxHashes
|
||||||
|
mutable Epoch::Marker m_epoch_marker; //!< epoch when last touched, useful for graph algorithms
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif // BITCOIN_TXMEMPOOL_ENTRY_H
|
@ -42,6 +42,7 @@
|
|||||||
#include <tinyformat.h>
|
#include <tinyformat.h>
|
||||||
#include <txdb.h>
|
#include <txdb.h>
|
||||||
#include <txmempool.h>
|
#include <txmempool.h>
|
||||||
|
#include <txmempool_entry.h>
|
||||||
#include <uint256.h>
|
#include <uint256.h>
|
||||||
#include <undo.h>
|
#include <undo.h>
|
||||||
#include <util/check.h> // For NDEBUG compile time check
|
#include <util/check.h> // For NDEBUG compile time check
|
||||||
|
@ -15,7 +15,6 @@ EXPECTED_CIRCULAR_DEPENDENCIES = (
|
|||||||
"chainparamsbase -> util/system -> chainparamsbase",
|
"chainparamsbase -> util/system -> chainparamsbase",
|
||||||
"node/blockstorage -> validation -> node/blockstorage",
|
"node/blockstorage -> validation -> node/blockstorage",
|
||||||
"node/utxo_snapshot -> validation -> node/utxo_snapshot",
|
"node/utxo_snapshot -> validation -> node/utxo_snapshot",
|
||||||
"policy/fees -> txmempool -> policy/fees",
|
|
||||||
"qt/addresstablemodel -> qt/walletmodel -> qt/addresstablemodel",
|
"qt/addresstablemodel -> qt/walletmodel -> qt/addresstablemodel",
|
||||||
"qt/recentrequeststablemodel -> qt/walletmodel -> qt/recentrequeststablemodel",
|
"qt/recentrequeststablemodel -> qt/walletmodel -> qt/recentrequeststablemodel",
|
||||||
"qt/sendcoinsdialog -> qt/walletmodel -> qt/sendcoinsdialog",
|
"qt/sendcoinsdialog -> qt/walletmodel -> qt/sendcoinsdialog",
|
||||||
|
@ -53,6 +53,7 @@ unsigned-integer-overflow:policy/fees.cpp
|
|||||||
unsigned-integer-overflow:prevector.h
|
unsigned-integer-overflow:prevector.h
|
||||||
unsigned-integer-overflow:script/interpreter.cpp
|
unsigned-integer-overflow:script/interpreter.cpp
|
||||||
unsigned-integer-overflow:txmempool.cpp
|
unsigned-integer-overflow:txmempool.cpp
|
||||||
|
unsigned-integer-overflow:txmempool_entry.cpp
|
||||||
implicit-integer-sign-change:compat/stdin.cpp
|
implicit-integer-sign-change:compat/stdin.cpp
|
||||||
implicit-integer-sign-change:compressor.h
|
implicit-integer-sign-change:compressor.h
|
||||||
implicit-integer-sign-change:crypto/
|
implicit-integer-sign-change:crypto/
|
||||||
@ -62,6 +63,7 @@ implicit-integer-sign-change:script/bitcoinconsensus.cpp
|
|||||||
implicit-integer-sign-change:script/interpreter.cpp
|
implicit-integer-sign-change:script/interpreter.cpp
|
||||||
implicit-integer-sign-change:serialize.h
|
implicit-integer-sign-change:serialize.h
|
||||||
implicit-integer-sign-change:txmempool.cpp
|
implicit-integer-sign-change:txmempool.cpp
|
||||||
|
implicit-integer-sign-change:txmempool_entry.cpp
|
||||||
implicit-signed-integer-truncation:crypto/
|
implicit-signed-integer-truncation:crypto/
|
||||||
implicit-unsigned-integer-truncation:crypto/
|
implicit-unsigned-integer-truncation:crypto/
|
||||||
shift-base:arith_uint256.cpp
|
shift-base:arith_uint256.cpp
|
||||||
|
Loading…
x
Reference in New Issue
Block a user