[Mesa-dev] [PATCH 03/10] r600g: transfers of MSAA color textures should do the resolve

Christoph Bumiller e0425955 at student.tuwien.ac.at
Tue Dec 4 03:35:31 PST 2012


On 04.12.2012 01:07, Marek Olšák wrote:
> so that ReadPixels and various fallbacks work.

Err, shouldn't the state tracker do the resolve ? What if someone wants
to read back the individual samples ?

Yes, I know this adds a few complications, like how they are stored for
the transfer (maybe read them with separate transfers ? - yes, slow),
and that you get an extra copy because you won't be able to directly
write to a staging resource, but I really dislike this implicit resolve ...

> ---
>  src/gallium/drivers/r600/r600_texture.c |   37 ++++++++++++++++++++++++++-----
>  1 file changed, 32 insertions(+), 5 deletions(-)
>
> diff --git a/src/gallium/drivers/r600/r600_texture.c b/src/gallium/drivers/r600/r600_texture.c
> index 0054c5b..d6d1b3d 100644
> --- a/src/gallium/drivers/r600/r600_texture.c
> +++ b/src/gallium/drivers/r600/r600_texture.c
> @@ -31,18 +31,38 @@
>  #include "util/u_format_s3tc.h"
>  #include "util/u_memory.h"
>  
> +
>  /* Copy from a full GPU texture to a transfer's staging one. */
>  static void r600_copy_to_staging_texture(struct pipe_context *ctx, struct r600_transfer *rtransfer)
>  {
>  	struct pipe_transfer *transfer = (struct pipe_transfer*)rtransfer;
> -	struct pipe_resource *texture = transfer->resource;
> +	struct pipe_resource *dst = &rtransfer->staging->b.b;
> +	struct pipe_resource *src = transfer->resource;
>  
> -	ctx->resource_copy_region(ctx, &rtransfer->staging->b.b,
> -				0, 0, 0, 0, texture, transfer->level,
> -				&transfer->box);
> +	if (src->nr_samples <= 1) {
> +		ctx->resource_copy_region(ctx, dst, 0, 0, 0, 0,
> +					  src, transfer->level, &transfer->box);
> +	} else {
> +		/* Resolve the resource. */
> +		struct pipe_blit_info blit;
> +
> +		memset(&blit, 0, sizeof(blit));
> +	        blit.src.resource = src;
> +	        blit.src.format = src->format;
> +	        blit.src.level = transfer->level;
> +	        blit.src.box = transfer->box;
> +	        blit.dst.resource = dst;
> +	        blit.dst.format = dst->format;
> +	        blit.dst.box.width = transfer->box.width;
> +	        blit.dst.box.height = transfer->box.height;
> +	        blit.dst.box.depth = transfer->box.depth;
> +	        blit.mask = PIPE_MASK_RGBA;
> +	        blit.filter = PIPE_TEX_FILTER_NEAREST;
> +
> +		ctx->blit(ctx, &blit);
> +	}
>  }
>  
> -
>  /* Copy from a transfer's staging texture to a full GPU one. */
>  static void r600_copy_from_staging_texture(struct pipe_context *ctx, struct r600_transfer *rtransfer)
>  {
> @@ -715,6 +735,13 @@ static void *r600_texture_transfer_map(struct pipe_context *ctx,
>  		*/
>  		struct r600_texture *staging_depth;
>  
> +		assert(rtex->resource.b.b.nr_samples <= 1);
> +		if (rtex->resource.b.b.nr_samples > 1) {
> +			R600_ERR("mapping MSAA zbuffer unimplemented\n");
> +			FREE(trans);
> +			return NULL;
> +		}
> +
>  		if (!r600_init_flushed_depth_texture(ctx, texture, &staging_depth)) {
>  			R600_ERR("failed to create temporary texture to hold untiled copy\n");
>  			FREE(trans);



More information about the mesa-dev mailing list