Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
fb5d0852
Unverified
Commit
fb5d0852
authored
Feb 23, 2018
by
Guillaume Ballet
Committed by
GitHub
Feb 23, 2018
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #16146 from status-im/pombeirp/whisperv6-peer-race-cond-fix
Fix race condition in whisperv6/peer.go
parents
44d40ffc
34d94e22
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
6 additions
and
0 deletions
+6
-0
peer.go
whisper/whisperv6/peer.go
+6
-0
No files found.
whisper/whisperv6/peer.go
View file @
fb5d0852
...
@@ -19,6 +19,7 @@ package whisperv6
...
@@ -19,6 +19,7 @@ package whisperv6
import
(
import
(
"fmt"
"fmt"
"math"
"math"
"sync"
"time"
"time"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/common"
...
@@ -36,6 +37,7 @@ type Peer struct {
...
@@ -36,6 +37,7 @@ type Peer struct {
trusted
bool
trusted
bool
powRequirement
float64
powRequirement
float64
bloomMu
sync
.
Mutex
bloomFilter
[]
byte
bloomFilter
[]
byte
fullNode
bool
fullNode
bool
...
@@ -225,10 +227,14 @@ func (peer *Peer) notifyAboutBloomFilterChange(bloom []byte) error {
...
@@ -225,10 +227,14 @@ func (peer *Peer) notifyAboutBloomFilterChange(bloom []byte) error {
}
}
func
(
peer
*
Peer
)
bloomMatch
(
env
*
Envelope
)
bool
{
func
(
peer
*
Peer
)
bloomMatch
(
env
*
Envelope
)
bool
{
peer
.
bloomMu
.
Lock
()
defer
peer
.
bloomMu
.
Unlock
()
return
peer
.
fullNode
||
bloomFilterMatch
(
peer
.
bloomFilter
,
env
.
Bloom
())
return
peer
.
fullNode
||
bloomFilterMatch
(
peer
.
bloomFilter
,
env
.
Bloom
())
}
}
func
(
peer
*
Peer
)
setBloomFilter
(
bloom
[]
byte
)
{
func
(
peer
*
Peer
)
setBloomFilter
(
bloom
[]
byte
)
{
peer
.
bloomMu
.
Lock
()
defer
peer
.
bloomMu
.
Unlock
()
peer
.
bloomFilter
=
bloom
peer
.
bloomFilter
=
bloom
peer
.
fullNode
=
isFullNode
(
bloom
)
peer
.
fullNode
=
isFullNode
(
bloom
)
if
peer
.
fullNode
&&
peer
.
bloomFilter
==
nil
{
if
peer
.
fullNode
&&
peer
.
bloomFilter
==
nil
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment