warp_from_parents works with write_cache enabled (#29185)
This commit is contained in:
parent
cd9f1f1862
commit
631a98a3b6
|
@ -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,
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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,
|
||||||
))
|
))
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue