TextureCacheBase: Delete textures completely instead of just invalidating them in ClearRenderTargets.
That's what would've been done in the next TCB::Load() call, anyway. Fixes issue 5742. Additionally, change efb copies to specify 1 as the number of mipmaps because that makes more sense than anything else.
This commit is contained in:
parent
4c7b63cf0e
commit
0811311604
|
@ -205,8 +205,11 @@ void TextureCache::ClearRenderTargets()
|
||||||
tcend = textures.end();
|
tcend = textures.end();
|
||||||
|
|
||||||
for (; iter!=tcend; ++iter)
|
for (; iter!=tcend; ++iter)
|
||||||
if (iter->second->type != TCET_EC_DYNAMIC)
|
if (iter->second->type == TCET_EC_VRAM)
|
||||||
iter->second->type = TCET_NORMAL;
|
{
|
||||||
|
delete iter->second;
|
||||||
|
textures.erase(iter++);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool TextureCache::CheckForCustomTextureLODs(u64 tex_hash, int texformat, unsigned int levels)
|
bool TextureCache::CheckForCustomTextureLODs(u64 tex_hash, int texformat, unsigned int levels)
|
||||||
|
@ -782,7 +785,7 @@ void TextureCache::CopyRenderTargetToTexture(u32 dstAddr, unsigned int dstFormat
|
||||||
textures[dstAddr] = entry = g_texture_cache->CreateRenderTargetTexture(scaled_tex_w, scaled_tex_h);
|
textures[dstAddr] = entry = g_texture_cache->CreateRenderTargetTexture(scaled_tex_w, scaled_tex_h);
|
||||||
|
|
||||||
// TODO: Using the wrong dstFormat, dumb...
|
// TODO: Using the wrong dstFormat, dumb...
|
||||||
entry->SetGeneralParameters(dstAddr, 0, dstFormat, 0);
|
entry->SetGeneralParameters(dstAddr, 0, dstFormat, 1);
|
||||||
entry->SetDimensions(tex_w, tex_h, scaled_tex_w, scaled_tex_h);
|
entry->SetDimensions(tex_w, tex_h, scaled_tex_w, scaled_tex_h);
|
||||||
entry->SetHashes(TEXHASH_INVALID);
|
entry->SetHashes(TEXHASH_INVALID);
|
||||||
entry->type = TCET_EC_VRAM;
|
entry->type = TCET_EC_VRAM;
|
||||||
|
|
Loading…
Reference in New Issue