go-ethereum/miner/miner.go

87 lines
1.7 KiB
Go
Raw Normal View History

2014-10-31 15:56:42 +02:00
package miner
import (
"math/big"
2014-10-31 15:56:42 +02:00
2015-03-18 14:00:01 +02:00
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/core"
2015-04-07 13:32:55 +03:00
"github.com/ethereum/go-ethereum/core/state"
"github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum/go-ethereum/logger"
"github.com/ethereum/go-ethereum/logger/glog"
2015-03-03 18:55:23 +02:00
"github.com/ethereum/go-ethereum/pow"
2014-10-31 15:56:42 +02:00
)
type Miner struct {
2015-02-09 17:20:34 +02:00
worker *worker
MinAcceptedGasPrice *big.Int
threads int
mining bool
eth core.Backend
pow pow.PoW
}
func New(eth core.Backend, pow pow.PoW) *Miner {
return &Miner{eth: eth, pow: pow, worker: newWorker(common.Address{}, eth)}
2014-10-31 15:56:42 +02:00
}
func (self *Miner) Mining() bool {
return self.mining
2014-10-31 15:56:42 +02:00
}
func (m *Miner) SetGasPrice(price *big.Int) {
2015-05-09 13:51:40 +03:00
// FIXME block tests set a nil gas price. Quick dirty fix
if price == nil {
return
}
m.worker.gasPrice = price
}
func (self *Miner) Start(coinbase common.Address, threads int) {
self.mining = true
for i := 0; i < threads; i++ {
self.worker.register(NewCpuAgent(i, self.pow))
}
self.threads = threads
glog.V(logger.Info).Infof("Starting mining operation (CPU=%d TOT=%d)\n", threads, len(self.worker.agents))
self.worker.coinbase = coinbase
2015-02-09 17:20:34 +02:00
self.worker.start()
self.worker.commitNewWork()
2014-10-31 15:56:42 +02:00
}
func (self *Miner) Stop() {
self.worker.stop()
self.mining = false
}
func (self *Miner) Register(agent Agent) {
if self.mining {
agent.Start()
}
self.worker.register(agent)
}
2015-02-09 17:20:34 +02:00
func (self *Miner) HashRate() int64 {
return self.pow.GetHashrate()
}
func (self *Miner) SetExtra(extra []byte) {
self.worker.extra = extra
}
2015-04-07 13:32:55 +03:00
func (self *Miner) PendingState() *state.StateDB {
return self.worker.pendingState()
}
func (self *Miner) PendingBlock() *types.Block {
return self.worker.pendingBlock()
}