fuzz: mini_miner_selection: ASSERT: mock_template_txids.size() <= blocktemplate->block.vtx.size() #30367
issue maflcko openend this issue on July 1, 2024-
maflcko commented at 10:05 am on July 1, 2024: member
-
maflcko added the label Wallet on Jul 1, 2024
-
maflcko added the label Tests on Jul 1, 2024
-
maflcko commented at 10:20 am on July 1, 2024: member
0$ echo 'AyABAAAAACAg/wAAAAAA/yD/AQAAAAAg/yCu/w==' | base64 --decode > /tmp/oss-fuzz-crash 1$ FUZZ=mini_miner_selection ./src/test/fuzz/fuzz /tmp/oss-fuzz-crash
-
dergoegge commented at 10:12 am on July 9, 2024: membercc @glozow @murchandamus (in case you missed it) would be nice to have this fixed and also have an explanation of the actual bug, since it is somewhat of a mystery why it’s so hard to find
-
glozow commented at 11:49 am on July 9, 2024: member
Ooh fun, this found a difference between
MiniMiner
andCTxMemPool
’s comparators , which boils down to a lack of precision inCFeeRate
.Debugging, the 3 entries in mempool are
A <- B <- C A: 1sat/264vB B: 0sat/178vB C:1sat/178vB
The minimum feerate, i.e.
target_feerate
orblockMinFeeRate
is 1sat/vB.BlockAssembler
selects A.MiniMiner
selects ABC. They are both wrong to do so, since all transactions have a feerate below 1sat/vB. This is becauseCFeeRate
roundsminfeerate.GetFee(packagesize)
up to 1sat, and theif
condition succeeds. But this isn’t the bug that was hit by the fuzzer.The actual bug is in the comparators:
CompareTxMemPoolentryByAncestorFee
inCTxMemPool
casts everything todouble
s and doesn’t compare usingCFeeRate
objects. It can see that A’s feerate is 1/264=0.0038sat/vB, while C’s ancestor feerate is 2/260=0.0032sat/vB, and orders A before C.CFeeRate
only stores satoshis per KvB, soCFeerate(1, 264)
andCFeeRate(2, 260)
both becomeCFeerate(nSatoshisPerK=3)
, i.e. 0.003sat/vB.The
AncestorFeerateComparator
inMiniMiner
comparesCFeeRate
s and basically sees that 3 == 3, tiebreaks using txid, and selects package ABC first. You can observe that the fuzz input in this issue succeeds if you multiply all fees by 10 before passing them to theCFeeRate
constructors inAncestorFeerateComparator
(then it’s comparing 32 and 38). -
glozow commented at 12:01 pm on July 9, 2024: member
I can open a PR to change
MiniMiner
to store/compareFeeFrac
s, which by itself would fix the imprecision bug, though I’m not sure if that’ll make it identical to txmempool.Changing txmempool seems less important imo since there is no current imprecision bug, and perhaps cluster mempool plans to do this anyway.
-
fanquake closed this on Jul 15, 2024
-
fanquake referenced this in commit 01ed4927f0 on Jul 15, 2024
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-21 06:12 UTC
More mirrored repositories can be found on mirror.b10c.me