Merge pull request #2581 from mimimi085181/FreeTexture-code-cleanup

Code cleanup for FreeTexture after merging PR #2097
This commit is contained in:
Markus Wick 2015-06-10 12:49:20 +02:00
commit 9b8eb55cd4
2 changed files with 14 additions and 18 deletions

View File

@ -154,7 +154,7 @@ void TextureCache::Cleanup(int _frameCount)
// EFB copies living on the host GPU are unrecoverable and thus shouldn't be deleted
!iter->second->IsEfbCopy())
{
iter = RemoveTextureFromCache(iter);
iter = FreeTexture(iter);
}
else
{
@ -191,7 +191,7 @@ void TextureCache::MakeRangeDynamic(u32 start_address, u32 size)
{
if (iter->second->OverlapsMemoryRange(start_address, size))
{
iter = RemoveTextureFromCache(iter);
iter = FreeTexture(iter);
}
else
{
@ -388,8 +388,7 @@ TextureCache::TCacheEntryBase* TextureCache::Load(const u32 stage)
// never be useful again. It's theoretically possible for a game to do
// something weird where the copy could become useful in the future, but in
// practice it doesn't happen.
FreeTexture(entry);
iter = textures_by_address.erase(iter);
iter = FreeTexture(iter);
continue;
}
}
@ -461,7 +460,7 @@ TextureCache::TCacheEntryBase* TextureCache::Load(const u32 stage)
if (temp_frameCount != 0x7fffffff)
{
// pool this texture and make a new one later
RemoveTextureFromCache(oldest_entry);
FreeTexture(oldest_entry);
}
std::shared_ptr<HiresTexture> hires_tex;
@ -885,7 +884,7 @@ void TextureCache::CopyRenderTargetToTexture(u32 dstAddr, unsigned int dstFormat
TexCache::iterator iter = iter_range.first;
while (iter != iter_range.second)
{
iter = RemoveTextureFromCache(iter);
iter = FreeTexture(iter);
}
// create the texture
@ -937,20 +936,18 @@ TextureCache::TCacheEntryBase* TextureCache::AllocateTexture(const TCacheEntryCo
return entry;
}
TextureCache::TexCache::iterator TextureCache::RemoveTextureFromCache(TexCache::iterator iter)
TextureCache::TexCache::iterator TextureCache::FreeTexture(TexCache::iterator iter)
{
if (iter->second->textures_by_hash_iter != textures_by_address.end())
TCacheEntryBase* entry = iter->second;
if (entry->textures_by_hash_iter != textures_by_address.end())
{
textures_by_hash.erase(iter->second->textures_by_hash_iter);
iter->second->textures_by_hash_iter = textures_by_address.end();
textures_by_hash.erase(entry->textures_by_hash_iter);
entry->textures_by_hash_iter = textures_by_address.end();
}
FreeTexture(iter->second);
return textures_by_address.erase(iter);
}
void TextureCache::FreeTexture(TCacheEntryBase* entry)
{
entry->frameCount = FRAMECOUNT_INVALID;
texture_pool.insert(TexPool::value_type(entry->config, entry));
return textures_by_address.erase(iter);
}

View File

@ -140,8 +140,7 @@ private:
static void CheckTempSize(size_t required_size);
static TCacheEntryBase* AllocateTexture(const TCacheEntryConfig& config);
static TexCache::iterator RemoveTextureFromCache(TexCache::iterator t_iter);
static void FreeTexture(TCacheEntryBase* entry);
static TexCache::iterator FreeTexture(TexCache::iterator t_iter);
static TCacheEntryBase* ReturnEntry(unsigned int stage, TCacheEntryBase* entry);