From 32b677bf4f2b4a718f62683e1daec87a3a83b83d Mon Sep 17 00:00:00 2001 From: Brooks Date: Tue, 12 Nov 2024 20:42:52 -0500 Subject: [PATCH] Verifies accounts before clean/shrink (#3592) --- runtime/src/bank.rs | 63 +++++++++++++++++++++++++-------------------- 1 file changed, 35 insertions(+), 28 deletions(-) diff --git a/runtime/src/bank.rs b/runtime/src/bank.rs index 1242d125b475ae..1626b51faaf004 100644 --- a/runtime/src/bank.rs +++ b/runtime/src/bank.rs @@ -6190,6 +6190,41 @@ impl Bank { base: Option<(Slot, /*capitalization*/ u64)>, duplicates_lt_hash: Option>, ) -> bool { + // If we verify the accounts using the lattice-based hash *and* with storages (as opposed + // to the index), then we rely on the DuplicatesLtHash as given by generate_index(). Since + // the duplicates are based on a specific set of storages, we must use the exact same + // storages to do the lattice-based accounts verification. This means we must wait to + // clean/shrink until *after* we've gotten Arcs to the storages (this prevents their + // untimely removal). Simply, we call `verify_accounts_hash()` before we call `clean` or + // `shrink`. + let (verified_accounts, verify_accounts_time_us) = measure_us!({ + let should_verify_accounts = !self.rc.accounts.accounts_db.skip_initial_hash_calc; + if should_verify_accounts { + info!("Verifying accounts..."); + let verified = self.verify_accounts_hash( + base, + VerifyAccountsHashConfig { + test_hash_calculation, + ignore_mismatch: false, + require_rooted_bank: false, + run_in_background: true, + store_hash_raw_data_for_debug: false, + }, + duplicates_lt_hash, + ); + info!("Verifying accounts... In background."); + verified + } else { + info!("Verifying accounts... Skipped."); + self.rc + .accounts + .accounts_db + .verify_accounts_hash_in_bg + .verification_complete(); + true + } + }); + let (_, clean_time_us) = measure_us!({ let should_clean = force_clean || (!skip_shrink && self.slot() > 0); if should_clean { @@ -6225,34 +6260,6 @@ impl Bank { } }); - let (verified_accounts, verify_accounts_time_us) = measure_us!({ - let should_verify_accounts = !self.rc.accounts.accounts_db.skip_initial_hash_calc; - if should_verify_accounts { - info!("Verifying accounts..."); - let verified = self.verify_accounts_hash( - base, - VerifyAccountsHashConfig { - test_hash_calculation, - ignore_mismatch: false, - require_rooted_bank: false, - run_in_background: true, - store_hash_raw_data_for_debug: false, - }, - duplicates_lt_hash, - ); - info!("Verifying accounts... In background."); - verified - } else { - info!("Verifying accounts... Skipped."); - self.rc - .accounts - .accounts_db - .verify_accounts_hash_in_bg - .verification_complete(); - true - } - }); - info!("Verifying bank..."); let (verified_bank, verify_bank_time_us) = measure_us!(self.verify_hash()); info!("Verifying bank... Done.");