GPUDevice: Fix erratic texture pool recycling
This commit is contained in:
parent
98d5b98ab1
commit
6d07d70946
|
@ -793,25 +793,23 @@ std::unique_ptr<GPUTexture> GPUDevice::FetchTexture(u32 width, u32 height, u32 l
|
||||||
if (is_texture && m_features.prefer_unused_textures)
|
if (is_texture && m_features.prefer_unused_textures)
|
||||||
{
|
{
|
||||||
// Try to find a texture that wasn't used this frame first.
|
// Try to find a texture that wasn't used this frame first.
|
||||||
// Start at the back of the pool.
|
for (it = m_texture_pool.begin(); it != m_texture_pool.end(); ++it)
|
||||||
it = m_texture_pool.end();
|
|
||||||
for (auto rit = m_texture_pool.rbegin(); rit != m_texture_pool.rend(); ++rit)
|
|
||||||
{
|
{
|
||||||
if (rit->use_counter == m_texture_pool_counter)
|
if (it->use_counter == m_texture_pool_counter)
|
||||||
{
|
{
|
||||||
// We're into textures recycled this frame, not going to find anything newer.
|
// We're into textures recycled this frame, not going to find anything newer.
|
||||||
// But prefer reuse over creating a new texture.
|
// But prefer reuse over creating a new texture.
|
||||||
if (m_texture_pool.size() < pool_size)
|
if (m_texture_pool.size() < pool_size)
|
||||||
|
{
|
||||||
|
it = m_texture_pool.end();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (rit->key == key)
|
if (it->key == key)
|
||||||
{
|
|
||||||
it = std::prev(rit.base());
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (it = pool.begin(); it != pool.end(); ++it)
|
for (it = pool.begin(); it != pool.end(); ++it)
|
||||||
|
@ -869,7 +867,7 @@ void GPUDevice::RecycleTexture(std::unique_ptr<GPUTexture> texture)
|
||||||
pool.push_back({std::move(texture), m_texture_pool_counter, key});
|
pool.push_back({std::move(texture), m_texture_pool_counter, key});
|
||||||
|
|
||||||
const u32 max_size = is_texture ? MAX_TEXTURE_POOL_SIZE : MAX_TARGET_POOL_SIZE;
|
const u32 max_size = is_texture ? MAX_TEXTURE_POOL_SIZE : MAX_TARGET_POOL_SIZE;
|
||||||
while (pool.size() >= max_size)
|
while (pool.size() > max_size)
|
||||||
{
|
{
|
||||||
Log_ProfileFmt("Trim {}x{} texture from pool", pool.front().texture->GetWidth(), pool.front().texture->GetHeight());
|
Log_ProfileFmt("Trim {}x{} texture from pool", pool.front().texture->GetWidth(), pool.front().texture->GetHeight());
|
||||||
pool.pop_front();
|
pool.pop_front();
|
||||||
|
@ -901,7 +899,7 @@ void GPUDevice::TrimTexturePool()
|
||||||
TexturePool& pool = pool_idx ? m_target_pool : m_texture_pool;
|
TexturePool& pool = pool_idx ? m_target_pool : m_texture_pool;
|
||||||
for (auto it = pool.begin(); it != pool.end();)
|
for (auto it = pool.begin(); it != pool.end();)
|
||||||
{
|
{
|
||||||
const u32 delta = (it->use_counter - prev_counter);
|
const u32 delta = (prev_counter - it->use_counter);
|
||||||
if (delta < POOL_PURGE_DELAY)
|
if (delta < POOL_PURGE_DELAY)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -680,7 +680,7 @@ protected:
|
||||||
std::unique_ptr<GPUSampler> m_linear_sampler;
|
std::unique_ptr<GPUSampler> m_linear_sampler;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static constexpr u32 MAX_TEXTURE_POOL_SIZE = 100;
|
static constexpr u32 MAX_TEXTURE_POOL_SIZE = 125;
|
||||||
static constexpr u32 MAX_TARGET_POOL_SIZE = 50;
|
static constexpr u32 MAX_TARGET_POOL_SIZE = 50;
|
||||||
static constexpr u32 POOL_PURGE_DELAY = 300;
|
static constexpr u32 POOL_PURGE_DELAY = 300;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue