aboutsummaryrefslogtreecommitdiff
path: root/src/validation.cpp
diff options
context:
space:
mode:
authorGreg Sanders <gsanders87@gmail.com>2023-09-13 14:20:14 -0400
committerGreg Sanders <gsanders87@gmail.com>2023-09-14 13:32:01 -0400
commit275579d8c133c066212a26423639956e2576e97a (patch)
tree260d90c51d878f75f7319051110509c01ef5ba1b /src/validation.cpp
parentf1a9fd627b1a669c4dfab797da42825230708f2a (diff)
downloadbitcoin-275579d8c133c066212a26423639956e2576e97a.tar.xz
Remove MemPoolAccept::m_limits, only have local copies for carveouts
Diffstat (limited to 'src/validation.cpp')
-rw-r--r--src/validation.cpp26
1 files changed, 14 insertions, 12 deletions
diff --git a/src/validation.cpp b/src/validation.cpp
index 6e0addc877..cf4728c214 100644
--- a/src/validation.cpp
+++ b/src/validation.cpp
@@ -432,8 +432,7 @@ public:
m_pool(mempool),
m_view(&m_dummy),
m_viewmempool(&active_chainstate.CoinsTip(), m_pool),
- m_active_chainstate(active_chainstate),
- m_limits{m_pool.m_limits}
+ m_active_chainstate(active_chainstate)
{
}
@@ -683,8 +682,6 @@ private:
Chainstate& m_active_chainstate;
- CTxMemPool::Limits m_limits;
-
/** Whether the transaction(s) would replace any mempool transactions. If so, RBF rules apply. */
bool m_rbf{false};
};
@@ -873,6 +870,11 @@ bool MemPoolAccept::PreChecks(ATMPArgs& args, Workspace& ws)
if (!bypass_limits && !args.m_package_feerates && !CheckFeeRate(ws.m_vsize, ws.m_modified_fees, state)) return false;
ws.m_iters_conflicting = m_pool.GetIterSet(ws.m_conflicts);
+
+ // Note that these modifications are only applicable to single transaction scenarios;
+ // carve-outs and package RBF are disabled for multi-transaction evaluations.
+ CTxMemPool::Limits maybe_rbf_limits = m_pool.m_limits;
+
// Calculate in-mempool ancestors, up to a limit.
if (ws.m_conflicts.size() == 1) {
// In general, when we receive an RBF transaction with mempool conflicts, we want to know whether we
@@ -905,11 +907,11 @@ bool MemPoolAccept::PreChecks(ATMPArgs& args, Workspace& ws)
assert(ws.m_iters_conflicting.size() == 1);
CTxMemPool::txiter conflict = *ws.m_iters_conflicting.begin();
- m_limits.descendant_count += 1;
- m_limits.descendant_size_vbytes += conflict->GetSizeWithDescendants();
+ maybe_rbf_limits.descendant_count += 1;
+ maybe_rbf_limits.descendant_size_vbytes += conflict->GetSizeWithDescendants();
}
- auto ancestors{m_pool.CalculateMemPoolAncestors(*entry, m_limits)};
+ auto ancestors{m_pool.CalculateMemPoolAncestors(*entry, maybe_rbf_limits)};
if (!ancestors) {
// If CalculateMemPoolAncestors fails second time, we want the original error string.
// Contracting/payment channels CPFP carve-out:
@@ -925,9 +927,9 @@ bool MemPoolAccept::PreChecks(ATMPArgs& args, Workspace& ws)
// this, see https://lists.linuxfoundation.org/pipermail/bitcoin-dev/2018-November/016518.html
CTxMemPool::Limits cpfp_carve_out_limits{
.ancestor_count = 2,
- .ancestor_size_vbytes = m_limits.ancestor_size_vbytes,
- .descendant_count = m_limits.descendant_count + 1,
- .descendant_size_vbytes = m_limits.descendant_size_vbytes + EXTRA_DESCENDANT_TX_SIZE_LIMIT,
+ .ancestor_size_vbytes = maybe_rbf_limits.ancestor_size_vbytes,
+ .descendant_count = maybe_rbf_limits.descendant_count + 1,
+ .descendant_size_vbytes = maybe_rbf_limits.descendant_size_vbytes + EXTRA_DESCENDANT_TX_SIZE_LIMIT,
};
const auto error_message{util::ErrorString(ancestors).original};
if (ws.m_vsize > EXTRA_DESCENDANT_TX_SIZE_LIMIT) {
@@ -1010,7 +1012,7 @@ bool MemPoolAccept::PackageMempoolChecks(const std::vector<CTransactionRef>& txn
{ return !m_pool.exists(GenTxid::Txid(tx->GetHash()));}));
std::string err_string;
- if (!m_pool.CheckPackageLimits(txns, m_limits, err_string)) {
+ if (!m_pool.CheckPackageLimits(txns, err_string)) {
// This is a package-wide error, separate from an individual transaction error.
return package_state.Invalid(PackageValidationResult::PCKG_POLICY, "package-mempool-limits", err_string);
}
@@ -1165,7 +1167,7 @@ bool MemPoolAccept::SubmitPackage(const ATMPArgs& args, std::vector<Workspace>&
// Re-calculate mempool ancestors to call addUnchecked(). They may have changed since the
// last calculation done in PreChecks, since package ancestors have already been submitted.
{
- auto ancestors{m_pool.CalculateMemPoolAncestors(*ws.m_entry, m_limits)};
+ auto ancestors{m_pool.CalculateMemPoolAncestors(*ws.m_entry, m_pool.m_limits)};
if(!ancestors) {
results.emplace(ws.m_ptx->GetWitnessHash(), MempoolAcceptResult::Failure(ws.m_state));
// Since PreChecks() and PackageMempoolChecks() both enforce limits, this should never fail.