Skip to content

Commit

Permalink
remove cond_var
Browse files Browse the repository at this point in the history
  • Loading branch information
HaoranYi committed Nov 6, 2024
1 parent 144925e commit c34e0ed
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 18 deletions.
21 changes: 7 additions & 14 deletions accounts-db/src/verify_accounts_hash_in_background.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,6 @@ use {
pub struct VerifyAccountsHashInBackground {
/// true when verification has completed or never had to run in background
pub verified: Arc<AtomicBool>,
/// enable waiting for verification to become complete
complete: Arc<WaitableCondvar>,
/// thread doing verification
thread: Mutex<Option<JoinHandle<bool>>>,
/// set when background thread has completed
Expand All @@ -27,7 +25,6 @@ impl Default for VerifyAccountsHashInBackground {
fn default() -> Self {
// initialize, expecting possible background verification to be started
Self {
complete: Arc::default(),
// with default initialization, 'verified' is false
verified: Arc::new(AtomicBool::new(false)),
// no thread to start with
Expand All @@ -47,7 +44,6 @@ impl VerifyAccountsHashInBackground {

/// notify that the bg process has completed
pub fn background_finished(&self) {
self.complete.notify_all();
self.background_completed.store(true, Ordering::Release);
}

Expand All @@ -59,7 +55,7 @@ impl VerifyAccountsHashInBackground {
}

/// block until bg process is complete
pub fn wait_for_complete(&self) {
pub fn join_background_thread(&self) {
// just now completing
let mut lock = self.thread.lock().unwrap();
if lock.is_none() {
Expand All @@ -81,14 +77,11 @@ impl VerifyAccountsHashInBackground {
// already completed
return true;
}
if self.complete.wait_timeout(Duration::default())
&& !self.background_completed.load(Ordering::Acquire)
{
// timed out, so not complete
if !self.background_completed.load(Ordering::Acquire) {
false
} else {
// Did not time out, so thread finished. Join it.
self.wait_for_complete();
// background thread has completed, so join the thread and panic if verify fails.
self.join_background_thread();
true
}
}
Expand Down Expand Up @@ -134,7 +127,7 @@ pub mod tests {
solana_logger::setup();
let verify = Arc::new(VerifyAccountsHashInBackground::default());
start_thread_and_return(&verify, true, || {});
verify.wait_for_complete();
verify.join_background_thread();
assert!(verify.check_complete());
}

Expand All @@ -143,7 +136,7 @@ pub mod tests {
fn test_panic() {
let verify = Arc::new(VerifyAccountsHashInBackground::default());
start_thread_and_return(&verify, false, || {});
verify.wait_for_complete();
verify.join_background_thread();
assert!(!verify.check_complete());
}

Expand All @@ -159,7 +152,7 @@ pub mod tests {
});
assert!(!verify.check_complete());
finish.store(true, Ordering::Relaxed);
verify.wait_for_complete();
verify.join_background_thread();
assert!(verify.check_complete());
}
}
2 changes: 1 addition & 1 deletion ledger-tool/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2101,7 +2101,7 @@ fn main() {
.accounts
.accounts_db
.verify_accounts_hash_in_bg
.wait_for_complete();
.join_background_thread();

let child_bank_required = rent_burn_percentage.is_ok()
|| hashes_per_tick.is_some()
Expand Down
6 changes: 3 additions & 3 deletions runtime/src/bank.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5641,7 +5641,7 @@ impl Bank {
accounts
.accounts_db
.verify_accounts_hash_in_bg
.wait_for_complete();
.join_background_thread();

let slot = self.slot();

Expand Down Expand Up @@ -5968,7 +5968,7 @@ impl Bank {
.accounts
.accounts_db
.verify_accounts_hash_in_bg
.wait_for_complete();
.join_background_thread();
self.rc
.accounts
.accounts_db
Expand Down Expand Up @@ -7199,7 +7199,7 @@ impl Bank {
.accounts
.accounts_db
.verify_accounts_hash_in_bg
.wait_for_complete()
.join_background_thread()
}

pub fn get_sysvar_cache_for_tests(&self) -> SysvarCache {
Expand Down

0 comments on commit c34e0ed

Please sign in to comment.