Commit 69ae2cc7 authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

d3d10/effect: Use SamplerState.Texture when setting shader resources.

parent c0e2138e
...@@ -94,8 +94,6 @@ static struct d3d10_effect_variable null_matrix_variable = {{(const ID3D10Effect ...@@ -94,8 +94,6 @@ static struct d3d10_effect_variable null_matrix_variable = {{(const ID3D10Effect
&null_local_buffer, &null_type}; &null_local_buffer, &null_type};
static struct d3d10_effect_variable null_string_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_string_variable_vtbl}, static struct d3d10_effect_variable null_string_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_string_variable_vtbl},
&null_local_buffer, &null_type}; &null_local_buffer, &null_type};
static struct d3d10_effect_variable null_shader_resource_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_shader_resource_variable_vtbl},
&null_local_buffer, &null_type};
static struct d3d10_effect_variable null_render_target_view_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_render_target_view_variable_vtbl}, static struct d3d10_effect_variable null_render_target_view_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_render_target_view_variable_vtbl},
&null_local_buffer, &null_type}; &null_local_buffer, &null_type};
static struct d3d10_effect_variable null_depth_stencil_view_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_depth_stencil_view_variable_vtbl}, static struct d3d10_effect_variable null_depth_stencil_view_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_depth_stencil_view_variable_vtbl},
...@@ -111,6 +109,16 @@ static struct d3d10_effect_variable null_rasterizer_variable = {{(const ID3D10Ef ...@@ -111,6 +109,16 @@ static struct d3d10_effect_variable null_rasterizer_variable = {{(const ID3D10Ef
static struct d3d10_effect_variable null_sampler_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_sampler_variable_vtbl}, static struct d3d10_effect_variable null_sampler_variable = {{(const ID3D10EffectVariableVtbl *)&d3d10_effect_sampler_variable_vtbl},
&null_local_buffer, &null_type}; &null_local_buffer, &null_type};
static ID3D10ShaderResourceView *null_srvs[D3D10_COMMONSHADER_INPUT_RESOURCE_SLOT_COUNT];
static struct d3d10_effect_variable null_shader_resource_variable =
{
.ID3D10EffectVariable_iface.lpVtbl = (ID3D10EffectVariableVtbl *)&d3d10_effect_shader_resource_variable_vtbl,
.buffer = &null_local_buffer,
.type = &null_type,
.u.resource.srv = null_srvs,
};
/* anonymous_shader_type and anonymous_shader */ /* anonymous_shader_type and anonymous_shader */
static char anonymous_name[] = "$Anonymous"; static char anonymous_name[] = "$Anonymous";
static char anonymous_vertexshader_name[] = "vertexshader"; static char anonymous_vertexshader_name[] = "vertexshader";
...@@ -1683,6 +1691,7 @@ static BOOL read_value_list(const char *data, size_t data_size, DWORD offset, ...@@ -1683,6 +1691,7 @@ static BOOL read_value_list(const char *data, size_t data_size, DWORD offset,
break; break;
case D3D10_SVT_TEXTURE: case D3D10_SVT_TEXTURE:
*(void **)out_data = &null_shader_resource_variable;
break; break;
default: default:
...@@ -3909,8 +3918,17 @@ static void apply_shader_resources(ID3D10Device *device, struct d3d10_effect_var ...@@ -3909,8 +3918,17 @@ static void apply_shader_resources(ID3D10Device *device, struct d3d10_effect_var
} }
break; break;
case D3D10_SIT_TBUFFER:
case D3D10_SIT_TEXTURE: case D3D10_SIT_TEXTURE:
if (rsrc_v->type->basetype == D3D10_SVT_SAMPLER)
{
TRACE("Using texture associated with sampler %s.\n", debugstr_a(rsrc_v->name));
rsrc_v = rsrc_v->u.state.desc.sampler.texture;
}
/* fallthrough */
case D3D10_SIT_TBUFFER:
if (sr->in_type == D3D10_SIT_TBUFFER) if (sr->in_type == D3D10_SIT_TBUFFER)
{ {
update_buffer(device, rsrc_v); update_buffer(device, rsrc_v);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment