forked from premiere/premiere-libtorrent
fixes to the new disk cache and the volatile cache feature
This commit is contained in:
parent
ccf8b0278a
commit
53144f6f14
|
@ -392,33 +392,6 @@ namespace libtorrent
|
||||||
add_job(j, l);
|
add_job(j, l);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool range_overlap(int start1, int length1, int start2, int length2)
|
|
||||||
{
|
|
||||||
return (start1 <= start2 && start1 + length1 > start2)
|
|
||||||
|| (start2 <= start1 && start2 + length2 > start1);
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace
|
|
||||||
{
|
|
||||||
// The semantic of this operator is:
|
|
||||||
// should lhs come before rhs in the job queue
|
|
||||||
bool operator<(disk_io_job const& lhs, disk_io_job const& rhs)
|
|
||||||
{
|
|
||||||
// NOTE: comparison inverted to make higher priority
|
|
||||||
// skip _in_front_of_ lower priority
|
|
||||||
if (lhs.priority > rhs.priority) return true;
|
|
||||||
if (lhs.priority < rhs.priority) return false;
|
|
||||||
|
|
||||||
if (lhs.storage.get() < rhs.storage.get()) return true;
|
|
||||||
if (lhs.storage.get() > rhs.storage.get()) return false;
|
|
||||||
if (lhs.piece < rhs.piece) return true;
|
|
||||||
if (lhs.piece > rhs.piece) return false;
|
|
||||||
if (lhs.offset < rhs.offset) return true;
|
|
||||||
// if (lhs.offset > rhs.offset) return false;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
struct update_last_use
|
struct update_last_use
|
||||||
{
|
{
|
||||||
void operator()(disk_io_thread::cached_piece_entry& p)
|
void operator()(disk_io_thread::cached_piece_entry& p)
|
||||||
|
@ -463,8 +436,11 @@ namespace libtorrent
|
||||||
cache_lru_index_t& ridx = m_read_pieces.get<1>();
|
cache_lru_index_t& ridx = m_read_pieces.get<1>();
|
||||||
i = ridx.begin();
|
i = ridx.begin();
|
||||||
while (i != ridx.end() && now - i->last_use > cut_off)
|
while (i != ridx.end() && now - i->last_use > cut_off)
|
||||||
|
{
|
||||||
|
free_piece(const_cast<cached_piece_entry&>(*i), l);
|
||||||
ridx.erase(i++);
|
ridx.erase(i++);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// returns the number of blocks that were freed
|
// returns the number of blocks that were freed
|
||||||
int disk_io_thread::free_piece(cached_piece_entry& p, mutex::scoped_lock& l)
|
int disk_io_thread::free_piece(cached_piece_entry& p, mutex::scoped_lock& l)
|
||||||
|
@ -711,12 +687,6 @@ namespace libtorrent
|
||||||
{
|
{
|
||||||
std::memcpy(buf.get() + offset, p.blocks[i].buf, block_size);
|
std::memcpy(buf.get() + offset, p.blocks[i].buf, block_size);
|
||||||
offset += m_block_size;
|
offset += m_block_size;
|
||||||
if (m_settings.volatile_read_cache)
|
|
||||||
{
|
|
||||||
free_buffer(p.blocks[i].buf);
|
|
||||||
p.blocks[i].buf = 0;
|
|
||||||
--p.num_blocks;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
buffer_size += block_size;
|
buffer_size += block_size;
|
||||||
TORRENT_ASSERT(p.num_blocks > 0);
|
TORRENT_ASSERT(p.num_blocks > 0);
|
||||||
|
@ -1126,7 +1096,8 @@ namespace libtorrent
|
||||||
TORRENT_ASSERT(ret > 0);
|
TORRENT_ASSERT(ret > 0);
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
cache_piece_index_t& idx = m_read_pieces.get<0>();
|
cache_piece_index_t& idx = m_read_pieces.get<0>();
|
||||||
idx.modify(p, update_last_use());
|
if (p->num_blocks == 0) idx.erase(p);
|
||||||
|
else idx.modify(p, update_last_use());
|
||||||
|
|
||||||
// if read cache is disabled or we exceeded the
|
// if read cache is disabled or we exceeded the
|
||||||
// limit, remove this piece from the cache
|
// limit, remove this piece from the cache
|
||||||
|
@ -1243,6 +1214,8 @@ namespace libtorrent
|
||||||
free_buffer(p.blocks[block].buf);
|
free_buffer(p.blocks[block].buf);
|
||||||
p.blocks[block].buf = 0;
|
p.blocks[block].buf = 0;
|
||||||
--p.num_blocks;
|
--p.num_blocks;
|
||||||
|
--m_cache_stats.cache_size;
|
||||||
|
--m_cache_stats.read_cache_size;
|
||||||
}
|
}
|
||||||
++block;
|
++block;
|
||||||
}
|
}
|
||||||
|
@ -1289,7 +1262,8 @@ namespace libtorrent
|
||||||
|
|
||||||
ret = copy_from_piece(const_cast<cached_piece_entry&>(*p), hit, j, l);
|
ret = copy_from_piece(const_cast<cached_piece_entry&>(*p), hit, j, l);
|
||||||
if (ret < 0) return ret;
|
if (ret < 0) return ret;
|
||||||
idx.modify(p, update_last_use());
|
if (p->num_blocks == 0) idx.erase(p);
|
||||||
|
else idx.modify(p, update_last_use());
|
||||||
|
|
||||||
ret = j.buffer_size;
|
ret = j.buffer_size;
|
||||||
++m_cache_stats.blocks_read;
|
++m_cache_stats.blocks_read;
|
||||||
|
|
Loading…
Reference in New Issue