diff options
author | glozow <gloriajzhao@gmail.com> | 2021-12-03 18:03:16 +0000 |
---|---|---|
committer | glozow <gloriajzhao@gmail.com> | 2021-12-06 15:30:06 +0000 |
commit | b4adc5ad6769e4a5a6179dfff271cd4c9dc47a5b (patch) | |
tree | f1480b9141908f2299d160790de098bc7590159b /src/txmempool.cpp | |
parent | b6002b07a36f0d58dc6becd04bfcf78599056b7c (diff) |
[bugfix] update lockpoints correctly during reorg
During a reorg, we re-check timelocks on all mempool entries using
CheckSequenceLocks(useExistingLockPoints=false) and remove any
now-invalid entries. CheckSequenceLocks() also mutates the LockPoints
passed in, and we update valid entries' LockPoints using
update_lock_points. Thus, update_lock_points(lp) needs to be called
right after CheckSequenceLocks(lp), otherwise we lose the data in lp.
commit bedf246 introduced a bug by separating those two loops.
Diffstat (limited to 'src/txmempool.cpp')
-rw-r--r-- | src/txmempool.cpp | 5 |
1 files changed, 1 insertions, 4 deletions
diff --git a/src/txmempool.cpp b/src/txmempool.cpp index ba1bdb197b..26cb2ff4b4 100644 --- a/src/txmempool.cpp +++ b/src/txmempool.cpp @@ -639,10 +639,7 @@ void CTxMemPool::removeForReorg(CChain& chain, std::function<bool(txiter)> check } RemoveStaged(setAllRemoves, false, MemPoolRemovalReason::REORG); for (indexed_transaction_set::const_iterator it = mapTx.begin(); it != mapTx.end(); it++) { - const LockPoints lp{it->GetLockPoints()}; - if (!TestLockPointValidity(chain, lp)) { - mapTx.modify(it, update_lock_points(lp)); - } + assert(TestLockPointValidity(chain, it->GetLockPoints())); } } |