wined3d: Either set SM3 for both vertex and fragment shaders or for neither.
This commit is contained in:
parent
f63a84be61
commit
9d0e17e9ea
|
@ -4924,39 +4924,29 @@ static BOOL shader_glsl_dirty_const(void)
|
||||||
|
|
||||||
static void shader_glsl_get_caps(const struct wined3d_gl_info *gl_info, struct shader_caps *pCaps)
|
static void shader_glsl_get_caps(const struct wined3d_gl_info *gl_info, struct shader_caps *pCaps)
|
||||||
{
|
{
|
||||||
/* Nvidia Geforce6/7 or Ati R4xx/R5xx cards with GLSL support, support VS 3.0 but older Nvidia/Ati
|
/* NVIDIA GeForce 6 / 7 or ATI R4xx / R5xx cards with GLSL support
|
||||||
* models with GLSL support only support 2.0. In case of nvidia we can detect VS 2.0 support based
|
* support SM3, but older NVIDIA / ATI models with GLSL support only
|
||||||
* on the version of NV_vertex_program.
|
* support SM2. In case of NVIDIA we can detect SM3 support based on the
|
||||||
* For Ati cards there's no way using glsl (it abstracts the lowlevel info away) and also not
|
* version of NV_vertex_program / NV_fragment_program. For other cards we
|
||||||
* using ARB_vertex_program. It is safe to assume that when a card supports pixel shader 2.0 it
|
* try to detect SM3 based on the maximum number of native fragment
|
||||||
* supports vertex shader 2.0 too and the way around. We can detect ps2.0 using the maximum number
|
* program instructions. PS2.0 requires at least 96 instructions, 2.0a/b
|
||||||
* of native instructions, so use that here. For more info see the pixel shader versioning code below.
|
* goes up to 512. Assume that if the number of instructions is 512 or
|
||||||
*/
|
* less we have to do with SM2 hardware. NOTE: SM3 requires 512 or more
|
||||||
if ((gl_info->supported[NV_VERTEX_PROGRAM2] && !gl_info->supported[NV_VERTEX_PROGRAM3])
|
* instructions but ATI and NVIDIA offer more than that (1024 vs 4096) on
|
||||||
|| gl_info->limits.arb_ps_instructions <= 512)
|
* their most basic SM3 hardware. */
|
||||||
pCaps->VertexShaderVersion = WINED3DVS_VERSION(2,0);
|
if ((gl_info->supported[NV_VERTEX_PROGRAM3] && gl_info->supported[NV_FRAGMENT_PROGRAM2])
|
||||||
else
|
|| gl_info->limits.arb_ps_instructions > 512)
|
||||||
|
{
|
||||||
pCaps->VertexShaderVersion = WINED3DVS_VERSION(3,0);
|
pCaps->VertexShaderVersion = WINED3DVS_VERSION(3,0);
|
||||||
TRACE_(d3d_caps)("Hardware vertex shader version %d.%d enabled (GLSL)\n", (pCaps->VertexShaderVersion >> 8) & 0xff, pCaps->VertexShaderVersion & 0xff);
|
|
||||||
pCaps->MaxVertexShaderConst = gl_info->limits.glsl_vs_float_constants;
|
|
||||||
|
|
||||||
/* Older DX9-class videocards (GeforceFX / Radeon >9500/X*00) only support pixel shader 2.0/2.0a/2.0b.
|
|
||||||
* In OpenGL the extensions related to GLSL abstract lowlevel GL info away which is needed
|
|
||||||
* to distinguish between 2.0 and 3.0 (and 2.0a/2.0b). In case of Nvidia we use their fragment
|
|
||||||
* program extensions. On other hardware including ATI GL_ARB_fragment_program offers the info
|
|
||||||
* in max native instructions. Intel and others also offer the info in this extension but they
|
|
||||||
* don't support GLSL (at least on Windows).
|
|
||||||
*
|
|
||||||
* PS2.0 requires at least 96 instructions, 2.0a/2.0b go up to 512. Assume that if the number
|
|
||||||
* of instructions is 512 or less we have to do with ps2.0 hardware.
|
|
||||||
* NOTE: ps3.0 hardware requires 512 or more instructions but ati and nvidia offer 'enough' (1024 vs 4096) on their most basic ps3.0 hardware.
|
|
||||||
*/
|
|
||||||
if ((gl_info->supported[NV_FRAGMENT_PROGRAM] && !gl_info->supported[NV_FRAGMENT_PROGRAM2])
|
|
||||||
|| gl_info->limits.arb_ps_instructions <= 512)
|
|
||||||
pCaps->PixelShaderVersion = WINED3DPS_VERSION(2,0);
|
|
||||||
else
|
|
||||||
pCaps->PixelShaderVersion = WINED3DPS_VERSION(3,0);
|
pCaps->PixelShaderVersion = WINED3DPS_VERSION(3,0);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
pCaps->VertexShaderVersion = WINED3DVS_VERSION(2,0);
|
||||||
|
pCaps->PixelShaderVersion = WINED3DPS_VERSION(2,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
pCaps->MaxVertexShaderConst = gl_info->limits.glsl_vs_float_constants;
|
||||||
pCaps->MaxPixelShaderConst = gl_info->limits.glsl_ps_float_constants;
|
pCaps->MaxPixelShaderConst = gl_info->limits.glsl_ps_float_constants;
|
||||||
|
|
||||||
/* FIXME: The following line is card dependent. -8.0 to 8.0 is the
|
/* FIXME: The following line is card dependent. -8.0 to 8.0 is the
|
||||||
|
@ -4972,9 +4962,13 @@ static void shader_glsl_get_caps(const struct wined3d_gl_info *gl_info, struct s
|
||||||
* offer a way to query this.
|
* offer a way to query this.
|
||||||
*/
|
*/
|
||||||
pCaps->PixelShader1xMaxValue = 8.0;
|
pCaps->PixelShader1xMaxValue = 8.0;
|
||||||
TRACE_(d3d_caps)("Hardware pixel shader version %d.%d enabled (GLSL)\n", (pCaps->PixelShaderVersion >> 8) & 0xff, pCaps->PixelShaderVersion & 0xff);
|
|
||||||
|
|
||||||
pCaps->VSClipping = TRUE;
|
pCaps->VSClipping = TRUE;
|
||||||
|
|
||||||
|
TRACE_(d3d_caps)("Hardware vertex shader version %u.%u enabled (GLSL).\n",
|
||||||
|
(pCaps->VertexShaderVersion >> 8) & 0xff, pCaps->VertexShaderVersion & 0xff);
|
||||||
|
TRACE_(d3d_caps)("Hardware pixel shader version %u.%u enabled (GLSL).\n",
|
||||||
|
(pCaps->PixelShaderVersion >> 8) & 0xff, pCaps->PixelShaderVersion & 0xff);
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL shader_glsl_color_fixup_supported(struct color_fixup_desc fixup)
|
static BOOL shader_glsl_color_fixup_supported(struct color_fixup_desc fixup)
|
||||||
|
|
Loading…
Reference in New Issue