From c7ac35d8ad517c13a9433bceef1bed1210dc0342 Mon Sep 17 00:00:00 2001 From: okilisan Date: Mon, 2 Sep 2024 19:13:10 +0200 Subject: [PATCH 1/6] Adjust difficulty managment between rusty and golang nodes during the first block window --- cmd/karlsenminer/main.go | 2 +- domain/consensus/constructors.go | 2 +- .../processes/difficultymanager/difficultymanager.go | 6 +++++- domain/dagconfig/params.go | 8 ++++++++ 4 files changed, 15 insertions(+), 3 deletions(-) diff --git a/cmd/karlsenminer/main.go b/cmd/karlsenminer/main.go index 00e16b8e45..bbeecd9820 100644 --- a/cmd/karlsenminer/main.go +++ b/cmd/karlsenminer/main.go @@ -30,7 +30,7 @@ func main() { // Show version at startup. log.Infof("Version %s", version.Version()) - log.Infof("Using KarlsenHashV2 impl: %s", pow.GetHashingAlgoVersion()) + log.Infof("Miner compatibility KarlsenHashV1 & KarlsenHashV2 impl: %s", pow.GetHashingAlgoVersion()) // Enable http profiling server if requested. if cfg.Profile != "" { diff --git a/domain/consensus/constructors.go b/domain/consensus/constructors.go index b730c51869..40b08d2886 100644 --- a/domain/consensus/constructors.go +++ b/domain/consensus/constructors.go @@ -19,7 +19,7 @@ type GHOSTDAGManagerConstructor func( // DifficultyManagerConstructor is the function signature for a constructor of a type implementing model.DifficultyManager type DifficultyManagerConstructor func(model.DBReader, model.GHOSTDAGManager, model.GHOSTDAGDataStore, - model.BlockHeaderStore, model.DAABlocksStore, model.DAGTopologyManager, model.DAGTraversalManager, *big.Int, int, bool, time.Duration, + model.BlockHeaderStore, model.DAABlocksStore, model.DAGTopologyManager, model.DAGTraversalManager, *big.Int, int, int, bool, time.Duration, *externalapi.DomainHash, uint32) model.DifficultyManager // PastMedianTimeManagerConstructor is the function signature for a constructor of a type implementing model.PastMedianTimeManager diff --git a/domain/consensus/processes/difficultymanager/difficultymanager.go b/domain/consensus/processes/difficultymanager/difficultymanager.go index 2f73bd1098..d5f8e64f3c 100644 --- a/domain/consensus/processes/difficultymanager/difficultymanager.go +++ b/domain/consensus/processes/difficultymanager/difficultymanager.go @@ -26,6 +26,7 @@ type difficultyManager struct { genesisHash *externalapi.DomainHash powMax *big.Int difficultyAdjustmentWindowSize int + minDifficultyWindowLen int disableDifficultyAdjustment bool targetTimePerBlock time.Duration genesisBits uint32 @@ -41,6 +42,7 @@ func New(databaseContext model.DBReader, dagTraversalManager model.DAGTraversalManager, powMax *big.Int, difficultyAdjustmentWindowSize int, + minDifficultyWindowLen int, disableDifficultyAdjustment bool, targetTimePerBlock time.Duration, genesisHash *externalapi.DomainHash, @@ -55,6 +57,7 @@ func New(databaseContext model.DBReader, dagTraversalManager: dagTraversalManager, powMax: powMax, difficultyAdjustmentWindowSize: difficultyAdjustmentWindowSize, + minDifficultyWindowLen: minDifficultyWindowLen, disableDifficultyAdjustment: disableDifficultyAdjustment, targetTimePerBlock: targetTimePerBlock, genesisHash: genesisHash, @@ -117,7 +120,8 @@ func (dm *difficultyManager) requiredDifficultyFromTargetsWindow(targetsWindow b // We could instead clamp the timestamp difference to `targetTimePerBlock`, // but then everything will cancel out and we'll get the target from the last block, which will be the same as genesis. // We add 64 as a safety margin - if len(targetsWindow) < 2 || len(targetsWindow) < dm.difficultyAdjustmentWindowSize { + //if len(targetsWindow) < 2 || len(targetsWindow) < dm.difficultyAdjustmentWindowSize { + if len(targetsWindow) < 2 || len(targetsWindow) < dm.minDifficultyWindowLen { return dm.genesisBits, nil } diff --git a/domain/dagconfig/params.go b/domain/dagconfig/params.go index 6ba7cd3347..71db6da74c 100644 --- a/domain/dagconfig/params.go +++ b/domain/dagconfig/params.go @@ -110,6 +110,10 @@ type Params struct { // to calculate the required difficulty of each block. DifficultyAdjustmentWindowSize int + // MinDifficultyWindowLen is the minimum size of window that can be inspected + // under this value the genesis difficulty is sent. + MinDifficultyWindowLen int + // These fields are related to voting on consensus rule changes as // defined by BIP0009. // @@ -234,6 +238,7 @@ var MainnetParams = Params{ TargetTimePerBlock: defaultTargetTimePerBlock, FinalityDuration: defaultFinalityDuration, DifficultyAdjustmentWindowSize: defaultDifficultyAdjustmentWindowSize, + MinDifficultyWindowLen: 10, TimestampDeviationTolerance: defaultTimestampDeviationTolerance, // Consensus rule change deployments. @@ -303,6 +308,7 @@ var TestnetParams = Params{ TargetTimePerBlock: defaultTargetTimePerBlock, FinalityDuration: defaultFinalityDuration, DifficultyAdjustmentWindowSize: defaultDifficultyAdjustmentWindowSize, + MinDifficultyWindowLen: 10, TimestampDeviationTolerance: defaultTimestampDeviationTolerance, // Consensus rule change deployments. @@ -372,6 +378,7 @@ var SimnetParams = Params{ TargetTimePerBlock: time.Millisecond, FinalityDuration: time.Minute, DifficultyAdjustmentWindowSize: defaultDifficultyAdjustmentWindowSize, + MinDifficultyWindowLen: 10, TimestampDeviationTolerance: defaultTimestampDeviationTolerance, // Consensus rule change deployments. @@ -433,6 +440,7 @@ var DevnetParams = Params{ TargetTimePerBlock: defaultTargetTimePerBlock, FinalityDuration: defaultFinalityDuration, DifficultyAdjustmentWindowSize: defaultDifficultyAdjustmentWindowSize, + MinDifficultyWindowLen: 10, TimestampDeviationTolerance: defaultTimestampDeviationTolerance, // Consensus rule change deployments. From 8cb5eb98aa5331a909c40d9889a6befe20dd00a9 Mon Sep 17 00:00:00 2001 From: okilisan Date: Mon, 2 Sep 2024 19:28:09 +0200 Subject: [PATCH 2/6] diff adjustment - forget the factory in last commit --- domain/consensus/factory.go | 1 + 1 file changed, 1 insertion(+) diff --git a/domain/consensus/factory.go b/domain/consensus/factory.go index 4c70792751..0b554bf6c9 100644 --- a/domain/consensus/factory.go +++ b/domain/consensus/factory.go @@ -233,6 +233,7 @@ func (f *factory) NewConsensus(config *Config, db infrastructuredatabase.Databas dagTraversalManager, config.PowMax, config.DifficultyAdjustmentWindowSize, + config.MinDifficultyWindowLen, config.DisableDifficultyAdjustment, config.TargetTimePerBlock, config.GenesisHash, From f118156546d5ecf56478fc6ba51e686ca687bf02 Mon Sep 17 00:00:00 2001 From: okilisan Date: Mon, 2 Sep 2024 19:33:28 +0200 Subject: [PATCH 3/6] fix for integration test diff manager signature --- .../pruning_violation_proof_of_work_and_difficulty_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go b/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go index 4bd7593dee..978eaaa1bc 100644 --- a/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go +++ b/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go @@ -304,7 +304,7 @@ func TestValidateDifficulty(t *testing.T) { genesisBits: consensusConfig.GenesisBlock.Header.Bits()} factory.SetTestDifficultyManager(func(_ model.DBReader, _ model.GHOSTDAGManager, _ model.GHOSTDAGDataStore, _ model.BlockHeaderStore, daaBlocksStore model.DAABlocksStore, _ model.DAGTopologyManager, - _ model.DAGTraversalManager, _ *big.Int, _ int, _ bool, _ time.Duration, + _ model.DAGTraversalManager, _ *big.Int, _ int, _ int, _ bool, _ time.Duration, _ *externalapi.DomainHash, _ uint32) model.DifficultyManager { mocDifficulty.daaBlocksStore = daaBlocksStore From 9806d6386938682475211f7b45cbe36451c531e4 Mon Sep 17 00:00:00 2001 From: okilisan Date: Tue, 3 Sep 2024 10:12:41 +0200 Subject: [PATCH 4/6] difficulty adjustment window fix --- .../interface_processes_difficultymanager.go | 1 + .../processes/blockbuilder/block_builder.go | 4 ++-- ...ing_violation_proof_of_work_and_difficulty.go | 2 +- ...iolation_proof_of_work_and_difficulty_test.go | 16 +++++++++++----- .../difficultymanager/difficultymanager.go | 5 +++++ 5 files changed, 20 insertions(+), 8 deletions(-) diff --git a/domain/consensus/model/interface_processes_difficultymanager.go b/domain/consensus/model/interface_processes_difficultymanager.go index f710c03128..ec9b88da91 100644 --- a/domain/consensus/model/interface_processes_difficultymanager.go +++ b/domain/consensus/model/interface_processes_difficultymanager.go @@ -11,4 +11,5 @@ type DifficultyManager interface { RequiredDifficulty(stagingArea *StagingArea, blockHash *externalapi.DomainHash) (uint32, error) EstimateNetworkHashesPerSecond(startHash *externalapi.DomainHash, windowSize int) (uint64, error) GenesisDifficulty() uint32 + DifficultyAdjustmentWindowSize() int } diff --git a/domain/consensus/processes/blockbuilder/block_builder.go b/domain/consensus/processes/blockbuilder/block_builder.go index c3c8da688b..6b8d3ff2d1 100644 --- a/domain/consensus/processes/blockbuilder/block_builder.go +++ b/domain/consensus/processes/blockbuilder/block_builder.go @@ -212,9 +212,9 @@ func (bb *blockBuilder) buildHeader(stagingArea *model.StagingArea, transactions } // adjust the difficulty - /*if daaScore <= (bb.hfDAAScore+10) && daaScore >= bb.hfDAAScore { + if daaScore <= (bb.hfDAAScore+uint64(bb.difficultyManager.DifficultyAdjustmentWindowSize())) && daaScore >= bb.hfDAAScore { bits = bb.difficultyManager.GenesisDifficulty() - }*/ + } hashMerkleRoot := bb.newBlockHashMerkleRoot(transactions) acceptedIDMerkleRoot, err := bb.newBlockAcceptedIDMerkleRoot(stagingArea) diff --git a/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty.go b/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty.go index f7f591fba9..9dc7971ab0 100644 --- a/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty.go +++ b/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty.go @@ -135,7 +135,7 @@ func (v *blockValidator) validateDifficulty(stagingArea *model.StagingArea, } // bypass the difficulty check during HF - if header.DAAScore() <= (v.hfDAAScore+10) && header.DAAScore() >= v.hfDAAScore { + if header.DAAScore() <= (v.hfDAAScore+uint64(v.difficultyManager.DifficultyAdjustmentWindowSize())) && header.DAAScore() >= v.hfDAAScore { expectedBits = v.difficultyManager.GenesisDifficulty() } diff --git a/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go b/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go index 978eaaa1bc..44ec0753f6 100644 --- a/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go +++ b/domain/consensus/processes/blockvalidator/pruning_violation_proof_of_work_and_difficulty_test.go @@ -344,11 +344,17 @@ func TestValidateDifficulty(t *testing.T) { } type mocDifficultyManager struct { - testDifficulty uint32 - testGenesisBits uint32 - daaBlocksStore model.DAABlocksStore - genesisDaaScore uint64 - genesisBits uint32 + testDifficulty uint32 + testGenesisBits uint32 + daaBlocksStore model.DAABlocksStore + genesisDaaScore uint64 + genesisBits uint32 + difficultyAdjustmentWindowSize int +} + +// DifficultyAdjustmentWindowSize implements model.DifficultyManager. +func (dm *mocDifficultyManager) DifficultyAdjustmentWindowSize() int { + return dm.difficultyAdjustmentWindowSize } // GenesisDifficulty implements model.DifficultyManager. diff --git a/domain/consensus/processes/difficultymanager/difficultymanager.go b/domain/consensus/processes/difficultymanager/difficultymanager.go index d5f8e64f3c..062a73ec6f 100644 --- a/domain/consensus/processes/difficultymanager/difficultymanager.go +++ b/domain/consensus/processes/difficultymanager/difficultymanager.go @@ -108,6 +108,11 @@ func (dm *difficultyManager) GenesisDifficulty() uint32 { return dm.genesisBits } +// DifficultyAdjustmentWindowSize returns the size of the window of diff adjustment +func (dm *difficultyManager) DifficultyAdjustmentWindowSize() int { + return dm.difficultyAdjustmentWindowSize +} + func (dm *difficultyManager) requiredDifficultyFromTargetsWindow(targetsWindow blockWindow) (uint32, error) { if dm.disableDifficultyAdjustment { return dm.genesisBits, nil From 3d0201bb2d5b0de6e7efcda47cccfd38475d778d Mon Sep 17 00:00:00 2001 From: Lemois 1337 Date: Tue, 3 Sep 2024 15:12:49 +0200 Subject: [PATCH 5/6] Hardfork in devnet and simnet after the difficulty adjustment window --- domain/dagconfig/params.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/domain/dagconfig/params.go b/domain/dagconfig/params.go index 71db6da74c..917e28589c 100644 --- a/domain/dagconfig/params.go +++ b/domain/dagconfig/params.go @@ -417,7 +417,7 @@ var SimnetParams = Params{ MaxBlockLevel: 250, MergeDepth: defaultMergeDepth, - HFDAAScore: 50, + HFDAAScore: 3600, } // DevnetParams defines the network parameters for the development Karlsen network. @@ -481,7 +481,7 @@ var DevnetParams = Params{ MaxBlockLevel: 250, MergeDepth: defaultMergeDepth, - HFDAAScore: 50, + HFDAAScore: 3600, } // ErrDuplicateNet describes an error where the parameters for a Karlsen From eebcf69a26e266b23c594d4c7b5c9aedaa2ddd68 Mon Sep 17 00:00:00 2001 From: Lemois 1337 Date: Tue, 3 Sep 2024 15:57:37 +0200 Subject: [PATCH 6/6] Fix simnet pruning test --- domain/consensus/processes/pruningmanager/pruning_test.go | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/domain/consensus/processes/pruningmanager/pruning_test.go b/domain/consensus/processes/pruningmanager/pruning_test.go index 6e5e77e798..b89b336500 100644 --- a/domain/consensus/processes/pruningmanager/pruning_test.go +++ b/domain/consensus/processes/pruningmanager/pruning_test.go @@ -40,7 +40,7 @@ func TestPruning(t *testing.T) { dagconfig.MainnetParams.Name: "503", dagconfig.TestnetParams.Name: "502", dagconfig.DevnetParams.Name: "503", - dagconfig.SimnetParams.Name: "503", + dagconfig.SimnetParams.Name: "502", }, }