mirror of https://github.com/PCSX2/pcsx2.git
GSdx: Update D3D fbmask emulation on texture shuffle.
Improves accuracy on Sly series. Rendering is still bad and needs a lot more work but it's a little bit better.
This commit is contained in:
parent
0f5d3d2f1b
commit
c8c9731262
|
@ -119,17 +119,20 @@ void GSRendererDX11::EmulateTextureShuffleAndFbmask()
|
||||||
|
|
||||||
// Please bang my head against the wall!
|
// Please bang my head against the wall!
|
||||||
// 1/ Reduce the frame mask to a 16 bit format
|
// 1/ Reduce the frame mask to a 16 bit format
|
||||||
// FIXME GSVector will be nice here
|
|
||||||
const uint32& m = m_context->FRAME.FBMSK;
|
const uint32& m = m_context->FRAME.FBMSK;
|
||||||
uint32 fbmask = ((m >> 3) & 0x1F) | ((m >> 6) & 0x3E0) | ((m >> 9) & 0x7C00) | ((m >> 16) & 0x8000);
|
uint32 fbmask = ((m >> 3) & 0x1F) | ((m >> 6) & 0x3E0) | ((m >> 9) & 0x7C00) | ((m >> 16) & 0x8000);
|
||||||
|
// FIXME GSVector will be nice here
|
||||||
|
uint8 rg_mask = fbmask & 0xFF;
|
||||||
|
uint8 ba_mask = (fbmask >> 8) & 0xFF;
|
||||||
om_bsel.wrgba = 0;
|
om_bsel.wrgba = 0;
|
||||||
|
|
||||||
// 2 Select the new mask (Please someone put SSE here)
|
// 2 Select the new mask (Please someone put SSE here)
|
||||||
if ((fbmask & 0xFF) == 0) {
|
if (rg_mask != 0xFF) {
|
||||||
if (write_ba)
|
if (write_ba) {
|
||||||
om_bsel.wb = 1;
|
om_bsel.wb = 1;
|
||||||
else
|
} else {
|
||||||
om_bsel.wr = 1;
|
om_bsel.wr = 1;
|
||||||
|
}
|
||||||
} else if ((fbmask & 0xFF) != 0xFF) {
|
} else if ((fbmask & 0xFF) != 0xFF) {
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
fprintf(stderr, "Please fix me! wb %u wr %u\n", om_bsel.wb, om_bsel.wr);
|
fprintf(stderr, "Please fix me! wb %u wr %u\n", om_bsel.wb, om_bsel.wr);
|
||||||
|
@ -137,12 +140,12 @@ void GSRendererDX11::EmulateTextureShuffleAndFbmask()
|
||||||
//ASSERT(0);
|
//ASSERT(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
fbmask >>= 8;
|
if (ba_mask != 0xFF) {
|
||||||
if ((fbmask & 0xFF) == 0) {
|
if (write_ba) {
|
||||||
if (write_ba)
|
|
||||||
om_bsel.wa = 1;
|
om_bsel.wa = 1;
|
||||||
else
|
} else {
|
||||||
om_bsel.wg = 1;
|
om_bsel.wg = 1;
|
||||||
|
}
|
||||||
} else if ((fbmask & 0xFF) != 0xFF) {
|
} else if ((fbmask & 0xFF) != 0xFF) {
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
fprintf(stderr, "Please fix me! wa %u wg %u\n", om_bsel.wa, om_bsel.wg);
|
fprintf(stderr, "Please fix me! wa %u wg %u\n", om_bsel.wa, om_bsel.wg);
|
||||||
|
|
|
@ -444,7 +444,7 @@ void GSRendererOGL::EmulateChannelShuffle(GSTexture** rt, const GSTextureCache::
|
||||||
//
|
//
|
||||||
// Note: Tales Of Abyss and Tekken5 could hit this path too. Those games are
|
// Note: Tales Of Abyss and Tekken5 could hit this path too. Those games are
|
||||||
// handled above.
|
// handled above.
|
||||||
GL_INS("maybe not a channel!");
|
GL_INS("Maybe not a channel!");
|
||||||
m_channel_shuffle = false;
|
m_channel_shuffle = false;
|
||||||
} else if (m_context->CLAMP.WMS == 3 && ((m_context->CLAMP.MAXU & 0x8) == 8)) {
|
} else if (m_context->CLAMP.WMS == 3 && ((m_context->CLAMP.MAXU & 0x8) == 8)) {
|
||||||
// Read either blue or Alpha. Let's go for Blue ;)
|
// Read either blue or Alpha. Let's go for Blue ;)
|
||||||
|
@ -495,7 +495,7 @@ void GSRendererOGL::EmulateChannelShuffle(GSTexture** rt, const GSTextureCache::
|
||||||
m_ps_sel.channel = 1;
|
m_ps_sel.channel = 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
GL_INS("channel not supported");
|
GL_INS("Channel not supported");
|
||||||
m_channel_shuffle = false;
|
m_channel_shuffle = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue