gsdx: fix crash when preload data frame is enabled

Height of the dirty rectangle must be the GS size of the RT. Of course
RT doesn't have any height so we compute the max safest value.

Fix issue #987

Candidate for 1.4 release
This commit is contained in:
Gregory Hainaut 2015-12-28 17:56:04 +01:00
parent 90ad6e89ad
commit c36fccdd8e
1 changed files with 8 additions and 1 deletions

View File

@ -338,7 +338,14 @@ GSTextureCache::Target* GSTextureCache::LookupTarget(const GIFRegTEX0& TEX0, int
if (s_IS_OPENGL) { if (s_IS_OPENGL) {
if (m_preload_frame) { if (m_preload_frame) {
GL_INS("Preloading the RT DATA"); GL_INS("Preloading the RT DATA");
dst->m_dirty.push_back(GSDirtyRect(GSVector4i(0, 0, TEX0.TBW * 64, h), TEX0.PSM)); // RT doesn't have height but if we use a too big value, we will read outside of the GS memory.
int page0 = TEX0.TBP0 >> 5;
int max_page = (MAX_PAGES - page0);
int max_h = 32 * max_page / TEX0.TBW;
// h is likely smaller than w (true most of the time). Reduce the upload size (speed)
max_h = std::min(max_h, TEX0.TBW * 64);
dst->m_dirty.push_back(GSDirtyRect(GSVector4i(0, 0, TEX0.TBW * 64, max_h), TEX0.PSM));
dst->Update(); dst->Update();
} else { } else {
#ifdef ENABLE_OGL_DEBUG #ifdef ENABLE_OGL_DEBUG