aboutsummaryrefslogtreecommitdiffstats
path: root/whisper/whisperv5
diff options
context:
space:
mode:
authorBas van Kervel <basvankervel@gmail.com>2017-06-21 17:15:47 +0800
committerBas van Kervel <basvankervel@gmail.com>2017-06-21 17:15:47 +0800
commita4e4c76cb30f34f8a06431802fdc3b9ba0643d47 (patch)
treed0949d50fe0f685f42f653f89fc00206ea9c00cb /whisper/whisperv5
parent7a11e86442ab51401ad764777666133d82656264 (diff)
downloadgo-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.tar
go-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.tar.gz
go-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.tar.bz2
go-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.tar.lz
go-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.tar.xz
go-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.tar.zst
go-tangerine-a4e4c76cb30f34f8a06431802fdc3b9ba0643d47.zip
whisper: use syncmap for dynamic configuration options
Diffstat (limited to 'whisper/whisperv5')
-rw-r--r--whisper/whisperv5/whisper.go61
1 files changed, 18 insertions, 43 deletions
diff --git a/whisper/whisperv5/whisper.go b/whisper/whisperv5/whisper.go
index 1e10b1d76..d09246f69 100644
--- a/whisper/whisperv5/whisper.go
+++ b/whisper/whisperv5/whisper.go
@@ -26,8 +26,6 @@ import (
"sync"
"time"
- "sync/atomic"
-
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/log"
@@ -35,6 +33,7 @@ import (
"github.com/ethereum/go-ethereum/rpc"
"github.com/syndtr/goleveldb/leveldb/errors"
"golang.org/x/crypto/pbkdf2"
+ "golang.org/x/sync/syncmap"
set "gopkg.in/fatih/set.v0"
)
@@ -46,38 +45,12 @@ type Statistics struct {
totalMessagesCleared int
}
-type settingType byte
-type settingsMap map[settingType]interface{}
-
const (
- minPowIdx settingType = iota // Minimal PoW required by the whisper node
- maxMsgSizeIdx settingType = iota // Maximal message length allowed by the whisper node
- OverflowIdx settingType = iota // Indicator of message queue overflow
+ minPowIdx = iota // Minimal PoW required by the whisper node
+ maxMsgSizeIdx = iota // Maximal message length allowed by the whisper node
+ overflowIdx = iota // Indicator of message queue overflow
)
-type settingsVault struct {
- vaultMu sync.Mutex
- vault atomic.Value
-}
-
-func (s *settingsVault) get(idx settingType) interface{} {
- m := s.vault.Load().(settingsMap)
- return m[idx]
-}
-
-func (s *settingsVault) store(idx settingType, val interface{}) {
- s.vaultMu.Lock()
- defer s.vaultMu.Unlock()
-
- m1 := s.vault.Load().(settingsMap)
- m2 := make(settingsMap)
- for k, v := range m1 {
- m2[k] = v
- }
- m2[idx] = val
- s.vault.Store(m2)
-}
-
// Whisper represents a dark communication interface through the Ethereum
// network, using its very own P2P communication layer.
type Whisper struct {
@@ -99,7 +72,7 @@ type Whisper struct {
p2pMsgQueue chan *Envelope // Message queue for peer-to-peer messages (not to be forwarded any further)
quit chan struct{} // Channel used for graceful exit
- settings settingsVault // holds configuration settings that can be dynamically changed
+ settings syncmap.Map // holds configuration settings that can be dynamically changed
statsMu sync.Mutex // guard stats
stats Statistics // Statistics of whisper node
@@ -126,10 +99,9 @@ func New(cfg *Config) *Whisper {
whisper.filters = NewFilters(whisper)
- whisper.settings.vault.Store(make(settingsMap))
- whisper.settings.store(minPowIdx, cfg.MinimumAcceptedPOW)
- whisper.settings.store(maxMsgSizeIdx, cfg.MaxMessageSize)
- whisper.settings.store(OverflowIdx, false)
+ whisper.settings.Store(minPowIdx, cfg.MinimumAcceptedPOW)
+ whisper.settings.Store(maxMsgSizeIdx, cfg.MaxMessageSize)
+ whisper.settings.Store(overflowIdx, false)
// p2p whisper sub protocol handler
whisper.protocol = p2p.Protocol{
@@ -150,17 +122,20 @@ func New(cfg *Config) *Whisper {
}
func (w *Whisper) MinPow() float64 {
- return w.settings.get(minPowIdx).(float64)
+ val, _ := w.settings.Load(minPowIdx)
+ return val.(float64)
}
// MaxMessageSize returns the maximum accepted message size.
func (w *Whisper) MaxMessageSize() uint32 {
- return w.settings.get(maxMsgSizeIdx).(uint32)
+ val, _ := w.settings.Load(maxMsgSizeIdx)
+ return val.(uint32)
}
// Overflow returns an indication if the message queue is full.
func (w *Whisper) Overflow() bool {
- return w.settings.get(OverflowIdx).(bool)
+ val, _ := w.settings.Load(overflowIdx)
+ return val.(bool)
}
// APIs returns the RPC descriptors the Whisper implementation offers
@@ -196,7 +171,7 @@ func (w *Whisper) SetMaxMessageSize(size uint32) error {
if size > MaxMessageSize {
return fmt.Errorf("message size too large [%d>%d]", size, MaxMessageSize)
}
- w.settings.store(maxMsgSizeIdx, uint32(size))
+ w.settings.Store(maxMsgSizeIdx, uint32(size))
return nil
}
@@ -205,7 +180,7 @@ func (w *Whisper) SetMinimumPoW(val float64) error {
if val <= 0.0 {
return fmt.Errorf("invalid PoW: %f", val)
}
- w.settings.store(minPowIdx, val)
+ w.settings.Store(minPowIdx, val)
return nil
}
@@ -679,12 +654,12 @@ func (w *Whisper) checkOverflow() {
if queueSize == messageQueueLimit {
if !w.Overflow() {
- w.settings.store(OverflowIdx, true)
+ w.settings.Store(overflowIdx, true)
log.Warn("message queue overflow")
}
} else if queueSize <= messageQueueLimit/2 {
if w.Overflow() {
- w.settings.store(OverflowIdx, false)
+ w.settings.Store(overflowIdx, false)
log.Warn("message queue overflow fixed (back to normal)")
}
}