소스 검색

Better tests. peer_laden is needed beacuse the peer might have

gotten new request if the piece was fully downloaded and found
to be bad.
master
Richard Nyberg 20 년 전
부모
커밋
1e1846b8f3
1개의 변경된 파일2개의 추가작업 그리고 2개의 파일을 삭제
  1. +2
    -2
      btpd/policy_if.c

+ 2
- 2
btpd/policy_if.c 파일 보기

@@ -261,7 +261,7 @@ cm_on_block(struct peer *p, uint32_t index, uint32_t begin, uint32_t length,

if (tp->endgame) {
BTPDQ_FOREACH(p, &tp->peers, cm_entry) {
if (peer_has(p, index) && peer_leech_ok(p))
if (peer_has(p, index) && p->nreqs_out > 0)
peer_cancel(p, index, begin, length);
}
if (pc->ngot == pc->nblocks)
@@ -272,7 +272,7 @@ cm_on_block(struct peer *p, uint32_t index, uint32_t begin, uint32_t length,
pc->nbusy--;
if (pc->ngot == pc->nblocks)
cm_on_piece(pc);
if (peer_leech_ok(p))
if (peer_leech_ok(p) && !peer_laden(p))
cm_assign_requests(p);
}
}

||||||
x
 
000:0
불러오는 중...
취소
저장