diff --git a/src/torrent.cpp b/src/torrent.cpp index da1532dfd..cd1d1a98d 100644 --- a/src/torrent.cpp +++ b/src/torrent.cpp @@ -7011,6 +7011,9 @@ namespace libtorrent { TORRENT_ASSERT(m_ses.is_network_thread()); // build a list of peers and sort it by download_queue_time + // we use this sorted list to determine which peer we should + // request a block from. The higher up a peer is in the list, + // the sooner we will fully download the block we request. std::vector peers; peers.reserve(m_connections.size()); std::remove_copy_if(m_connections.begin(), m_connections.end() @@ -7028,6 +7031,9 @@ namespace libtorrent ptime now = time_now(); + // now, iterate over all time critical pieces, in order of importance, and + // request them from the peers, in order of responsiveness. i.e. request + // the most time critical pieces from the fastest peers. for (std::list::iterator i = m_time_critical_pieces.begin() , end(m_time_critical_pieces.end()); i != end; ++i) { @@ -7035,16 +7041,19 @@ namespace libtorrent + milliseconds(m_average_piece_time + m_piece_time_deviation * 4)) { // don't request pieces whose deadline is too far in the future + // this is one of the termination conditions. We don't want to + // send requests for all pieces in the torrent right away break; } - // loop until every block has been requested from + // loop until every block has been requested from this piece (i->piece) do { // pick the peer with the lowest download_queue_time that has i->piece std::vector::iterator p = std::find_if(peers.begin(), peers.end() , boost::bind(&peer_connection::has_piece, _1, i->piece)); + // obviously we'll have to skip it if we don't have a peer that has this piece if (p == peers.end()) break; peer_connection& c = **p;