mirror of https://github.com/PCSX2/pcsx2.git
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:
parent
90ad6e89ad
commit
c36fccdd8e
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue