From ec371403e1f8d2193e8e5a25dc872afd46bd15b7 Mon Sep 17 00:00:00 2001 From: behzad nouri Date: Tue, 11 Jun 2024 08:32:24 -0500 Subject: [PATCH] patches bug in chained Merkle root update --- .../broadcast_stage/standard_broadcast_run.rs | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/turbine/src/broadcast_stage/standard_broadcast_run.rs b/turbine/src/broadcast_stage/standard_broadcast_run.rs index 8e948ce8e85947..f108fc08226a6b 100644 --- a/turbine/src/broadcast_stage/standard_broadcast_run.rs +++ b/turbine/src/broadcast_stage/standard_broadcast_run.rs @@ -243,20 +243,20 @@ impl StandardBroadcastRun { return Err(Error::DuplicateSlotBroadcast(bank.slot())); } // Reinitialize state for this slot. - let chained_merkle_root = (self.slot == bank.parent_slot()) - .then_some(self.chained_merkle_root) - .ok_or_else(|| { - broadcast_utils::get_chained_merkle_root_from_parent( - bank.slot(), - bank.parent_slot(), - blockstore, - ) - }) - .unwrap_or_else(|err| { + let chained_merkle_root = if self.slot == bank.parent_slot() { + self.chained_merkle_root + } else { + broadcast_utils::get_chained_merkle_root_from_parent( + bank.slot(), + bank.parent_slot(), + blockstore, + ) + .unwrap_or_else(|err: Error| { error!("Unknown chained Merkle root: {err:?}"); process_stats.err_unknown_chained_merkle_root += 1; Hash::default() - }); + }) + }; self.slot = bank.slot(); self.parent = bank.parent_slot(); self.chained_merkle_root = chained_merkle_root;