warp_from_parents works with write_cache enabled (#29185)

This commit is contained in:
Jeff Washington (jwash) 2022-12-09 16:28:18 -06:00 committed by GitHub
parent cd9f1f1862
commit 631a98a3b6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 13 additions and 4 deletions

View File

@ -1668,6 +1668,7 @@ fn maybe_warp_slot(
&root_bank, &root_bank,
&Pubkey::default(), &Pubkey::default(),
warp_slot, warp_slot,
solana_runtime::accounts_db::CalcAccountsHashDataSource::Storages,
)); ));
bank_forks.set_root( bank_forks.set_root(
warp_slot, warp_slot,

View File

@ -594,6 +594,7 @@ fn test_epoch_accounts_hash_and_warping() {
&bank, &bank,
&Pubkey::default(), &Pubkey::default(),
eah_stop_slot_in_next_epoch, eah_stop_slot_in_next_epoch,
solana_runtime::accounts_db::CalcAccountsHashDataSource::IndexForTests,
)); ));
let bank = bank_forks.write().unwrap().insert(Bank::new_from_parent( let bank = bank_forks.write().unwrap().insert(Bank::new_from_parent(
&bank, &bank,
@ -625,6 +626,7 @@ fn test_epoch_accounts_hash_and_warping() {
&bank, &bank,
&Pubkey::default(), &Pubkey::default(),
eah_start_slot_in_next_epoch, eah_start_slot_in_next_epoch,
solana_runtime::accounts_db::CalcAccountsHashDataSource::Storages,
)); ));
let bank = bank_forks.write().unwrap().insert(Bank::new_from_parent( let bank = bank_forks.write().unwrap().insert(Bank::new_from_parent(
&bank, &bank,

View File

@ -3229,6 +3229,7 @@ fn main() {
&bank, &bank,
bank.collector_id(), bank.collector_id(),
warp_slot, warp_slot,
solana_runtime::accounts_db::CalcAccountsHashDataSource::IndexForTests,
)) ))
} else { } else {
bank bank

View File

@ -1125,6 +1125,8 @@ impl ProgramTestContext {
&bank, &bank,
&Pubkey::default(), &Pubkey::default(),
pre_warp_slot, pre_warp_slot,
// some warping tests cannot use the append vecs because of the sequence of adding roots and flushing
solana_runtime::accounts_db::CalcAccountsHashDataSource::IndexForTests,
)) ))
}; };

View File

@ -1881,7 +1881,12 @@ impl Bank {
/// * Adjusts the new bank's tick height to avoid having to run PoH for millions of slots /// * Adjusts the new bank's tick height to avoid having to run PoH for millions of slots
/// * Freezes the new bank, assuming that the user will `Bank::new_from_parent` from this bank /// * Freezes the new bank, assuming that the user will `Bank::new_from_parent` from this bank
/// * Calculates and sets the epoch accounts hash from the parent /// * Calculates and sets the epoch accounts hash from the parent
pub fn warp_from_parent(parent: &Arc<Bank>, collector_id: &Pubkey, slot: Slot) -> Self { pub fn warp_from_parent(
parent: &Arc<Bank>,
collector_id: &Pubkey,
slot: Slot,
data_source: CalcAccountsHashDataSource,
) -> Self {
parent.freeze(); parent.freeze();
parent parent
.rc .rc
@ -1889,9 +1894,7 @@ impl Bank {
.accounts_db .accounts_db
.epoch_accounts_hash_manager .epoch_accounts_hash_manager
.set_in_flight(parent.slot()); .set_in_flight(parent.slot());
parent.force_flush_accounts_cache(); let accounts_hash = parent.update_accounts_hash(data_source, false, true);
let accounts_hash =
parent.update_accounts_hash(CalcAccountsHashDataSource::Storages, false, true);
let epoch_accounts_hash = accounts_hash.into(); let epoch_accounts_hash = accounts_hash.into();
parent parent
.rc .rc