From f3eda7d85ad47ba61491e8879c186725b10f054d Mon Sep 17 00:00:00 2001 From: hrydgard Date: Sun, 14 Dec 2008 14:28:41 +0000 Subject: [PATCH] GL: Don't create a new texture every time the contents of one is updated. Probably not a noticable speed boost, but still .. it's good to be nice to GL :P git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@1531 8ced0084-cf51-0410-be5f-012b33b47a6e --- .../Plugin_VideoOGL/Src/TextureConverter.cpp | 2 +- .../Plugin_VideoOGL/Src/TextureMngr.cpp | 36 +++++++++---------- 2 files changed, 19 insertions(+), 19 deletions(-) diff --git a/Source/Plugins/Plugin_VideoOGL/Src/TextureConverter.cpp b/Source/Plugins/Plugin_VideoOGL/Src/TextureConverter.cpp index 6637560c7d..3c43ef3aed 100644 --- a/Source/Plugins/Plugin_VideoOGL/Src/TextureConverter.cpp +++ b/Source/Plugins/Plugin_VideoOGL/Src/TextureConverter.cpp @@ -142,7 +142,7 @@ void EncodeToRam(GLuint srcTexture, const TRectangle& sourceRc, TextureMngr::DisableStage(i); GL_REPORT_ERRORD(); - glViewport(0, 0, dstFmtWidth, dstHeight); + glViewport(0, 0, (GLsizei)dstFmtWidth, (GLsizei)dstHeight); glEnable(GL_FRAGMENT_PROGRAM_ARB); glBindProgramARB( GL_FRAGMENT_PROGRAM_ARB, s_rgbToYuyvProgram.glprogid); diff --git a/Source/Plugins/Plugin_VideoOGL/Src/TextureMngr.cpp b/Source/Plugins/Plugin_VideoOGL/Src/TextureMngr.cpp index 9c0fdcd0f1..73543d0e96 100644 --- a/Source/Plugins/Plugin_VideoOGL/Src/TextureMngr.cpp +++ b/Source/Plugins/Plugin_VideoOGL/Src/TextureMngr.cpp @@ -237,6 +237,8 @@ TextureMngr::TCacheEntry* TextureMngr::Load(int texstage, u32 address, int width int bs = TexDecoder_GetBlockWidthInTexels(format) - 1; int expandedWidth = (width + bs) & (~bs); + bool skip_texture_create = false; + if (iter != textures.end()) { TCacheEntry &entry = iter->second; @@ -256,24 +258,21 @@ TextureMngr::TCacheEntry* TextureMngr::Load(int texstage, u32 address, int width } else { - // can potentially do some caching - - //TCacheEntry &entry = entry; - /*if (width == entry.w && height==entry.h && format==entry.fmt) + // Let's reload the new texture data into the same texture, + // instead of destroying it and having to create a new one. + // Might speed up movie playback very, very slightly. + if (width == entry.w && height == entry.h && format == entry.fmt) { - LPDIRECT3DTEXTURE9 tex = entry.texture; - int bs = TexDecoder_GetBlockWidthInTexels(format)-1; - int expandedWidth = (width+bs) & (~bs); - D3DFORMAT dfmt = TexDecoder_Decode(temp,ptr,expandedWidth,height,format, tlutaddr, tlutfmt); - ReplaceTexture2D(tex,temp,width,height,expandedWidth,dfmt); - dev->SetTexture(texstage, stage,tex); - return; + glBindTexture(entry.isNonPow2 ? GL_TEXTURE_RECTANGLE_ARB : GL_TEXTURE_2D, entry.texture); + if (entry.mode.hex != tm0.hex) + entry.SetTextureParameters(tm0); + skip_texture_create = true; } else - {*/ + { entry.Destroy(); textures.erase(iter); - //} + } } } @@ -294,12 +293,13 @@ TextureMngr::TCacheEntry* TextureMngr::Load(int texstage, u32 address, int width entry.addr = address; entry.isRenderTarget = false; - entry.isNonPow2 = ((width & (width - 1)) || (height & (height - 1))); - - glGenTextures(1, (GLuint *)&entry.texture); - GLenum target = entry.isNonPow2 ? GL_TEXTURE_RECTANGLE_ARB : GL_TEXTURE_2D; - glBindTexture(target, entry.texture); + + GLenum target = entry.isNonPow2 ? GL_TEXTURE_RECTANGLE_ARB : GL_TEXTURE_2D; + if (!skip_texture_create) { + glGenTextures(1, (GLuint *)&entry.texture); + glBindTexture(target, entry.texture); + } if (expandedWidth != width) glPixelStorei(GL_UNPACK_ROW_LENGTH, expandedWidth);