[Mesa-dev] [PATCH] nvc0: fix wrong max value for driver queries

Ilia Mirkin imirkin at alum.mit.edu
Sun Mar 8 09:45:46 PDT 2015


On Sun, Mar 8, 2015 at 12:18 PM, Samuel Pitoiset
<samuel.pitoiset at gmail.com> wrote:
> The maximum value of a Gallium HUD's panel is automatically adjusted
> when the current value is greater than the max. If we set the
> pipe_query_driver_info::max_value to UINT64_MAX, the maximum value is
> never adjusted and this results in a right instead of a pretty curve

I'm guessing "right" is translated from "droite"? In english, that's
"straight line".

Can you confirm that this is what other drivers do? Another
interpretation of max_value is "max possible value", and the HUD
should keep track of its own "max seen" thing.

> which is correctly scaled.
>
> Signed-off-by: Samuel Pitoiset <samuel.pitoiset at gmail.com>
> ---
>  src/gallium/drivers/nouveau/nvc0/nvc0_query.c | 7 +++----
>  1 file changed, 3 insertions(+), 4 deletions(-)
>
> diff --git a/src/gallium/drivers/nouveau/nvc0/nvc0_query.c b/src/gallium/drivers/nouveau/nvc0/nvc0_query.c
> index ec464b5..f21deea 100644
> --- a/src/gallium/drivers/nouveau/nvc0/nvc0_query.c
> +++ b/src/gallium/drivers/nouveau/nvc0/nvc0_query.c
> @@ -1418,7 +1418,7 @@ nvc0_screen_get_driver_query_info(struct pipe_screen *pscreen,
>     if (id < NVC0_QUERY_DRV_STAT_COUNT) {
>        info->name = nvc0_drv_stat_names[id];
>        info->query_type = NVC0_QUERY_DRV_STAT(id);
> -      info->max_value = ~0ULL;
> +      info->max_value = 0;
>        info->uses_byte_units = !!strstr(info->name, "bytes");
>        return 1;
>     } else
> @@ -1427,15 +1427,14 @@ nvc0_screen_get_driver_query_info(struct pipe_screen *pscreen,
>        if (screen->base.class_3d >= NVE4_3D_CLASS) {
>           info->name = nve4_pm_query_names[id - NVC0_QUERY_DRV_STAT_COUNT];
>           info->query_type = NVE4_PM_QUERY(id - NVC0_QUERY_DRV_STAT_COUNT);
> -         info->max_value = (id < NVE4_PM_QUERY_METRIC_MP_OCCUPANCY) ?
> -            ~0ULL : 100;
> +         info->max_value = (id < NVE4_PM_QUERY_METRIC_MP_OCCUPANCY) ? 0 : 100;
>           info->uses_byte_units = FALSE;
>           return 1;
>        } else
>        if (screen->compute) {
>           info->name = nvc0_pm_query_names[id - NVC0_QUERY_DRV_STAT_COUNT];
>           info->query_type = NVC0_PM_QUERY(id - NVC0_QUERY_DRV_STAT_COUNT);
> -         info->max_value = ~0ULL;
> +         info->max_value = 0;
>           info->uses_byte_units = FALSE;
>           return 1;
>        }
> --
> 2.3.1
>


More information about the mesa-dev mailing list