gsdx ogl: move GS setup in SetupIA

Fix regression when geometry shader is disabled
This commit is contained in:
Gregory Hainaut 2016-08-31 09:22:35 +02:00
parent 165bcf5662
commit 448fee76c1
2 changed files with 43 additions and 53 deletions

View File

@ -64,7 +64,7 @@ bool GSRendererOGL::CreateDevice(GSDevice* dev)
void GSRendererOGL::Lines2Sprites() void GSRendererOGL::Lines2Sprites()
{ {
if (m_vt.m_primclass != GS_SPRITE_CLASS) return; ASSERT(m_vt.m_primclass == GS_SPRITE_CLASS);
// each sprite converted to quad needs twice the space // each sprite converted to quad needs twice the space
@ -126,7 +126,7 @@ void GSRendererOGL::Lines2Sprites()
} }
} }
void GSRendererOGL::SetupIA() void GSRendererOGL::SetupIA(const float& sx, const float& sy)
{ {
GL_PUSH("IA"); GL_PUSH("IA");
@ -138,35 +138,51 @@ void GSRendererOGL::SetupIA()
m_vertex.buff[i].UV &= 0x3FEF3FEF; m_vertex.buff[i].UV &= 0x3FEF3FEF;
} }
if (!GLLoader::found_geometry_shader)
Lines2Sprites();
dev->IASetVertexBuffer(m_vertex.buff, m_vertex.next);
dev->IASetIndexBuffer(m_index.buff, m_index.tail);
GLenum t = 0; GLenum t = 0;
bool unscale_hack = UserHacks_unscale_pt_ln & (GetUpscaleMultiplier() > 1) & GLLoader::found_geometry_shader;
switch(m_vt.m_primclass) switch(m_vt.m_primclass)
{ {
case GS_POINT_CLASS: case GS_POINT_CLASS:
t = GL_POINTS; if (unscale_hack) {
break; m_gs_sel.point = 1;
case GS_LINE_CLASS: vs_cb.PointSize = GSVector2(16.0f * sx, 16.0f * sy);
t = GL_LINES; }
break;
case GS_SPRITE_CLASS: t = GL_POINTS;
if (GLLoader::found_geometry_shader) break;
case GS_LINE_CLASS:
if (unscale_hack) {
m_gs_sel.line = 1;
vs_cb.PointSize = GSVector2(16.0f * sx, 16.0f * sy);
}
t = GL_LINES; t = GL_LINES;
else break;
case GS_SPRITE_CLASS:
if (GLLoader::found_geometry_shader) {
m_gs_sel.sprite = 1;
t = GL_LINES;
} else {
Lines2Sprites();
t = GL_TRIANGLES;
}
break;
case GS_TRIANGLE_CLASS:
t = GL_TRIANGLES; t = GL_TRIANGLES;
break; break;
case GS_TRIANGLE_CLASS:
t = GL_TRIANGLES; default:
break; __assume(0);
default:
__assume(0);
} }
dev->IASetVertexBuffer(m_vertex.buff, m_vertex.next);
dev->IASetIndexBuffer(m_index.buff, m_index.tail);
dev->IASetPrimitiveTopology(t); dev->IASetPrimitiveTopology(t);
} }
@ -1333,45 +1349,19 @@ void GSRendererOGL::DrawPrims(GSTexture* rt, GSTexture* ds, GSTextureCache::Sour
// Always bind the RT. This way special effect can use it. // Always bind the RT. This way special effect can use it.
dev->PSSetShaderResource(3, rt); dev->PSSetShaderResource(3, rt);
// GS
bool unscale_hack = UserHacks_unscale_pt_ln & (GetUpscaleMultiplier() > 1) & GLLoader::found_geometry_shader;
switch(m_vt.m_primclass)
{
case GS_POINT_CLASS:
if (unscale_hack) {
m_gs_sel.point = 1;
vs_cb.PointSize = GSVector2(2.0f * rtscale.x / rtsize.x, 2.0f * rtscale.y / rtsize.y);
}
break;
case GS_LINE_CLASS:
if (unscale_hack) {
m_gs_sel.line = 1;
vs_cb.PointSize = GSVector2(2.0f * rtscale.x / rtsize.x, 2.0f * rtscale.y / rtsize.y);
}
break;
case GS_SPRITE_CLASS:
m_gs_sel.sprite = 1;
break;
case GS_TRIANGLE_CLASS:
break;
default:
__assume(0);
}
dev->SetupPipeline(m_vs_sel, m_gs_sel, m_ps_sel);
// rs // rs
const GSVector4& hacked_scissor = m_channel_shuffle ? GSVector4(0, 0, 1024, 1024) : m_context->scissor.in; const GSVector4& hacked_scissor = m_channel_shuffle ? GSVector4(0, 0, 1024, 1024) : m_context->scissor.in;
GSVector4i scissor = GSVector4i(GSVector4(rtscale).xyxy() * hacked_scissor).rintersect(GSVector4i(rtsize).zwxy()); GSVector4i scissor = GSVector4i(GSVector4(rtscale).xyxy() * hacked_scissor).rintersect(GSVector4i(rtsize).zwxy());
SetupIA(); SetupIA(sx, sy);
dev->OMSetColorMaskState(m_om_csel); dev->OMSetColorMaskState(m_om_csel);
dev->SetupOM(m_om_dssel); dev->SetupOM(m_om_dssel);
dev->SetupCB(&vs_cb, &ps_cb); dev->SetupCB(&vs_cb, &ps_cb);
dev->SetupPipeline(m_vs_sel, m_gs_sel, m_ps_sel);
if (DATE_GL42) { if (DATE_GL42) {
GL_PUSH("Date GL42"); GL_PUSH("Date GL42");
// It could be good idea to use stencil in the same time. // It could be good idea to use stencil in the same time.

View File

@ -75,7 +75,7 @@ class GSRendererOGL final : public GSRendererHW
private: private:
inline void ResetStates(); inline void ResetStates();
inline void Lines2Sprites(); inline void Lines2Sprites();
inline void SetupIA(); inline void SetupIA(const float& sx, const float& sy);
inline void EmulateTextureShuffleAndFbmask(); inline void EmulateTextureShuffleAndFbmask();
inline void EmulateChannelShuffle(GSTexture** rt, const GSTextureCache::Source* tex); inline void EmulateChannelShuffle(GSTexture** rt, const GSTextureCache::Source* tex);
inline void EmulateBlending(bool DATE_GL42); inline void EmulateBlending(bool DATE_GL42);