summaryrefslogtreecommitdiffstats
path: root/src/gallium
diff options
context:
space:
mode:
authorChristoph Bumiller <[email protected]>2011-10-13 22:36:27 +0200
committerChristoph Bumiller <[email protected]>2011-10-21 23:00:38 +0200
commit3dff43d8974f3eab650df613ac56d92a1f81d8ec (patch)
tree79a2bf54978de0b3b1da56b81d1146fabf611268 /src/gallium
parent74ff845e336ed0ccd6884aa072a19ac7ce7dd0a2 (diff)
d3d1x: avoid translating invalid blend, depth or stencil state
Diffstat (limited to 'src/gallium')
-rw-r--r--src/gallium/state_trackers/d3d1x/gd3d11/d3d11_screen.h86
-rw-r--r--src/gallium/state_trackers/d3d1x/gd3d1x/d3d1x_private.h2
2 files changed, 56 insertions, 32 deletions
diff --git a/src/gallium/state_trackers/d3d1x/gd3d11/d3d11_screen.h b/src/gallium/state_trackers/d3d1x/gd3d11/d3d11_screen.h
index bed1dcb3383..84d747199f1 100644
--- a/src/gallium/state_trackers/d3d1x/gd3d11/d3d11_screen.h
+++ b/src/gallium/state_trackers/d3d1x/gd3d11/d3d11_screen.h
@@ -391,27 +391,29 @@ struct GalliumD3D11ScreenImpl : public GalliumD3D11Screen
template<typename T, typename U>
bool convert_blend_state(T& to, const U& from, unsigned BlendEnable, unsigned RenderTargetWriteMask)
{
- if(invalid(0
- || from.SrcBlend >= D3D11_BLEND_COUNT
- || from.SrcBlendAlpha >= D3D11_BLEND_COUNT
- || from.DestBlend >= D3D11_BLEND_COUNT
- || from.DestBlendAlpha >= D3D11_BLEND_COUNT
- || from.BlendOp >= 6
- || from.BlendOpAlpha >= 6
- || !from.BlendOp
- || !from.BlendOpAlpha
- ))
+ if(unlikely(BlendEnable &&
+ (from.SrcBlend >= D3D11_BLEND_COUNT ||
+ from.SrcBlendAlpha >= D3D11_BLEND_COUNT ||
+ from.DestBlend >= D3D11_BLEND_COUNT ||
+ from.DestBlendAlpha >= D3D11_BLEND_COUNT ||
+ from.BlendOp >= 6 ||
+ from.BlendOp == 0 ||
+ from.BlendOpAlpha >= 6 ||
+ from.BlendOpAlpha == 0)))
return false;
to.blend_enable = BlendEnable;
- to.rgb_func = from.BlendOp - 1;
- to.alpha_func = from.BlendOpAlpha - 1;
+ if(BlendEnable)
+ {
+ to.rgb_func = from.BlendOp - 1;
+ to.alpha_func = from.BlendOpAlpha - 1;
- to.rgb_src_factor = d3d11_to_pipe_blend[from.SrcBlend];
- to.alpha_src_factor = d3d11_to_pipe_blend[from.SrcBlendAlpha];
- to.rgb_dst_factor = d3d11_to_pipe_blend[from.DestBlend];
- to.alpha_dst_factor = d3d11_to_pipe_blend[from.DestBlendAlpha];
+ to.rgb_src_factor = d3d11_to_pipe_blend[from.SrcBlend];
+ to.alpha_src_factor = d3d11_to_pipe_blend[from.SrcBlendAlpha];
+ to.rgb_dst_factor = d3d11_to_pipe_blend[from.DestBlend];
+ to.alpha_dst_factor = d3d11_to_pipe_blend[from.DestBlendAlpha];
+ }
to.colormask = RenderTargetWriteMask & 0xf;
return true;
@@ -435,8 +437,10 @@ struct GalliumD3D11ScreenImpl : public GalliumD3D11Screen
memset(&state, 0, sizeof(state));
state.alpha_to_coverage = !!blend_state_desc->AlphaToCoverageEnable;
state.independent_blend_enable = !!blend_state_desc->IndependentBlendEnable;
+
assert(PIPE_MAX_COLOR_BUFS >= 8);
- for(unsigned i = 0; i < 8; ++i)
+ const unsigned n = blend_state_desc->IndependentBlendEnable ? 8 : 1;
+ for(unsigned i = 0; i < n; ++i)
{
if(!convert_blend_state(
state.rt[i],
@@ -506,23 +510,41 @@ struct GalliumD3D11ScreenImpl : public GalliumD3D11Screen
pipe_depth_stencil_alpha_state state;
memset(&state, 0, sizeof(state));
+
state.depth.enabled = !!depth_stencil_state_desc->DepthEnable;
- state.depth.writemask = depth_stencil_state_desc->DepthWriteMask;
- state.depth.func = depth_stencil_state_desc->DepthFunc - 1;
+ if(depth_stencil_state_desc->DepthEnable)
+ {
+ if(depth_stencil_state_desc->DepthFunc == 0 ||
+ depth_stencil_state_desc->DepthFunc >= 9)
+ return E_INVALIDARG;
+ state.depth.writemask = depth_stencil_state_desc->DepthWriteMask;
+ state.depth.func = depth_stencil_state_desc->DepthFunc - 1;
+ }
+
state.stencil[0].enabled = !!depth_stencil_state_desc->StencilEnable;
- state.stencil[0].writemask = depth_stencil_state_desc->StencilWriteMask;
- state.stencil[0].valuemask = depth_stencil_state_desc->StencilReadMask;
- state.stencil[0].zpass_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->FrontFace.StencilPassOp];
- state.stencil[0].fail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->FrontFace.StencilFailOp];
- state.stencil[0].zfail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->FrontFace.StencilDepthFailOp];
- state.stencil[0].func = depth_stencil_state_desc->FrontFace.StencilFunc - 1;
- state.stencil[1].enabled = !!depth_stencil_state_desc->StencilEnable;
- state.stencil[1].writemask = depth_stencil_state_desc->StencilWriteMask;
- state.stencil[1].valuemask = depth_stencil_state_desc->StencilReadMask;
- state.stencil[1].zpass_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->BackFace.StencilPassOp];
- state.stencil[1].fail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->BackFace.StencilFailOp];
- state.stencil[1].zfail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->BackFace.StencilDepthFailOp];
- state.stencil[1].func = depth_stencil_state_desc->BackFace.StencilFunc - 1;
+ if(depth_stencil_state_desc->StencilEnable)
+ {
+ if(depth_stencil_state_desc->FrontFace.StencilPassOp >= D3D11_STENCIL_OP_COUNT ||
+ depth_stencil_state_desc->FrontFace.StencilFailOp >= D3D11_STENCIL_OP_COUNT ||
+ depth_stencil_state_desc->FrontFace.StencilDepthFailOp >= D3D11_STENCIL_OP_COUNT ||
+ depth_stencil_state_desc->BackFace.StencilPassOp >= D3D11_STENCIL_OP_COUNT ||
+ depth_stencil_state_desc->BackFace.StencilFailOp >= D3D11_STENCIL_OP_COUNT ||
+ depth_stencil_state_desc->BackFace.StencilDepthFailOp >= D3D11_STENCIL_OP_COUNT)
+ return E_INVALIDARG;
+ state.stencil[0].writemask = depth_stencil_state_desc->StencilWriteMask;
+ state.stencil[0].valuemask = depth_stencil_state_desc->StencilReadMask;
+ state.stencil[0].zpass_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->FrontFace.StencilPassOp];
+ state.stencil[0].fail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->FrontFace.StencilFailOp];
+ state.stencil[0].zfail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->FrontFace.StencilDepthFailOp];
+ state.stencil[0].func = depth_stencil_state_desc->FrontFace.StencilFunc - 1;
+ state.stencil[1].enabled = !!depth_stencil_state_desc->StencilEnable;
+ state.stencil[1].writemask = depth_stencil_state_desc->StencilWriteMask;
+ state.stencil[1].valuemask = depth_stencil_state_desc->StencilReadMask;
+ state.stencil[1].zpass_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->BackFace.StencilPassOp];
+ state.stencil[1].fail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->BackFace.StencilFailOp];
+ state.stencil[1].zfail_op = d3d11_to_pipe_stencil_op[depth_stencil_state_desc->BackFace.StencilDepthFailOp];
+ state.stencil[1].func = depth_stencil_state_desc->BackFace.StencilFunc - 1;
+ }
if(!depth_stencil_state)
return S_FALSE;
diff --git a/src/gallium/state_trackers/d3d1x/gd3d1x/d3d1x_private.h b/src/gallium/state_trackers/d3d1x/gd3d1x/d3d1x_private.h
index 9d5d9c30b06..247fa0da42a 100644
--- a/src/gallium/state_trackers/d3d1x/gd3d1x/d3d1x_private.h
+++ b/src/gallium/state_trackers/d3d1x/gd3d1x/d3d1x_private.h
@@ -76,12 +76,14 @@ extern "C"
#define D3D11_STAGE_CS 5
#define D3D11_STAGES 6
+#define D3D10_BLEND_COUNT 20
#define D3D11_BLEND_COUNT 20
extern unsigned d3d11_to_pipe_blend[D3D11_BLEND_COUNT];
#define D3D11_USAGE_COUNT 4
extern unsigned d3d11_to_pipe_usage[D3D11_USAGE_COUNT];
+#define D3D10_STENCIL_OP_COUNT 9
#define D3D11_STENCIL_OP_COUNT 9
extern unsigned d3d11_to_pipe_stencil_op[D3D11_STENCIL_OP_COUNT];