Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
dms3
go-dms3
Commits
e5983cbe
Commit
e5983cbe
authored
Nov 18, 2014
by
Brian Tiger Chow
Committed by
Jeromy
Dec 05, 2014
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
some renaming
License: MIT Signed-off-by:
Brian Tiger Chow
<
brian@perfmode.com
>
parent
6c2a6669
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
12 additions
and
14 deletions
+12
-14
exchange/bitswap/bitswap.go
exchange/bitswap/bitswap.go
+11
-13
exchange/bitswap/bitswap_test.go
exchange/bitswap/bitswap_test.go
+1
-1
No files found.
exchange/bitswap/bitswap.go
View file @
e5983cbe
...
...
@@ -155,21 +155,19 @@ func (bs *bitswap) sendWantListTo(ctx context.Context, peers <-chan peer.Peer) e
}
func
(
bs
*
bitswap
)
run
(
ctx
context
.
Context
)
{
var
sendlist
<-
chan
peer
.
Peer
// Every so often, we should resend out our current want list
const
rebroadcastTime
=
time
.
Second
*
5
// Time to wait before sending out wantlists to better batch up requests
const
bufferTime
=
time
.
Millisecond
*
3
peersPerSend
:=
6
timeout
:=
time
.
After
(
rebroadcastTime
)
const
rebroadcastPeriod
=
time
.
Second
*
5
// Every so often, we should resend out our current want list
const
batchDelay
=
time
.
Millisecond
*
3
// Time to wait before sending out wantlists to better batch up requests
const
peersPerSend
=
6
const
threshold
=
10
var
sendlist
<-
chan
peer
.
Peer
// NB: must be initialized to zero value
broadcastSignal
:=
time
.
After
(
rebroadcastPeriod
)
unsent
:=
0
for
{
select
{
case
<-
timeout
:
case
<-
broadcastSignal
:
wantlist
:=
bs
.
wantlist
.
Keys
()
if
len
(
wantlist
)
==
0
{
continue
...
...
@@ -184,7 +182,7 @@ func (bs *bitswap) run(ctx context.Context) {
log
.
Errorf
(
"error sending wantlist: %s"
,
err
)
}
sendlist
=
nil
timeout
=
time
.
After
(
rebroadcast
Time
)
broadcastSignal
=
time
.
After
(
rebroadcast
Period
)
case
k
:=
<-
bs
.
blockRequests
:
if
unsent
==
0
{
sendlist
=
bs
.
routing
.
FindProvidersAsync
(
ctx
,
k
,
peersPerSend
)
...
...
@@ -198,12 +196,12 @@ func (bs *bitswap) run(ctx context.Context) {
log
.
Errorf
(
"error sending wantlist: %s"
,
err
)
}
unsent
=
0
timeout
=
time
.
After
(
rebroadcast
Time
)
broadcastSignal
=
time
.
After
(
rebroadcast
Period
)
sendlist
=
nil
}
else
{
// set a timeout to wait for more blocks or send current wantlist
timeout
=
time
.
After
(
b
ufferTime
)
broadcastSignal
=
time
.
After
(
b
atchDelay
)
}
case
<-
ctx
.
Done
()
:
return
...
...
exchange/bitswap/bitswap_test.go
View file @
e5983cbe
...
...
@@ -294,7 +294,7 @@ func session(net tn.Network, rs mock.RoutingServer, id peer.ID) instance {
routing
:
htc
,
sender
:
adapter
,
wantlist
:
util
.
NewKeySet
(),
blockReq
:
make
(
chan
util
.
Key
,
32
),
blockReq
uests
:
make
(
chan
util
.
Key
,
32
),
}
adapter
.
SetDelegate
(
bs
)
go
bs
.
run
(
context
.
TODO
())
...
...
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