mirror of https://github.com/PCSX2/pcsx2.git
GS/HW: Fix incorrect page mask in ClearGSLocalMemory()
This commit is contained in:
parent
56b83e5cfa
commit
39b4fd47c7
|
@ -6207,7 +6207,7 @@ void GSRendererHW::ClearGSLocalMemory(const GSOffset& off, const GSVector4i& r,
|
||||||
pxAssert((off.bp() & (BLOCKS_PER_PAGE - 1)) == 0);
|
pxAssert((off.bp() & (BLOCKS_PER_PAGE - 1)) == 0);
|
||||||
for (u32 current_page = off.bp() >> 5; top < page_aligned_bottom; top += pgs.y, current_page += fbw)
|
for (u32 current_page = off.bp() >> 5; top < page_aligned_bottom; top += pgs.y, current_page += fbw)
|
||||||
{
|
{
|
||||||
current_page &= 0x7ff;
|
current_page &= (MAX_PAGES - 1);
|
||||||
GSVector4i* ptr = reinterpret_cast<GSVector4i*>(m_mem.vm8() + current_page * PAGE_SIZE);
|
GSVector4i* ptr = reinterpret_cast<GSVector4i*>(m_mem.vm8() + current_page * PAGE_SIZE);
|
||||||
GSVector4i* const ptr_end = ptr + iterations_per_page;
|
GSVector4i* const ptr_end = ptr + iterations_per_page;
|
||||||
while (ptr != ptr_end)
|
while (ptr != ptr_end)
|
||||||
|
@ -6222,7 +6222,7 @@ void GSRendererHW::ClearGSLocalMemory(const GSOffset& off, const GSVector4i& r,
|
||||||
pxAssert((off.bp() & (BLOCKS_PER_PAGE - 1)) == 0);
|
pxAssert((off.bp() & (BLOCKS_PER_PAGE - 1)) == 0);
|
||||||
for (u32 current_page = off.bp() >> 5; top < page_aligned_bottom; top += pgs.y, current_page += fbw)
|
for (u32 current_page = off.bp() >> 5; top < page_aligned_bottom; top += pgs.y, current_page += fbw)
|
||||||
{
|
{
|
||||||
current_page &= 0x7ff;
|
current_page &= (MAX_PAGES - 1);
|
||||||
GSVector4i* ptr = reinterpret_cast<GSVector4i*>(m_mem.vm8() + current_page * PAGE_SIZE);
|
GSVector4i* ptr = reinterpret_cast<GSVector4i*>(m_mem.vm8() + current_page * PAGE_SIZE);
|
||||||
GSVector4i* const ptr_end = ptr + iterations_per_page;
|
GSVector4i* const ptr_end = ptr + iterations_per_page;
|
||||||
while (ptr != ptr_end)
|
while (ptr != ptr_end)
|
||||||
|
@ -6241,7 +6241,7 @@ void GSRendererHW::ClearGSLocalMemory(const GSOffset& off, const GSVector4i& r,
|
||||||
pxAssert((off.bp() & (BLOCKS_PER_PAGE - 1)) == 0);
|
pxAssert((off.bp() & (BLOCKS_PER_PAGE - 1)) == 0);
|
||||||
for (u32 current_page = off.bp() >> 5; top < page_aligned_bottom; top += pgs.y, current_page += fbw)
|
for (u32 current_page = off.bp() >> 5; top < page_aligned_bottom; top += pgs.y, current_page += fbw)
|
||||||
{
|
{
|
||||||
current_page &= 0x7ff;
|
current_page &= (MAX_PAGES - 1);
|
||||||
GSVector4i* ptr = reinterpret_cast<GSVector4i*>(m_mem.vm8() + current_page * PAGE_SIZE);
|
GSVector4i* ptr = reinterpret_cast<GSVector4i*>(m_mem.vm8() + current_page * PAGE_SIZE);
|
||||||
GSVector4i* const ptr_end = ptr + iterations_per_page;
|
GSVector4i* const ptr_end = ptr + iterations_per_page;
|
||||||
while (ptr != ptr_end)
|
while (ptr != ptr_end)
|
||||||
|
|
Loading…
Reference in New Issue