From 01d0c281834cbe871a35fc57f07e01a61be3a216 Mon Sep 17 00:00:00 2001 From: Javad Date: Tue, 10 Dec 2024 09:58:33 +0330 Subject: [PATCH 1/2] fix: refcator strong termination for change-proposer phase --- consensus/consensus.go | 6 ------ consensus/cp.go | 21 +++++++-------------- consensus/cp_decide.go | 2 -- 3 files changed, 7 insertions(+), 22 deletions(-) diff --git a/consensus/consensus.go b/consensus/consensus.go index 12a6d71bb..e84661efd 100644 --- a/consensus/consensus.go +++ b/consensus/consensus.go @@ -311,12 +311,6 @@ func (cs *consensus) AddVote(vte *vote.Vote) { cs.logger.Info("new vote added", "vote", vte) cs.currentState.onAddVote(vte) - - if vte.Type() == vote.VoteTypeCPDecided { - if vte.Round() > cs.round { - cs.changeProposer.cpDecide(vte.Round(), vte.CPValue()) - } - } } } diff --git a/consensus/cp.go b/consensus/cp.go index b61345e88..faa4bbcd8 100644 --- a/consensus/cp.go +++ b/consensus/cp.go @@ -313,26 +313,19 @@ func (cp *changeProposer) checkJust(vte *vote.Vote) error { func (cp *changeProposer) cpStrongTermination() { cpDecided := cp.log.CPDecidedVoteSet(cp.round) if cpDecided.HasAnyVoteFor(cp.cpRound, vote.CPValueNo) { - cp.cpDecide(cp.round, vote.CPValueNo) - } else if cpDecided.HasAnyVoteFor(cp.cpRound, vote.CPValueYes) { - cp.cpDecide(cp.round, vote.CPValueYes) - } -} - -func (cp *changeProposer) cpDecide(round int16, cpValue vote.CPValue) { - if cpValue == vote.CPValueYes { - cp.round = round + 1 - cp.cpDecided = 1 - cp.enterNewState(cp.proposeState) - } else if cpValue == vote.CPValueNo { - cp.round = round cp.cpDecided = 0 roundProposal := cp.log.RoundProposal(cp.round) if roundProposal == nil { cp.queryProposal() } - cp.enterNewState(cp.prepareState) + } else if cpDecided.HasAnyVoteFor(cp.cpRound, vote.CPValueYes) { + cp.round += 1 + cp.cpDecided = 1 + cp.enterNewState(cp.proposeState) + + // Check if there is any decided vote for the next round. + cp.cpStrongTermination() } } diff --git a/consensus/cp_decide.go b/consensus/cp_decide.go index 8f87ad6a4..07d82b914 100644 --- a/consensus/cp_decide.go +++ b/consensus/cp_decide.go @@ -26,7 +26,6 @@ func (s *cpDecideState) decide() { QCert: cert, } s.signAddCPDecidedVote(hash.UndefHash, s.cpRound, vote.CPValueYes, just) - s.cpDecide(s.round, vote.CPValueYes) } else if cpMainVotes.HasQuorumVotesFor(s.cpRound, vote.CPValueNo) { // decided for no and proceeds to the next round s.logger.Info("binary agreement decided", "value", 0, "round", s.cpRound) @@ -37,7 +36,6 @@ func (s *cpDecideState) decide() { QCert: cert, } s.signAddCPDecidedVote(*s.cpWeakValidity, s.cpRound, vote.CPValueNo, just) - s.cpDecide(s.round, vote.CPValueNo) } else { // conflicting votes s.logger.Debug("conflicting main votes", "round", s.cpRound) From ffb5682efc926d6806d0fc277d853262ccf90efb Mon Sep 17 00:00:00 2001 From: Javad Date: Tue, 10 Dec 2024 10:07:26 +0330 Subject: [PATCH 2/2] fix: linter errors --- consensus/cp.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/consensus/cp.go b/consensus/cp.go index faa4bbcd8..600eb51c8 100644 --- a/consensus/cp.go +++ b/consensus/cp.go @@ -321,7 +321,7 @@ func (cp *changeProposer) cpStrongTermination() { } cp.enterNewState(cp.prepareState) } else if cpDecided.HasAnyVoteFor(cp.cpRound, vote.CPValueYes) { - cp.round += 1 + cp.round++ cp.cpDecided = 1 cp.enterNewState(cp.proposeState)