Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Mainnet karlsenhashv2 #58

Merged
merged 48 commits into from
Aug 29, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
707297b
First fishhash tests
Dec 26, 2023
3f0537b
refresh seeder url
Dec 27, 2023
a7eaaea
add minor version
Dec 27, 2023
f239d00
fix logging
Dec 27, 2023
4c1311d
Merge pull request #2 from karlsen-network/master
wam-rd Dec 27, 2023
17b616d
vers
Dec 29, 2023
59e81f9
Fix issue on word32 usage in kernel mixing step
Dec 29, 2023
f19c8a5
Fix the dataset and light cache generation.
Jan 4, 2024
7e8bc86
Last fixes on kernel has
Jan 5, 2024
b6f296a
Code cleanup and dag generation correct logging
Jan 21, 2024
223b0cd
Added lock on mainnet connection
Jan 21, 2024
b9c6d1a
Merge pull request #29 from wam-rd/fishhash
lemois-1337 Jan 21, 2024
c093cef
Merge pull request #5 from karlsen-network/master
okilisan Mar 13, 2024
cd5888a
Fishhash plus implementation with hard fork procedure
Mar 19, 2024
0bed91d
Remove blocking tests on block version because node contains both alg…
Mar 31, 2024
a8405b3
hard fork procedure from khashv1 to khashv2
Jun 26, 2024
5dea9c1
fix critical bug in matrix generation
Jun 28, 2024
e7ce09b
fix lint issues
Jun 28, 2024
39f0f3f
fix lint issues 2
Jun 28, 2024
4ab6b22
HF procedure with diff adjustment
okilisan Aug 11, 2024
687bb34
Merge pull request #52 from okilisan/mainnet_karlsenhashv2
lemois-1337 Aug 23, 2024
5707e8c
Removed periodic race detection workflow
lemois-1337 Aug 23, 2024
e99a2e1
Added 'HFDAAScore' to 'simnet' to pass tests
lemois-1337 Aug 23, 2024
d1e678a
align with rusty block version test
okilisan Aug 23, 2024
866f1d6
Merge pull request #53 from okilisan/mainnet_karlsenhashv2
lemois-1337 Aug 24, 2024
0d50f2b
Merge remote-tracking branch 'refs/remotes/origin/mainnet_karlsenhash…
lemois-1337 Aug 24, 2024
e135ccd
Fixed pruning_test in simnet and devnet genesis from Rust node
lemois-1337 Aug 25, 2024
0cab1d1
Fixed remaining integration tests and Go modules update
lemois-1337 Aug 26, 2024
75d4ccf
Use 4-char abbreviation as rest of KLS logging system (POW->POWK)
lemois-1337 Aug 26, 2024
32a6946
Increase windows runner pagefile to 32gb
lemois-1337 Aug 26, 2024
f8d8eae
Remove Go cache in test workflow due to its constant failures
lemois-1337 Aug 26, 2024
e34b69a
Increase code coverage timeout to 120m due to khashv2.
lemois-1337 Aug 26, 2024
98b0730
Increase timeout in integration tests and sequential execution
lemois-1337 Aug 26, 2024
03a8258
Fixed 'BlockVersionKHashV2' in debug output and removed linebreak
lemois-1337 Aug 27, 2024
629e525
Partially revert e135ccd6ca1dafef9fd06c72639793fe6708647e:
lemois-1337 Aug 27, 2024
2ff2931
Moving khashv2 pre-computed dag file during stability tests
lemois-1337 Aug 27, 2024
8862cc3
Partially revert 0cab1d18a7b5dad418f2aa7683d4af39ac19bb99
lemois-1337 Aug 27, 2024
23b175a
Give orphans stability test more time to process blocks
lemois-1337 Aug 27, 2024
c56f01e
Increase Linux swapfile size in GitHub runner to avoid OOM
lemois-1337 Aug 28, 2024
f2d4fb4
Merge pull request #54 from lemois-1337/mainnet_karlsenhashv2
lemois-1337 Aug 28, 2024
29726b7
Increase swap size for code coverage to support khashv2
lemois-1337 Aug 28, 2024
89f8351
Version bump to 2.1.0 for khashv2
lemois-1337 Aug 28, 2024
68bd3ca
Merge pull request #55 from lemois-1337/mainnet_karlsenhashv2
lemois-1337 Aug 28, 2024
c2d369f
Mainnet HFDAAScore set to 26962009 to switch to khashv2
lemois-1337 Aug 28, 2024
5582011
Updated README.md and added khashv2 paragraph
lemois-1337 Aug 29, 2024
825a94c
Merge pull request #56 from lemois-1337/mainnet_karlsenhashv2
lemois-1337 Aug 29, 2024
bc65e01
Re-enable mainnet sync
lemois-1337 Aug 29, 2024
a133806
Merge pull request #57 from lemois-1337/mainnet_karlsenhashv2
lemois-1337 Aug 29, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Fix the dataset and light cache generation.
  • Loading branch information
