[Mesa-dev] [PATCH] radeonsi: disable perfect ZPASS counts for PIPE_QUERY_OCCLUSION_PREDICATE
Nicolai Hähnle
nhaehnle at gmail.com
Thu Apr 7 00:47:08 UTC 2016
Reviewed-by: Nicolai Hähnle <nicolai.haehnle at amd.com>
On 06.04.2016 19:36, Marek Olšák wrote:
> From: Marek Olšák <marek.olsak at amd.com>
>
> ---
> src/gallium/drivers/radeon/r600_pipe_common.h | 3 ++-
> src/gallium/drivers/radeon/r600_query.c | 12 ++++++++++--
> src/gallium/drivers/radeonsi/si_state.c | 6 ++++--
> 3 files changed, 16 insertions(+), 5 deletions(-)
>
> diff --git a/src/gallium/drivers/radeon/r600_pipe_common.h b/src/gallium/drivers/radeon/r600_pipe_common.h
> index 381ad21..062c319 100644
> --- a/src/gallium/drivers/radeon/r600_pipe_common.h
> +++ b/src/gallium/drivers/radeon/r600_pipe_common.h
> @@ -425,8 +425,9 @@ struct r600_common_context {
> unsigned flags; /* flush flags */
>
> /* Queries. */
> - /* The list of active queries. Only one query of each type can be active. */
> + /* The list of active queries. */
> int num_occlusion_queries;
> + int num_perfect_occlusion_queries;
> /* Keep track of non-timer queries, because they should be suspended
> * during context flushing.
> * The timer queries (TIME_ELAPSED) shouldn't be suspended for blits,
> diff --git a/src/gallium/drivers/radeon/r600_query.c b/src/gallium/drivers/radeon/r600_query.c
> index f9a5721..7a2d2ee 100644
> --- a/src/gallium/drivers/radeon/r600_query.c
> +++ b/src/gallium/drivers/radeon/r600_query.c
> @@ -414,14 +414,22 @@ static void r600_update_occlusion_query_state(struct r600_common_context *rctx,
> if (type == PIPE_QUERY_OCCLUSION_COUNTER ||
> type == PIPE_QUERY_OCCLUSION_PREDICATE) {
> bool old_enable = rctx->num_occlusion_queries != 0;
> - bool enable;
> + bool old_perfect_enable =
> + rctx->num_perfect_occlusion_queries != 0;
> + bool enable, perfect_enable;
>
> rctx->num_occlusion_queries += diff;
> assert(rctx->num_occlusion_queries >= 0);
>
> + if (type == PIPE_QUERY_OCCLUSION_COUNTER) {
> + rctx->num_perfect_occlusion_queries += diff;
> + assert(rctx->num_perfect_occlusion_queries >= 0);
> + }
> +
> enable = rctx->num_occlusion_queries != 0;
> + perfect_enable = rctx->num_perfect_occlusion_queries != 0;
>
> - if (enable != old_enable) {
> + if (enable != old_enable || perfect_enable != old_perfect_enable) {
> rctx->set_occlusion_query_state(&rctx->b, enable);
> }
> }
> diff --git a/src/gallium/drivers/radeonsi/si_state.c b/src/gallium/drivers/radeonsi/si_state.c
> index 462dc63..297fe78 100644
> --- a/src/gallium/drivers/radeonsi/si_state.c
> +++ b/src/gallium/drivers/radeonsi/si_state.c
> @@ -1383,16 +1383,18 @@ static void si_emit_db_render_state(struct si_context *sctx, struct r600_atom *s
>
> /* DB_COUNT_CONTROL (occlusion queries) */
> if (sctx->b.num_occlusion_queries > 0) {
> + bool perfect = sctx->b.num_perfect_occlusion_queries > 0;
> +
> if (sctx->b.chip_class >= CIK) {
> radeon_emit(cs,
> - S_028004_PERFECT_ZPASS_COUNTS(1) |
> + S_028004_PERFECT_ZPASS_COUNTS(perfect) |
> S_028004_SAMPLE_RATE(sctx->framebuffer.log_samples) |
> S_028004_ZPASS_ENABLE(1) |
> S_028004_SLICE_EVEN_ENABLE(1) |
> S_028004_SLICE_ODD_ENABLE(1));
> } else {
> radeon_emit(cs,
> - S_028004_PERFECT_ZPASS_COUNTS(1) |
> + S_028004_PERFECT_ZPASS_COUNTS(perfect) |
> S_028004_SAMPLE_RATE(sctx->framebuffer.log_samples));
> }
> } else {
>
More information about the mesa-dev
mailing list