diff options
author | Kenneth Graunke <[email protected]> | 2018-12-19 20:34:55 -0800 |
---|---|---|
committer | Kenneth Graunke <[email protected]> | 2019-02-21 10:26:11 -0800 |
commit | 7ddc1f8dedd181cff37f4fdae72a0967c5914915 (patch) | |
tree | 0fec4494e7d4af0572310955c11706a6a610b2a5 /src | |
parent | 6c17e7d95f36a2f16fc8667243b3b469a2c601a7 (diff) |
iris: Only resolve inputs for actual shader stages
We don't need to consider compute at render time, and don't need to
consider disabled stages. 4% on drawoverhead.
Diffstat (limited to 'src')
-rw-r--r-- | src/gallium/drivers/iris/iris_context.h | 4 | ||||
-rw-r--r-- | src/gallium/drivers/iris/iris_draw.c | 6 | ||||
-rw-r--r-- | src/gallium/drivers/iris/iris_resolve.c | 13 |
3 files changed, 11 insertions, 12 deletions
diff --git a/src/gallium/drivers/iris/iris_context.h b/src/gallium/drivers/iris/iris_context.h index 596b195b5a8..042a2cfb43d 100644 --- a/src/gallium/drivers/iris/iris_context.h +++ b/src/gallium/drivers/iris/iris_context.h @@ -677,8 +677,8 @@ uint64_t iris_timebase_scale(const struct gen_device_info *devinfo, /* iris_resolve.c */ -void iris_predraw_resolve_inputs(struct iris_context *ice, - struct iris_batch *batch); +void iris_predraw_resolve_inputs(struct iris_batch *batch, + struct iris_shader_state *shs); void iris_predraw_resolve_framebuffer(struct iris_context *ice, struct iris_batch *batch); void iris_postdraw_update_resolve_tracking(struct iris_context *ice, diff --git a/src/gallium/drivers/iris/iris_draw.c b/src/gallium/drivers/iris/iris_draw.c index 602a0ec517f..fb62f0c5452 100644 --- a/src/gallium/drivers/iris/iris_draw.c +++ b/src/gallium/drivers/iris/iris_draw.c @@ -98,7 +98,11 @@ iris_draw_vbo(struct pipe_context *ctx, const struct pipe_draw_info *info) iris_update_compiled_shaders(ice); - iris_predraw_resolve_inputs(ice, batch); + for (gl_shader_stage stage = 0; stage < MESA_SHADER_COMPUTE; stage++) { + if (ice->shaders.prog[stage]) + iris_predraw_resolve_inputs(batch, &ice->state.shaders[stage]); + } + iris_predraw_resolve_framebuffer(ice, batch); iris_binder_reserve_3d(ice); diff --git a/src/gallium/drivers/iris/iris_resolve.c b/src/gallium/drivers/iris/iris_resolve.c index 240f6f8c879..737bcfe0e90 100644 --- a/src/gallium/drivers/iris/iris_resolve.c +++ b/src/gallium/drivers/iris/iris_resolve.c @@ -74,16 +74,11 @@ resolve_image_views(struct iris_batch *batch, * enabled depth texture, and flush the render cache for any dirty textures. */ void -iris_predraw_resolve_inputs(struct iris_context *ice, - struct iris_batch *batch) +iris_predraw_resolve_inputs(struct iris_batch *batch, + struct iris_shader_state *shs) { - for (gl_shader_stage stage = 0; stage < MESA_SHADER_STAGES; stage++) { - struct iris_shader_state *shs = &ice->state.shaders[stage]; - resolve_sampler_views(batch, shs); - resolve_image_views(batch, shs); - } - - // XXX: storage images + resolve_sampler_views(batch, shs); + resolve_image_views(batch, shs); } void |