mirror of
https://github.com/ethereum/go-ethereum.git
synced 2026-02-26 15:47:21 +00:00
p2p: use safe atomic operations when changing connFlags (#17325)
This commit is contained in:
parent
c4df67461f
commit
eef65b20fc
1 changed files with 11 additions and 6 deletions
|
|
@ -258,13 +258,18 @@ func (c *conn) is(f connFlag) bool {
|
|||
}
|
||||
|
||||
func (c *conn) set(f connFlag, val bool) {
|
||||
flags := connFlag(atomic.LoadInt32((*int32)(&c.flags)))
|
||||
if val {
|
||||
flags |= f
|
||||
} else {
|
||||
flags &= ^f
|
||||
for {
|
||||
oldFlags := connFlag(atomic.LoadInt32((*int32)(&c.flags)))
|
||||
flags := oldFlags
|
||||
if val {
|
||||
flags |= f
|
||||
} else {
|
||||
flags &= ^f
|
||||
}
|
||||
if atomic.CompareAndSwapInt32((*int32)(&c.flags), int32(oldFlags), int32(flags)) {
|
||||
return
|
||||
}
|
||||
}
|
||||
atomic.StoreInt32((*int32)(&c.flags), int32(flags))
|
||||
}
|
||||
|
||||
// Peers returns all connected peers.
|
||||
|
|
|
|||
Loading…
Reference in a new issue