The coins cache (the CCoinsView* stack, CCoinsViewCache, and friends) is a correctness- and performance-critical part of validation, IBD, and assumeutxo.
Over time it has accumulated subtle invariants and legacy states (around cache entry flags, spent coin handling, and error catching), and we have been chipping away at it through focused refactors, bugfixes, tests, and performance work.
This issue tracks the related PRs to help reviewers see how they fit together. The overall aim is fewer error cases, cleaner cache layering, and parallel validation.
PRs needing review
Testing
- #34887 - compare
CDBWrapperagainst an in-memory oracle - #34866 - exercise LevelDB reads under concurrent index-like access.
Remove invalid cache states
- #34864 - remove unreachable FRESH-but-not-DIRTY state from code and tests.
Simplify view hierarchy
- #35180 - narrow the public
CCoinsViewCacheAPI around reset internals. - #34320 - replace
HaveCoin()withGetCoin(). - #34132 - centralize coins DB read failures in
CDBWrapperand remove the error-catcher layer.
Optimizations
- #35215 - simplified in-memory utxo set key hashing
- #35295 - async input prefetch during
ConnectBlock. - #35195 - let libstdc++ cache UTXO outpoint hash codes for faster coins-map operations.
Other
- #35200 - replace the oversized-
dbcachewarning cliff with a reserved-memory formula. - #33854 - skip early chain activation during reindex when headers are below minimum chainwork (see #31494).
- #32317 - move UTXO access to
SpendBlock(kernel API, Utreexo, SwiftSync). - #35205 - route node, Qt, and kernel through the shared two-tier
dbcachedefault.
Recently merged
- #31449 -
getblockstatsRPC UTXO overhead fix - #34124 - make
CCoinsViewpurely virtual, add explicitCCoinsViewEmpty. - #34692 - increase the default dbcache value from 450MiB to 1024MiB
- #34576 - batch ThreadPool submissions under one lock for input-fetcher prep
- #34655 - constrain coins-view fuzz inputs to valid cache caller states.
- #34165 - add non-mutating
PeekCoin()to avoid polluting the main cache. - #33512 - track dirty entries so flush progress reflects actual writes.
- #33680 - split
FORCE_SYNC/FORCE_FLUSH, keep cache warm forscantxoutset/gettxoutsetinfo/snapshots. - #34164 - add
Reset()and reusable view to discard failed connects cheaply. - #34207 - ensure
GetCoin()only returns unspent coins, align tests with production. - #34253 - cache IBD status so readers do not take
cs_main. - #33866 - remove always-true return from
BatchWrite. - #33657 - allow reading partial block data (useful for bindex).
- #33602 - reduce map lookups in
BatchWrite. - #33333 - warn when
-dbcacheexceeds RAM cap.
IRC context: https://bitcoin-irc.chaincode.com/bitcoin-core-dev/2026-01-08