diff options
author | Chia-I Wu <[email protected]> | 2013-06-20 12:57:42 +0800 |
---|---|---|
committer | Chia-I Wu <[email protected]> | 2013-06-25 12:10:34 +0800 |
commit | 96e2133e72ec0fb6173b79838f1a7d153b8f25b6 (patch) | |
tree | 4769c51ac033e5771cde6b8c235da1a0f4f8974b /src/gallium/drivers/ilo/ilo_shader.c | |
parent | f0afedeb750d9f696242294c730827a28bdaac70 (diff) |
ilo: clean up finalize_shader_states()
Add ilo_shader_select_kernel() to replace the dependency table,
ilo_shader_variant_init(), and ilo_shader_state_use_variant().
With the changes, we no longer need to include ilo_shader_internal.h in
ilo_state.c.
Diffstat (limited to 'src/gallium/drivers/ilo/ilo_shader.c')
-rw-r--r-- | src/gallium/drivers/ilo/ilo_shader.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/src/gallium/drivers/ilo/ilo_shader.c b/src/gallium/drivers/ilo/ilo_shader.c index 0f22ebb4dd8..4d63ec69098 100644 --- a/src/gallium/drivers/ilo/ilo_shader.c +++ b/src/gallium/drivers/ilo/ilo_shader.c @@ -29,6 +29,7 @@ #include "intel_winsys.h" #include "shader/ilo_shader_internal.h" +#include "ilo_state.h" #include "ilo_shader.h" struct ilo_shader_cache { @@ -687,6 +688,10 @@ ilo_shader_create_vs(const struct ilo_dev_info *dev, shader = ilo_shader_state_create(precompile, PIPE_SHADER_VERTEX, state); + /* states used in ilo_shader_variant_init() */ + shader->info.non_orthogonal_states = ILO_DIRTY_VERTEX_SAMPLER_VIEWS | + ILO_DIRTY_RASTERIZER; + return shader; } @@ -699,6 +704,11 @@ ilo_shader_create_gs(const struct ilo_dev_info *dev, shader = ilo_shader_state_create(precompile, PIPE_SHADER_GEOMETRY, state); + /* states used in ilo_shader_variant_init() */ + shader->info.non_orthogonal_states = ILO_DIRTY_GEOMETRY_SAMPLER_VIEWS | + ILO_DIRTY_VS | + ILO_DIRTY_RASTERIZER; + return shader; } @@ -711,6 +721,11 @@ ilo_shader_create_fs(const struct ilo_dev_info *dev, shader = ilo_shader_state_create(precompile, PIPE_SHADER_FRAGMENT, state); + /* states used in ilo_shader_variant_init() */ + shader->info.non_orthogonal_states = ILO_DIRTY_FRAGMENT_SAMPLER_VIEWS | + ILO_DIRTY_RASTERIZER | + ILO_DIRTY_FRAMEBUFFER; + return shader; } @@ -723,6 +738,8 @@ ilo_shader_create_cs(const struct ilo_dev_info *dev, shader = ilo_shader_state_create(precompile, PIPE_SHADER_COMPUTE, state); + shader->info.non_orthogonal_states = 0; + return shader; } @@ -740,3 +757,28 @@ ilo_shader_destroy(struct ilo_shader_state *shader) FREE((struct tgsi_token *) shader->info.tokens); FREE(shader); } + +/** + * Select a kernel for the given context. This will compile a new kernel if + * none of the existing kernels work with the context. + * + * \param ilo the context + * \param dirty states of the context that are considered changed + * \return true if a different kernel is selected + */ +bool +ilo_shader_select_kernel(struct ilo_shader_state *shader, + const struct ilo_context *ilo, + uint32_t dirty) +{ + const struct ilo_shader * const cur = shader->shader; + struct ilo_shader_variant variant; + + if (!(shader->info.non_orthogonal_states & dirty)) + return false; + + ilo_shader_variant_init(&variant, &shader->info, ilo); + ilo_shader_state_use_variant(shader, &variant); + + return (shader->shader != cur); +} |