forked from premiere/premiere-libtorrent
add more default reporting about the request and download queue of peers to track end-game stall issue
This commit is contained in:
parent
44c95ebbc5
commit
57f24128a9
|
@ -75,14 +75,14 @@ using boost::bind;
|
||||||
|
|
||||||
bool sleep_and_input(int* c, int sleep)
|
bool sleep_and_input(int* c, int sleep)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < sleep * 2; ++i)
|
for (int i = 0; i < 2; ++i)
|
||||||
{
|
{
|
||||||
if (_kbhit())
|
if (_kbhit())
|
||||||
{
|
{
|
||||||
*c = _getch();
|
*c = _getch();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
Sleep(500);
|
Sleep(sleep / 2);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
};
|
};
|
||||||
|
@ -137,7 +137,7 @@ retry:
|
||||||
fd_set set;
|
fd_set set;
|
||||||
FD_ZERO(&set);
|
FD_ZERO(&set);
|
||||||
FD_SET(0, &set);
|
FD_SET(0, &set);
|
||||||
timeval tv = {sleep, 0};
|
timeval tv = {sleep/ 1000, (sleep % 1000) * 1000 };
|
||||||
ret = select(1, &set, 0, 0, &tv);
|
ret = select(1, &set, 0, 0, &tv);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
{
|
{
|
||||||
|
@ -146,15 +146,17 @@ retry:
|
||||||
}
|
}
|
||||||
if (errno == EINTR)
|
if (errno == EINTR)
|
||||||
{
|
{
|
||||||
if (total_milliseconds(libtorrent::time_now_hires() - start) < sleep * 1000)
|
if (total_milliseconds(libtorrent::time_now_hires() - start) < sleep)
|
||||||
goto retry;
|
goto retry;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ret < 0 && errno != 0 && errno != ETIMEDOUT)
|
if (ret < 0 && errno != 0 && errno != ETIMEDOUT)
|
||||||
|
{
|
||||||
fprintf(stderr, "select failed: %s\n", strerror(errno));
|
fprintf(stderr, "select failed: %s\n", strerror(errno));
|
||||||
|
libtorrent::sleep(500);
|
||||||
|
}
|
||||||
|
|
||||||
libtorrent::sleep(500);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -451,7 +453,7 @@ void print_peer_info(std::string& out, std::vector<libtorrent::peer_info> const&
|
||||||
#ifndef TORRENT_DISABLE_GEO_IP
|
#ifndef TORRENT_DISABLE_GEO_IP
|
||||||
if (print_as) out += "AS ";
|
if (print_as) out += "AS ";
|
||||||
#endif
|
#endif
|
||||||
out += "down (total | peak ) up (total | peak ) sent-req recv flags source ";
|
out += "down (total | peak ) up (total | peak ) sent-req tmo bsy rcv flags source ";
|
||||||
if (print_fails) out += "fail hshf ";
|
if (print_fails) out += "fail hshf ";
|
||||||
if (print_send_bufs) out += "rq sndb quota rcvb q-bytes ";
|
if (print_send_bufs) out += "rq sndb quota rcvb q-bytes ";
|
||||||
if (print_timers) out += "inactive wait timeout q-time ";
|
if (print_timers) out += "inactive wait timeout q-time ";
|
||||||
|
@ -487,15 +489,22 @@ void print_peer_info(std::string& out, std::vector<libtorrent::peer_info> const&
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
char temp[10];
|
||||||
|
snprintf(temp, sizeof(temp), "%d/%d"
|
||||||
|
, i->download_queue_length
|
||||||
|
, i->target_dl_queue_length);
|
||||||
|
temp[7] = 0;
|
||||||
|
|
||||||
snprintf(str, sizeof(str)
|
snprintf(str, sizeof(str)
|
||||||
, "%s%s (%s|%s) %s%s (%s|%s) %s%3d (%3d) %3d %c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c %c%c%c%c%c%c "
|
, "%s%s (%s|%s) %s%s (%s|%s) %s%7s %4d%4d%4d %c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c %c%c%c%c%c%c "
|
||||||
, esc("32"), add_suffix(i->down_speed, "/s").c_str()
|
, esc("32"), add_suffix(i->down_speed, "/s").c_str()
|
||||||
, add_suffix(i->total_download).c_str(), add_suffix(i->download_rate_peak, "/s").c_str()
|
, add_suffix(i->total_download).c_str(), add_suffix(i->download_rate_peak, "/s").c_str()
|
||||||
, esc("31"), add_suffix(i->up_speed, "/s").c_str(), add_suffix(i->total_upload).c_str()
|
, esc("31"), add_suffix(i->up_speed, "/s").c_str(), add_suffix(i->total_upload).c_str()
|
||||||
, add_suffix(i->upload_rate_peak, "/s").c_str(), esc("0")
|
, add_suffix(i->upload_rate_peak, "/s").c_str(), esc("0")
|
||||||
|
|
||||||
, i->download_queue_length
|
, temp // sent requests and target number of outstanding reqs.
|
||||||
, i->target_dl_queue_length
|
, i->timed_out_requests
|
||||||
|
, i->busy_requests
|
||||||
, i->upload_queue_length
|
, i->upload_queue_length
|
||||||
|
|
||||||
, (i->flags & peer_info::interesting)?'I':'.'
|
, (i->flags & peer_info::interesting)?'I':'.'
|
||||||
|
@ -959,7 +968,7 @@ int main(int argc, char* argv[])
|
||||||
|
|
||||||
proxy_settings ps;
|
proxy_settings ps;
|
||||||
|
|
||||||
int refresh_delay = 1;
|
int refresh_delay = 1000;
|
||||||
bool start_dht = true;
|
bool start_dht = true;
|
||||||
bool start_upnp = true;
|
bool start_upnp = true;
|
||||||
int loop_limit = 0;
|
int loop_limit = 0;
|
||||||
|
|
|
@ -156,6 +156,16 @@ namespace libtorrent
|
||||||
// for yet
|
// for yet
|
||||||
int download_queue_length;
|
int download_queue_length;
|
||||||
|
|
||||||
|
// the number of block requests that have
|
||||||
|
// timed out, and are still in the download
|
||||||
|
// queue
|
||||||
|
int timed_out_requests;
|
||||||
|
|
||||||
|
// the number of busy requests in the download
|
||||||
|
// queue. A budy request is a request for a block
|
||||||
|
// we've also requested from a different peer
|
||||||
|
int busy_requests;
|
||||||
|
|
||||||
// the number of request messages
|
// the number of request messages
|
||||||
// waiting to be sent inside the send buffer
|
// waiting to be sent inside the send buffer
|
||||||
int requests_in_buffer;
|
int requests_in_buffer;
|
||||||
|
|
|
@ -3582,9 +3582,17 @@ namespace libtorrent
|
||||||
p.load_balancing = total_free_upload();
|
p.load_balancing = total_free_upload();
|
||||||
|
|
||||||
p.download_queue_length = int(download_queue().size() + m_request_queue.size());
|
p.download_queue_length = int(download_queue().size() + m_request_queue.size());
|
||||||
p.requests_in_buffer = int(m_requests_in_buffer.size());
|
p.requests_in_buffer = int(m_requests_in_buffer.size() + m_request_queue.size());
|
||||||
p.target_dl_queue_length = int(desired_queue_size());
|
p.target_dl_queue_length = int(desired_queue_size());
|
||||||
p.upload_queue_length = int(upload_queue().size());
|
p.upload_queue_length = int(upload_queue().size());
|
||||||
|
p.timed_out_requests = 0;
|
||||||
|
p.busy_requests = 0;
|
||||||
|
for (std::vector<pending_block>::const_iterator i = m_download_queue.begin()
|
||||||
|
, end(m_download_queue.end()); i != end; ++i)
|
||||||
|
{
|
||||||
|
if (i->timed_out) ++p.timed_out_requests;
|
||||||
|
if (i->busy) ++p.busy_requests;
|
||||||
|
}
|
||||||
|
|
||||||
if (boost::optional<piece_block_progress> ret = downloading_piece_progress())
|
if (boost::optional<piece_block_progress> ret = downloading_piece_progress())
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue