Skip to content

Commit

Permalink
les/flowcontrol: fixed locking scheme
Browse files Browse the repository at this point in the history
  • Loading branch information
zsfelfoldi committed Nov 14, 2016
1 parent ca73dea commit a0c6649
Showing 1 changed file with 7 additions and 4 deletions.
11 changes: 7 additions & 4 deletions les/flowcontrol/control.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ type ServerNode struct {
params *ServerParams
sumCost uint64 // sum of req costs sent to this server
pending map[uint64]uint64 // value = sumCost after sending the given req
lock sync.Mutex
lock sync.RWMutex
}

func NewServerNode(params *ServerParams) *ServerNode {
Expand Down Expand Up @@ -135,8 +135,8 @@ func (peer *ServerNode) canSend(maxCost uint64) uint64 {
}

func (peer *ServerNode) CanSend(maxCost uint64) uint64 {
peer.lock.Lock()
defer peer.lock.Unlock()
peer.lock.RLock()
defer peer.lock.RUnlock()

return peer.canSend(maxCost)
}
Expand All @@ -148,7 +148,10 @@ func (peer *ServerNode) SendRequest(reqID, maxCost uint64) {

peer.recalcBLE(getTime())
for peer.bufEstimate < maxCost {
time.Sleep(time.Duration(peer.canSend(maxCost)))
wait := time.Duration(peer.canSend(maxCost))
peer.lock.Unlock()
time.Sleep(wait)
peer.lock.Lock()
peer.recalcBLE(getTime())
}
peer.bufEstimate -= maxCost
Expand Down

0 comments on commit a0c6649

Please sign in to comment.