[Mesa-dev] [PATCH] st/mesa: use surface format to generate mipmaps when available

Marek Olšák maraeo at gmail.com
Thu Jan 14 11:38:38 PST 2016


Hi Ilia,

surface_based originally meant that the resource has been imported
from a DMABUF or GEM FLINK handle. Such resources can't be reallocated
ever, nor can they be mipmapped.

Marek

On Thu, Jan 14, 2016 at 7:46 PM, Ilia Mirkin <imirkin at alum.mit.edu> wrote:
> This fixes the recently posted mipmap + texture views piglit test.
>
> Signed-off-by: Ilia Mirkin <imirkin at alum.mit.edu>
> Cc: "11.0 11.1" <mesa-stable at lists.freedesktop.org>
> ---
>  src/mesa/state_tracker/st_gen_mipmap.c | 10 ++++++++--
>  1 file changed, 8 insertions(+), 2 deletions(-)
>
> diff --git a/src/mesa/state_tracker/st_gen_mipmap.c b/src/mesa/state_tracker/st_gen_mipmap.c
> index 3e6c0a7..c4b3492 100644
> --- a/src/mesa/state_tracker/st_gen_mipmap.c
> +++ b/src/mesa/state_tracker/st_gen_mipmap.c
> @@ -80,6 +80,7 @@ st_generate_mipmap(struct gl_context *ctx, GLenum target,
>     struct st_texture_object *stObj = st_texture_object(texObj);
>     struct pipe_resource *pt = st_get_texobj_resource(texObj);
>     const uint baseLevel = texObj->BaseLevel;
> +   enum pipe_format format;
>     uint lastLevel, first_layer, last_layer;
>     uint dstLevel;
>
> @@ -149,16 +150,21 @@ st_generate_mipmap(struct gl_context *ctx, GLenum target,
>        last_layer = util_max_layer(pt, baseLevel);
>     }
>
> +   if (stObj->surface_based)
> +      format = stObj->surface_format;
> +   else
> +      format = pt->format;
> +
>     /* First see if the driver supports hardware mipmap generation,
>      * if not then generate the mipmap by rendering/texturing.
>      * If that fails, use the software fallback.
>      */
>     if (!st->pipe->screen->get_param(st->pipe->screen,
>                                      PIPE_CAP_GENERATE_MIPMAP) ||
> -       !st->pipe->generate_mipmap(st->pipe, pt, pt->format, baseLevel,
> +       !st->pipe->generate_mipmap(st->pipe, pt, format, baseLevel,
>                                    lastLevel, first_layer, last_layer)) {
>
> -      if (!util_gen_mipmap(st->pipe, pt, pt->format, baseLevel, lastLevel,
> +      if (!util_gen_mipmap(st->pipe, pt, format, baseLevel, lastLevel,
>                             first_layer, last_layer, PIPE_TEX_FILTER_LINEAR)) {
>           _mesa_generate_mipmap(ctx, target, texObj);
>        }
> --
> 2.4.10
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/mesa-dev


More information about the mesa-dev mailing list