wam-rd committed Jan 4, 2024
commit f19c8a51807488946a48b79b2e9d83597b974a0f
18 changes: 18 additions & 0 deletions cmd/karlsenminer/mineloop.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package main

import (
nativeerrors "errors"
"fmt"
"math/rand"
"sync/atomic"
"time"
Expand Down Expand Up @@ -40,6 +41,7 @@ func mineLoop(client *minerClient, numberOfBlocks uint64, targetBlocksPerSecond
})

spawn("blocksLoop", func() {
fmt.Printf("blocksLoop -- log0\n")
const windowSize = 10
hasBlockRateTarget := targetBlocksPerSecond != 0
var windowTicker, blockTicker *time.Ticker
Expand Down Expand Up @@ -72,6 +74,7 @@ func mineLoop(client *minerClient, numberOfBlocks uint64, targetBlocksPerSecond
})

spawn("handleFoundBlock", func() {
fmt.Printf("handleFoundBlock -- log0\n")
for i := uint64(0); numberOfBlocks == 0 || i < numberOfBlocks; i++ {
block := <-foundBlockChan
err := handleFoundBlock(client, block)
Expand All @@ -95,8 +98,16 @@ func mineLoop(client *minerClient, numberOfBlocks uint64, targetBlocksPerSecond

func logHashRate() {
spawn("logHashRate", func() {
fmt.Printf("logHashRate -- log0\n")
//_, state, _ := templatemanager.Get()
//fmt.Printf("logHashRate -- log1\n")
lastCheck := time.Now()
for range time.Tick(logHashRateInterval) {

//fmt.Printf("logHashRate -- log2\n")
//fmt.Printf("logHashRate -- IsContextReady : %t\n", state.IsContextReady())
//fmt.Printf("logHashRate -- IsContextReady : %t\n", state.IsContextReady())

currentHashesTried := atomic.LoadUint64(&hashesTried)
currentTime := time.Now()
kiloHashesTried := float64(currentHashesTried) / 1000.0
Expand Down Expand Up @@ -137,8 +148,10 @@ func handleFoundBlock(client *minerClient, block *externalapi.DomainBlock) error

func mineNextBlock(mineWhenNotSynced bool) *externalapi.DomainBlock {
nonce := rand.Uint64() // Use the global concurrent-safe random source.
//fmt.Printf("mineNextBlock -- log0\n")
for {
nonce++
//fmt.Printf("mineNextBlock -- log1\n")
// For each nonce we try to build a block from the most up to date
// block template.
// In the rare case where the nonce space is exhausted for a specific
Expand All @@ -163,8 +176,11 @@ func getBlockForMining(mineWhenNotSynced bool) (*externalapi.DomainBlock, *pow.S
const sleepTime = 500 * time.Millisecond
const sleepTimeWhenNotSynced = 5 * time.Second

//fmt.Printf("getBlockForMining -- log0\n")

for {
tryCount++
//fmt.Printf("getBlockForMining -- log1\n")

shouldLog := (tryCount-1)%10 == 0
template, state, isSynced := templatemanager.Get()
Expand All @@ -190,6 +206,7 @@ func getBlockForMining(mineWhenNotSynced bool) (*externalapi.DomainBlock, *pow.S
func templatesLoop(client *minerClient, miningAddr util.Address, errChan chan error) {
getBlockTemplate := func() {
template, err := client.GetBlockTemplate(miningAddr.String(), "karlsenminer-"+version.Version())
fmt.Printf("Getting Block template\n")
if nativeerrors.Is(err, router.ErrTimeout) {
log.Warnf("Got timeout while requesting block template from %s: %s", client.Address(), err)
reconnectErr := client.Reconnect()
Expand All @@ -207,6 +224,7 @@ func templatesLoop(client *minerClient, miningAddr util.Address, errChan chan er
errChan <- errors.Wrapf(err, "Error getting block template from %s", client.Address())
return
}
fmt.Printf("Template SET\n")
err = templatemanager.Set(template)
if err != nil {
errChan <- errors.Wrapf(err, "Error setting block template from %s", client.Address())
Expand Down
Loading