Fixed a few issues in the miner and updated hash rate title

* Sometimes old nonces were set by "old" agents
* Added the hash rate to the miner
This commit is contained in:
obscuren 2015-02-13 17:23:09 +01:00
parent 8305d409d2
commit 8a0f23915e
5 changed files with 66 additions and 29 deletions

View File

@ -289,6 +289,7 @@ ApplicationWindow {
styleColor: "#797979" styleColor: "#797979"
} }
/*
Label { Label {
//y: 6 //y: 6
objectName: "miningLabel" objectName: "miningLabel"
@ -307,6 +308,7 @@ ApplicationWindow {
anchors.right: peerGroup.left anchors.right: peerGroup.left
anchors.rightMargin: 5 anchors.rightMargin: 5
} }
*/
ProgressBar { ProgressBar {
visible: false visible: false

View File

@ -14,6 +14,30 @@ Rectangle {
color: "#00000000" color: "#00000000"
Label {
visible: false
id: lastBlockLabel
objectName: "lastBlockLabel"
text: "---"
font.pixelSize: 10
anchors.right: peerGroup.left
anchors.rightMargin: 5
onTextChanged: {
//menuItem.secondaryTitle = text
}
}
Label {
objectName: "miningLabel"
visible: false
font.pixelSize: 10
anchors.right: lastBlockLabel.left
anchors.rightMargin: 5
onTextChanged: {
menuItem.secondaryTitle = text
}
}
ColumnLayout { ColumnLayout {
spacing: 10 spacing: 10
anchors.fill: parent anchors.fill: parent

View File

@ -9,7 +9,7 @@ type CpuMiner struct {
c chan *types.Block c chan *types.Block
quit chan struct{} quit chan struct{}
quitCurrentOp chan struct{} quitCurrentOp chan struct{}
returnCh chan<- []byte returnCh chan<- Work
index int index int
pow pow.PoW pow pow.PoW
@ -28,9 +28,9 @@ func NewCpuMiner(index int, pow pow.PoW) *CpuMiner {
return miner return miner
} }
func (self *CpuMiner) Work() chan<- *types.Block { return self.c } func (self *CpuMiner) Work() chan<- *types.Block { return self.c }
func (self *CpuMiner) Pow() pow.PoW { return self.pow } func (self *CpuMiner) Pow() pow.PoW { return self.pow }
func (self *CpuMiner) SetNonceCh(ch chan<- []byte) { self.returnCh = ch } func (self *CpuMiner) SetNonceCh(ch chan<- Work) { self.returnCh = ch }
func (self *CpuMiner) Stop() { func (self *CpuMiner) Stop() {
close(self.quit) close(self.quit)
@ -42,7 +42,6 @@ out:
for { for {
select { select {
case block := <-self.c: case block := <-self.c:
minerlogger.Infof("miner[%d] got block\n", self.index)
// make sure it's open // make sure it's open
self.quitCurrentOp <- struct{}{} self.quitCurrentOp <- struct{}{}
@ -66,9 +65,9 @@ done:
} }
func (self *CpuMiner) mine(block *types.Block) { func (self *CpuMiner) mine(block *types.Block) {
minerlogger.Infof("started agent[%d]. mining...\n", self.index) minerlogger.Infof("(re)started agent[%d]. mining...\n", self.index)
nonce := self.pow.Search(block, self.quitCurrentOp) nonce := self.pow.Search(block, self.quitCurrentOp)
if nonce != nil { if nonce != nil {
self.returnCh <- nonce self.returnCh <- Work{block.Number().Uint64(), nonce}
} }
} }

View File

@ -38,22 +38,16 @@ func (self *Miner) Mining() bool {
} }
func (self *Miner) Start() { func (self *Miner) Start() {
self.mining = true
self.worker.start() self.worker.start()
self.worker.commitNewWork() self.worker.commitNewWork()
/*
timer := time.NewTicker(time.Second)
for {
select {
case <-timer.C:
fmt.Printf("%d workers. %d/Khash\n", len(self.worker.agents), self.HashRate())
}
}
*/
} }
func (self *Miner) Stop() { func (self *Miner) Stop() {
self.mining = false
self.worker.stop() self.worker.stop()
} }

View File

@ -41,16 +41,21 @@ func env(block *types.Block, eth *eth.Ethereum) *environment {
return env return env
} }
type Work struct {
Number uint64
Nonce []byte
}
type Agent interface { type Agent interface {
Work() chan<- *types.Block Work() chan<- *types.Block
SetNonceCh(chan<- []byte) SetNonceCh(chan<- Work)
Stop() Stop()
Pow() pow.PoW Pow() pow.PoW
} }
type worker struct { type worker struct {
agents []Agent agents []Agent
recv chan []byte recv chan Work
mux *event.TypeMux mux *event.TypeMux
quit chan struct{} quit chan struct{}
pow pow.PoW pow pow.PoW
@ -61,13 +66,15 @@ type worker struct {
coinbase []byte coinbase []byte
current *environment current *environment
mining bool
} }
func newWorker(coinbase []byte, eth *eth.Ethereum) *worker { func newWorker(coinbase []byte, eth *eth.Ethereum) *worker {
return &worker{ return &worker{
eth: eth, eth: eth,
mux: eth.EventMux(), mux: eth.EventMux(),
recv: make(chan []byte), recv: make(chan Work),
chain: eth.ChainManager(), chain: eth.ChainManager(),
proc: eth.BlockProcessor(), proc: eth.BlockProcessor(),
coinbase: coinbase, coinbase: coinbase,
@ -75,11 +82,17 @@ func newWorker(coinbase []byte, eth *eth.Ethereum) *worker {
} }
func (self *worker) start() { func (self *worker) start() {
self.mining = true
self.quit = make(chan struct{})
go self.update() go self.update()
go self.wait() go self.wait()
} }
func (self *worker) stop() { func (self *worker) stop() {
self.mining = false
close(self.quit) close(self.quit)
} }
@ -107,26 +120,31 @@ out:
break out break out
} }
} }
events.Unsubscribe()
} }
func (self *worker) wait() { func (self *worker) wait() {
for { for {
for nonce := range self.recv { for work := range self.recv {
self.current.block.Header().Nonce = nonce if self.current.block.Number().Uint64() == work.Number {
fmt.Println(self.current.block) self.current.block.Header().Nonce = work.Nonce
self.chain.InsertChain(types.Blocks{self.current.block}) self.chain.InsertChain(types.Blocks{self.current.block})
}
break break
} }
} }
} }
func (self *worker) push() { func (self *worker) push() {
self.current.state.Update(ethutil.Big0) if self.mining {
self.current.block.SetRoot(self.current.state.Root()) self.current.state.Update(ethutil.Big0)
self.current.block.SetRoot(self.current.state.Root())
for _, agent := range self.agents { for _, agent := range self.agents {
agent.Work() <- self.current.block agent.Work() <- self.current.block
}
} }
} }