aboutsummaryrefslogtreecommitdiffstats
path: root/miner/remote_agent.go
diff options
context:
space:
mode:
authorJeffrey Wilcke <jeffrey@ethereum.org>2015-08-07 18:08:48 +0800
committerJeffrey Wilcke <jeffrey@ethereum.org>2015-08-07 18:08:48 +0800
commite89536ca0b0e61111affd6cbacf21105bd637394 (patch)
treefb721ea654f5a5245e595e8f63bb7a034d3ddb76 /miner/remote_agent.go
parentac10c9352e053a06a69fad634e9ec6624ee5808d (diff)
parentc32073b11f12c3735c117b3b3c814505974d5a92 (diff)
downloadgo-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar
go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.gz
go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.bz2
go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.lz
go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.xz
go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.tar.zst
go-tangerine-e89536ca0b0e61111affd6cbacf21105bd637394.zip
Merge pull request #1596 from obscuren/submit-hashrate
miner, rpc: added submit hashrate for remote agents
Diffstat (limited to 'miner/remote_agent.go')
-rw-r--r--miner/remote_agent.go37
1 files changed, 35 insertions, 2 deletions
diff --git a/miner/remote_agent.go b/miner/remote_agent.go
index 674ca40ac..5c672a6e0 100644
--- a/miner/remote_agent.go
+++ b/miner/remote_agent.go
@@ -27,6 +27,11 @@ import (
"github.com/ethereum/go-ethereum/logger/glog"
)
+type hashrate struct {
+ ping time.Time
+ rate uint64
+}
+
type RemoteAgent struct {
mu sync.Mutex
@@ -36,14 +41,24 @@ type RemoteAgent struct {
currentWork *Work
work map[common.Hash]*Work
+
+ hashrateMu sync.RWMutex
+ hashrate map[common.Hash]hashrate
}
func NewRemoteAgent() *RemoteAgent {
- agent := &RemoteAgent{work: make(map[common.Hash]*Work)}
+ agent := &RemoteAgent{work: make(map[common.Hash]*Work), hashrate: make(map[common.Hash]hashrate)}
return agent
}
+func (a *RemoteAgent) SubmitHashrate(id common.Hash, rate uint64) {
+ a.hashrateMu.Lock()
+ defer a.hashrateMu.Unlock()
+
+ a.hashrate[id] = hashrate{time.Now(), rate}
+}
+
func (a *RemoteAgent) Work() chan<- *Work {
return a.workCh
}
@@ -63,7 +78,17 @@ func (a *RemoteAgent) Stop() {
close(a.workCh)
}
-func (a *RemoteAgent) GetHashRate() int64 { return 0 }
+// GetHashRate returns the accumulated hashrate of all identifier combined
+func (a *RemoteAgent) GetHashRate() (tot int64) {
+ a.hashrateMu.RLock()
+ defer a.hashrateMu.RUnlock()
+
+ // this could overflow
+ for _, hashrate := range a.hashrate {
+ tot += int64(hashrate.rate)
+ }
+ return
+}
func (a *RemoteAgent) GetWork() [3]string {
a.mu.Lock()
@@ -131,6 +156,14 @@ out:
}
}
a.mu.Unlock()
+
+ a.hashrateMu.Lock()
+ for id, hashrate := range a.hashrate {
+ if time.Since(hashrate.ping) > 10*time.Second {
+ delete(a.hashrate, id)
+ }
+ }
+ a.hashrateMu.Unlock()
}
}
}