From: Topi Pohjolainen Date: Fri, 1 Apr 2016 18:42:21 +0000 (+0300) Subject: i965/blorp: Add support for setting fast clear operation X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=da5a477ce413e4355eb5d826d112459629087fb0;p=mesa.git i965/blorp: Add support for setting fast clear operation Signed-off-by: Topi Pohjolainen Reviewed-by: Kenneth Graunke --- diff --git a/src/mesa/drivers/dri/i965/brw_blorp.cpp b/src/mesa/drivers/dri/i965/brw_blorp.cpp index 8c69f6f3147..18296237efd 100644 --- a/src/mesa/drivers/dri/i965/brw_blorp.cpp +++ b/src/mesa/drivers/dri/i965/brw_blorp.cpp @@ -164,6 +164,7 @@ brw_blorp_params::brw_blorp_params(unsigned num_varyings, y1(0), depth_format(0), hiz_op(GEN6_HIZ_OP_NONE), + fast_clear_op(0), use_wm_prog(false), num_varyings(num_varyings), num_draw_buffers(num_draw_buffers), diff --git a/src/mesa/drivers/dri/i965/brw_blorp.h b/src/mesa/drivers/dri/i965/brw_blorp.h index a1aaa2096f2..a291aff4525 100644 --- a/src/mesa/drivers/dri/i965/brw_blorp.h +++ b/src/mesa/drivers/dri/i965/brw_blorp.h @@ -241,6 +241,7 @@ public: brw_blorp_surface_info src; brw_blorp_surface_info dst; enum gen6_hiz_op hiz_op; + unsigned fast_clear_op; bool use_wm_prog; brw_blorp_wm_push_constants wm_push_consts; const unsigned num_varyings; diff --git a/src/mesa/drivers/dri/i965/gen7_blorp.cpp b/src/mesa/drivers/dri/i965/gen7_blorp.cpp index 630128cdc8d..11d075ae903 100644 --- a/src/mesa/drivers/dri/i965/gen7_blorp.cpp +++ b/src/mesa/drivers/dri/i965/gen7_blorp.cpp @@ -532,6 +532,8 @@ gen7_blorp_emit_ps_config(struct brw_context *brw, dw5 |= prog_data->first_curbe_grf << GEN7_PS_DISPATCH_START_GRF_SHIFT_0; } + dw4 |= params->fast_clear_op; + BEGIN_BATCH(8); OUT_BATCH(_3DSTATE_PS << 16 | (8 - 2)); OUT_BATCH(params->use_wm_prog ? prog_offset : 0); diff --git a/src/mesa/drivers/dri/i965/gen8_blorp.cpp b/src/mesa/drivers/dri/i965/gen8_blorp.cpp index d362dbe9053..65ebf5ba44c 100644 --- a/src/mesa/drivers/dri/i965/gen8_blorp.cpp +++ b/src/mesa/drivers/dri/i965/gen8_blorp.cpp @@ -386,6 +386,7 @@ gen8_blorp_emit_ps_config(struct brw_context *brw, dw6 |= (64 - 2) << HSW_PS_MAX_THREADS_SHIFT; dw6 |= GEN7_PS_POSOFFSET_NONE; + dw6 |= params->fast_clear_op; BEGIN_BATCH(12); OUT_BATCH(_3DSTATE_PS << 16 | (12 - 2));