Files
bitcoin/src/bench
Ryan Ofsky 33f8f8ae4c Merge bitcoin/bitcoin#30221: wallet: Ensure best block matches wallet scan state
30a94b1ab9 test, wallet: Remove concurrent writes test (Ava Chow)
b44b7c03fe wallet: Write best block record on unload (Ava Chow)
876a2585a8 wallet: Remove unnecessary database Close step on shutdown (Ava Chow)
98a1a5275c wallet: Remove chainStateFlushed (Ava Chow)
7fd3e1cf0c wallet, bench: Write a bestblock record in WalletMigration (Ava Chow)
6d3a8b195a wallet: Replace chainStateFlushed in loading with SetLastBlockProcessed (Ava Chow)
7bacabb204 wallet: Update best block record after block dis/connect (Ava Chow)

Pull request description:

  Implements the idea discussed in https://github.com/bitcoin/bitcoin/pull/29652#issuecomment-2010579484

  Currently, `m_last_block_processed` and `m_last_block_processed_height` are not guaranteed to match the block locator stored in the wallet, nor do either of those fields actually represent the last block that the wallet is synced up to. This is confusing and unintuitive.

  This PR changes those last block fields to be updated whenever the wallet makes a change to the db for new transaction state found in new blocks. Whenever a block is received that contains a transaction relevant to the wallet, the last block locator will now be written to disk. Furthermore, every block disconnection will now write an updated locator.

  To ensure that the locator is relatively recent and loading rescans are fairly quick in the event of unplanned shutdown, it is also now written every 144 blocks (~1 day). Additionally it is now written when the wallet is unloaded so that it is accurate when the wallet is loaded again.

  Lastly, the `chainstateFlushed` notification in the wallet is changed to be a no-op. The best block locator record is no longer written when `chainstateFlushed` is received from the node since it should already be mostly up to date.

ACKs for top commit:
  rkrux:
    ACK 30a94b1ab9
  mzumsande:
    Code Review ACK 30a94b1ab9
  ryanofsky:
    Code review ACK 30a94b1ab9. Only changes since last review are using WriteBestBlock method more places and updating comments.

Tree-SHA512: 46117541f8aaf13dde57430e813b4bbbd5e146e2632769675803c8e65a82f149a7cc6026489a127d32684b90124bd2b7c28216dbcfa6a47447300e8f3814e029
2025-05-19 15:50:51 -04:00
..
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-09-05 10:57:19 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2023-11-14 20:22:12 +01:00
2024-02-28 17:23:54 +00:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-09-05 10:57:19 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00
2024-08-27 07:33:59 +02:00