les: use atomic type (#27168)
This commit is contained in:
parent
f8aa623536
commit
25f9977f2d
@ -21,7 +21,6 @@ import (
|
|||||||
"math/big"
|
"math/big"
|
||||||
"math/rand"
|
"math/rand"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
@ -144,8 +143,8 @@ func (h *clientHandler) handle(p *serverPeer, noInitAnnounce bool) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Mark the peer starts to be served.
|
// Mark the peer starts to be served.
|
||||||
atomic.StoreUint32(&p.serving, 1)
|
p.serving.Store(true)
|
||||||
defer atomic.StoreUint32(&p.serving, 0)
|
defer p.serving.Store(false)
|
||||||
|
|
||||||
// Spawn a main loop to handle all incoming messages.
|
// Spawn a main loop to handle all incoming messages.
|
||||||
for {
|
for {
|
||||||
|
16
les/peer.go
16
les/peer.go
@ -124,9 +124,9 @@ type peerCommons struct {
|
|||||||
id string // Peer identity.
|
id string // Peer identity.
|
||||||
version int // Protocol version negotiated.
|
version int // Protocol version negotiated.
|
||||||
network uint64 // Network ID being on.
|
network uint64 // Network ID being on.
|
||||||
frozen uint32 // Flag whether the peer is frozen.
|
frozen atomic.Bool // Flag whether the peer is frozen.
|
||||||
announceType uint64 // New block announcement type.
|
announceType uint64 // New block announcement type.
|
||||||
serving uint32 // The status indicates the peer is served.
|
serving atomic.Bool // The status indicates the peer is served.
|
||||||
headInfo blockInfo // Last announced block information.
|
headInfo blockInfo // Last announced block information.
|
||||||
|
|
||||||
// Background task queue for caching peer tasks and executing in order.
|
// Background task queue for caching peer tasks and executing in order.
|
||||||
@ -143,7 +143,7 @@ type peerCommons struct {
|
|||||||
// isFrozen returns true if the client is frozen or the server has put our
|
// isFrozen returns true if the client is frozen or the server has put our
|
||||||
// client in frozen state
|
// client in frozen state
|
||||||
func (p *peerCommons) isFrozen() bool {
|
func (p *peerCommons) isFrozen() bool {
|
||||||
return atomic.LoadUint32(&p.frozen) != 0
|
return p.frozen.Load()
|
||||||
}
|
}
|
||||||
|
|
||||||
// canQueue returns an indicator whether the peer can queue an operation.
|
// canQueue returns an indicator whether the peer can queue an operation.
|
||||||
@ -398,7 +398,7 @@ func (p *serverPeer) rejectUpdate(size uint64) bool {
|
|||||||
// freeze processes Stop messages from the given server and set the status as
|
// freeze processes Stop messages from the given server and set the status as
|
||||||
// frozen.
|
// frozen.
|
||||||
func (p *serverPeer) freeze() {
|
func (p *serverPeer) freeze() {
|
||||||
if atomic.CompareAndSwapUint32(&p.frozen, 0, 1) {
|
if p.frozen.CompareAndSwap(false, true) {
|
||||||
p.sendQueue.Clear()
|
p.sendQueue.Clear()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -406,7 +406,7 @@ func (p *serverPeer) freeze() {
|
|||||||
// unfreeze processes Resume messages from the given server and set the status
|
// unfreeze processes Resume messages from the given server and set the status
|
||||||
// as unfrozen.
|
// as unfrozen.
|
||||||
func (p *serverPeer) unfreeze() {
|
func (p *serverPeer) unfreeze() {
|
||||||
atomic.StoreUint32(&p.frozen, 0)
|
p.frozen.Store(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
// sendRequest send a request to the server based on the given message type
|
// sendRequest send a request to the server based on the given message type
|
||||||
@ -823,11 +823,11 @@ func (p *clientPeer) freeze() {
|
|||||||
if p.version < lpv3 {
|
if p.version < lpv3 {
|
||||||
// if Stop/Resume is not supported then just drop the peer after setting
|
// if Stop/Resume is not supported then just drop the peer after setting
|
||||||
// its frozen status permanently
|
// its frozen status permanently
|
||||||
atomic.StoreUint32(&p.frozen, 1)
|
p.frozen.Store(true)
|
||||||
p.Peer.Disconnect(p2p.DiscUselessPeer)
|
p.Peer.Disconnect(p2p.DiscUselessPeer)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if atomic.SwapUint32(&p.frozen, 1) == 0 {
|
if !p.frozen.Swap(true) {
|
||||||
go func() {
|
go func() {
|
||||||
p.sendStop()
|
p.sendStop()
|
||||||
time.Sleep(freezeTimeBase + time.Duration(rand.Int63n(int64(freezeTimeRandom))))
|
time.Sleep(freezeTimeBase + time.Duration(rand.Int63n(int64(freezeTimeRandom))))
|
||||||
@ -840,7 +840,7 @@ func (p *clientPeer) freeze() {
|
|||||||
time.Sleep(freezeCheckPeriod)
|
time.Sleep(freezeCheckPeriod)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
atomic.StoreUint32(&p.frozen, 0)
|
p.frozen.Store(false)
|
||||||
p.sendResume(bufValue)
|
p.sendResume(bufValue)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
@ -19,7 +19,6 @@ package les
|
|||||||
import (
|
import (
|
||||||
"errors"
|
"errors"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/ethereum/go-ethereum/common"
|
"github.com/ethereum/go-ethereum/common"
|
||||||
@ -164,8 +163,8 @@ func (h *serverHandler) handle(p *clientPeer) error {
|
|||||||
}()
|
}()
|
||||||
|
|
||||||
// Mark the peer as being served.
|
// Mark the peer as being served.
|
||||||
atomic.StoreUint32(&p.serving, 1)
|
p.serving.Store(true)
|
||||||
defer atomic.StoreUint32(&p.serving, 0)
|
defer p.serving.Store(false)
|
||||||
|
|
||||||
// Spawn a main loop to handle all incoming messages.
|
// Spawn a main loop to handle all incoming messages.
|
||||||
for {
|
for {
|
||||||
|
@ -25,7 +25,6 @@ import (
|
|||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"fmt"
|
"fmt"
|
||||||
"math/big"
|
"math/big"
|
||||||
"sync/atomic"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -380,7 +379,7 @@ func newTestPeerPair(name string, version int, server *serverHandler, client *cl
|
|||||||
return nil, nil, fmt.Errorf("failed to establish protocol connection %v", err)
|
return nil, nil, fmt.Errorf("failed to establish protocol connection %v", err)
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
if atomic.LoadUint32(&peer1.serving) == 1 && atomic.LoadUint32(&peer2.serving) == 1 {
|
if peer1.serving.Load() && peer2.serving.Load() {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
time.Sleep(50 * time.Millisecond)
|
time.Sleep(50 * time.Millisecond)
|
||||||
@ -441,7 +440,7 @@ func (client *testClient) newRawPeer(t *testing.T, name string, version int, rec
|
|||||||
return nil, nil, nil
|
return nil, nil, nil
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
if atomic.LoadUint32(&peer.serving) == 1 {
|
if peer.serving.Load() {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
time.Sleep(50 * time.Millisecond)
|
time.Sleep(50 * time.Millisecond)
|
||||||
@ -505,7 +504,7 @@ func (server *testServer) newRawPeer(t *testing.T, name string, version int) (*t
|
|||||||
return nil, nil, nil
|
return nil, nil, nil
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
if atomic.LoadUint32(&peer.serving) == 1 {
|
if peer.serving.Load() {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
time.Sleep(50 * time.Millisecond)
|
time.Sleep(50 * time.Millisecond)
|
||||||
|
@ -20,7 +20,6 @@ import (
|
|||||||
"crypto/rand"
|
"crypto/rand"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"sync/atomic"
|
|
||||||
"testing"
|
"testing"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@ -136,7 +135,7 @@ func connect(server *serverHandler, serverId enode.ID, client *clientHandler, pr
|
|||||||
return nil, nil, fmt.Errorf("failed to establish protocol connection %v", err)
|
return nil, nil, fmt.Errorf("failed to establish protocol connection %v", err)
|
||||||
default:
|
default:
|
||||||
}
|
}
|
||||||
if atomic.LoadUint32(&peer1.serving) == 1 && atomic.LoadUint32(&peer2.serving) == 1 {
|
if peer1.serving.Load() && peer2.serving.Load() {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
time.Sleep(50 * time.Millisecond)
|
time.Sleep(50 * time.Millisecond)
|
||||||
|
Loading…
Reference in New Issue
Block a user