mirror of
https://github.com/libretro/pcsx2.git
synced 2025-01-14 13:39:00 +00:00
gsdx hw: factorize redundant code
This commit is contained in:
parent
b78c772a14
commit
1011a757a8
@ -372,26 +372,26 @@ void GSRendererHW::Draw()
|
|||||||
(context->FRAME.FBP == context->ZBUF.ZBP && !PRIM->TME && !context->ZBUF.ZMSK && !context->FRAME.FBMSK && context->TEST.ZTE)
|
(context->FRAME.FBP == context->ZBUF.ZBP && !PRIM->TME && !context->ZBUF.ZMSK && !context->FRAME.FBMSK && context->TEST.ZTE)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const bool draw_sprite_tex = PRIM->TME && (m_vt.m_primclass == GS_SPRITE_CLASS);
|
||||||
|
const GSVector4 delta_p = m_vt.m_max.p - m_vt.m_min.p;
|
||||||
|
bool single_page = (delta_p.x <= 64.0f) && (delta_p.y <= 32.0f);
|
||||||
|
|
||||||
if (m_channel_shuffle) {
|
if (m_channel_shuffle) {
|
||||||
GSVector4 delta_p = m_vt.m_max.p - m_vt.m_min.p;
|
m_channel_shuffle = draw_sprite_tex && (m_context->TEX0.PSM == PSM_PSMT8) && single_page;
|
||||||
m_channel_shuffle = PRIM->TME && (m_context->TEX0.PSM == PSM_PSMT8) && (delta_p.x <= 64.0f) && (delta_p.y <= 32.0f) && (m_vt.m_primclass == GS_SPRITE_CLASS);
|
|
||||||
if (m_channel_shuffle) {
|
if (m_channel_shuffle) {
|
||||||
GL_INS("Channel shuffle effect detected SKIP");
|
GL_INS("Channel shuffle effect detected SKIP");
|
||||||
GL_POP();
|
GL_POP();
|
||||||
s_n += 3; // Keep it sync with SW renderer
|
s_n += 3; // Keep it sync with SW renderer
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
} else if (PRIM->TME && m_context->FRAME.Block() == m_context->TEX0.TBP0 && (m_vt.m_primclass == GS_SPRITE_CLASS)) {
|
} else if (draw_sprite_tex && m_context->FRAME.Block() == m_context->TEX0.TBP0) {
|
||||||
// Special post-processing effect
|
// Special post-processing effect
|
||||||
GSVector4 delta_p = m_vt.m_max.p - m_vt.m_min.p;
|
|
||||||
|
|
||||||
if (m_vertex.next == 4) {
|
if (m_vertex.next == 4) {
|
||||||
// Note potentially we could also check the content of vertex (2nd
|
// Note potentially we could also check the content of vertex (2nd
|
||||||
// sprite must be half of the first one)
|
// sprite must be half of the first one)
|
||||||
GL_INS("Double downscale effect detected");
|
GL_INS("Double downscale effect detected");
|
||||||
m_double_downscale = true;
|
m_double_downscale = true;
|
||||||
} else if ((m_context->TEX0.PSM == PSM_PSMT8) && (delta_p.x <= 64.0f) && (delta_p.y <= 32.0f)) {
|
} else if ((m_context->TEX0.PSM == PSM_PSMT8) && single_page) {
|
||||||
//fprintf(stderr, "delta_p %f %f\n", delta_p.x, delta_p.y);
|
|
||||||
if (m_channel_shuffle) {
|
if (m_channel_shuffle) {
|
||||||
GL_INS("Channel shuffle effect detected SKIP");
|
GL_INS("Channel shuffle effect detected SKIP");
|
||||||
GL_POP();
|
GL_POP();
|
||||||
@ -474,13 +474,12 @@ void GSRendererHW::Draw()
|
|||||||
//
|
//
|
||||||
// Both input and output are 16 bits and texture was initially 32 bits!
|
// Both input and output are 16 bits and texture was initially 32 bits!
|
||||||
m_texture_shuffle = (GSLocalMemory::m_psm[context->FRAME.PSM].bpp == 16) && (tex_psm.bpp == 16)
|
m_texture_shuffle = (GSLocalMemory::m_psm[context->FRAME.PSM].bpp == 16) && (tex_psm.bpp == 16)
|
||||||
&& (m_vt.m_primclass == GS_SPRITE_CLASS) && tex->m_32_bits_fmt;
|
&& draw_sprite_tex && tex->m_32_bits_fmt;
|
||||||
|
|
||||||
// Texture shuffle is not yet supported with strange clamp mode
|
// Texture shuffle is not yet supported with strange clamp mode
|
||||||
ASSERT(!m_texture_shuffle || (context->CLAMP.WMS < 3 && context->CLAMP.WMT < 3));
|
ASSERT(!m_texture_shuffle || (context->CLAMP.WMS < 3 && context->CLAMP.WMT < 3));
|
||||||
|
|
||||||
GSVector4 delta_p = m_vt.m_max.p - m_vt.m_min.p;
|
if (tex->m_target && m_context->TEX0.PSM == PSM_PSMT8 && single_page) {
|
||||||
if (tex->m_target && m_context->TEX0.PSM == PSM_PSMT8 && ((delta_p.x <= 64.0f) && (delta_p.y <= 32.0f))) {
|
|
||||||
GL_INS("Channel shuffle effect detected (2nd shot)");
|
GL_INS("Channel shuffle effect detected (2nd shot)");
|
||||||
m_channel_shuffle = true;
|
m_channel_shuffle = true;
|
||||||
} else {
|
} else {
|
||||||
@ -595,7 +594,7 @@ void GSRendererHW::Draw()
|
|||||||
context->ZBUF.ZMSK = zm != 0;
|
context->ZBUF.ZMSK = zm != 0;
|
||||||
|
|
||||||
// A couple of hack to avoid upscaling issue. So far it seems to impacts mostly sprite
|
// A couple of hack to avoid upscaling issue. So far it seems to impacts mostly sprite
|
||||||
if ((m_upscale_multiplier > 1) && (m_vt.m_primclass == GS_SPRITE_CLASS)) {
|
if ((m_upscale_multiplier > 1) && draw_sprite_tex) {
|
||||||
size_t count = m_vertex.next;
|
size_t count = m_vertex.next;
|
||||||
GSVertex* v = &m_vertex.buff[0];
|
GSVertex* v = &m_vertex.buff[0];
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user