From 256ed337de9dab2df9cbfdb1260ed7897003a934 Mon Sep 17 00:00:00 2001 From: Romain Ruetschi Date: Tue, 4 Jun 2024 16:06:33 +0200 Subject: [PATCH 1/2] fix(code): Do not cancel prevote/precommit timeout when threshold is reached Otherwise we dont move to next round when the threshold was for `Nil`. --- code/actors/src/consensus.rs | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/code/actors/src/consensus.rs b/code/actors/src/consensus.rs index c32c0d0e8..8cd774240 100644 --- a/code/actors/src/consensus.rs +++ b/code/actors/src/consensus.rs @@ -372,12 +372,13 @@ where VoteType::Precommit => Timeout::precommit(round), }; - info!("Threshold met for {threshold:?} at round {round}, cancelling {timeout}"); // TODO - check on this. For L47 (PrecommitAny) the spec says: // upon 2f + 1 (PRECOMMIT, hp, roundp, *) for the first time do // schedule OnTimeoutPrecommit(hp , roundp) to be executed after timeoutPrecommit(roundp) // If we cancel the timeout we will not move to next round - state.timers.cast(TimersMsg::CancelTimeout(timeout))?; + // + // info!("Threshold met for {threshold:?} at round {round}, cancelling {timeout}"); + // state.timers.cast(TimersMsg::CancelTimeout(timeout))?; } } From e99dceaf675a971fd1b9c4e9747e59d3a6d97840 Mon Sep 17 00:00:00 2001 From: Romain Ruetschi Date: Tue, 4 Jun 2024 16:34:17 +0200 Subject: [PATCH 2/2] Remove dead code --- code/actors/src/consensus.rs | 54 +++++------------------------------- 1 file changed, 7 insertions(+), 47 deletions(-) diff --git a/code/actors/src/consensus.rs b/code/actors/src/consensus.rs index 8cd774240..5f847cb60 100644 --- a/code/actors/src/consensus.rs +++ b/code/actors/src/consensus.rs @@ -9,8 +9,8 @@ use tokio::sync::mpsc; use tracing::{debug, error, info, trace, warn}; use malachite_common::{ - Context, Height, NilOrVal, Proposal, Round, SignedBlockPart, SignedProposal, SignedVote, - Timeout, TimeoutStep, Validator, ValidatorSet, Value, ValueId, Vote, VoteType, + Context, Height, Proposal, Round, SignedBlockPart, SignedProposal, SignedVote, Timeout, + TimeoutStep, Validator, ValidatorSet, Value, Vote, }; use malachite_driver::Driver; use malachite_driver::Input as DriverInput; @@ -22,7 +22,7 @@ use malachite_network::Msg as NetworkMsg; use malachite_network::PeerId; use malachite_proto as proto; use malachite_proto::Protobuf; -use malachite_vote::{Threshold, ThresholdParams}; +use malachite_vote::ThresholdParams; use crate::gossip::Msg as GossipMsg; use crate::host::{LocallyProposedValue, Msg as HostMsg, ReceivedProposedValue}; @@ -63,10 +63,7 @@ pub enum Msg { TimeoutElapsed(Timeout), SendDriverInput(DriverInput), Decided(Ctx::Height, Round, Ctx::Value), - ProcessDriverOutputs( - Vec>, - Option<(VoteType, Round, NilOrVal>)>, - ), + ProcessDriverOutputs(Vec>), // The proposal builder has built a value and can be used in a new proposal consensus message ProposeValue(Ctx::Height, Round, Option), // The proposal builder has build a new block part, needs to be signed and gossiped by consensus @@ -330,21 +327,12 @@ where } } - let check_threshold = if let DriverInput::Vote(vote) = &input { - let round = Vote::::round(vote); - let value = Vote::::value(vote); - - Some((vote.vote_type(), round, value.clone())) - } else { - None - }; - let outputs = state .driver .process(input) .map_err(|e| format!("Driver failed to process input: {e}"))?; - myself.cast(Msg::ProcessDriverOutputs(outputs, check_threshold))?; + myself.cast(Msg::ProcessDriverOutputs(outputs))?; Ok(()) } @@ -352,36 +340,9 @@ where async fn process_driver_outputs( &self, outputs: Vec>, - check_threshold: Option<(VoteType, Round, NilOrVal>)>, myself: ActorRef>, state: &mut State, ) -> Result<(), ActorProcessingErr> { - // When we receive a vote, check if we've gotten +2/3 votes for the value we just received a vote for, - // if so then cancel the corresponding timeout. - if let Some((vote_type, round, value)) = check_threshold { - let threshold = match value { - NilOrVal::Nil => Threshold::Nil, - NilOrVal::Val(value) => Threshold::Value(value), - }; - - let votes = state.driver.votes(); - - if votes.is_threshold_met(&round, vote_type, threshold.clone()) { - let timeout = match vote_type { - VoteType::Prevote => Timeout::prevote(round), - VoteType::Precommit => Timeout::precommit(round), - }; - - // TODO - check on this. For L47 (PrecommitAny) the spec says: - // upon 2f + 1 (PRECOMMIT, hp, roundp, *) for the first time do - // schedule OnTimeoutPrecommit(hp , roundp) to be executed after timeoutPrecommit(roundp) - // If we cancel the timeout we will not move to next round - // - // info!("Threshold met for {threshold:?} at round {round}, cancelling {timeout}"); - // state.timers.cast(TimersMsg::CancelTimeout(timeout))?; - } - } - for output in outputs { let next = self .handle_driver_output(output, myself.clone(), state) @@ -758,9 +719,8 @@ where self.send_driver_input(input, myself, state).await?; } - Msg::ProcessDriverOutputs(outputs, check_threshold) => { - self.process_driver_outputs(outputs, check_threshold, myself, state) - .await?; + Msg::ProcessDriverOutputs(outputs) => { + self.process_driver_outputs(outputs, myself, state).await?; } Msg::BuilderBlockPart(block_part) => {