r600g: Do colorformat endian swap for PIPE_USAGE_STAGING
authorOded Gabbay <oded.gabbay@gmail.com>
Wed, 2 Mar 2016 19:11:49 +0000 (21:11 +0200)
committerOded Gabbay <oded.gabbay@gmail.com>
Thu, 3 Mar 2016 07:20:08 +0000 (09:20 +0200)
There is an old if statement (dated to 2011) that prevented doing
endian swap for colorformat, in case the buffer is marked
as PIPE_USAGE_STAGING.

This is now wrong because st_ReadPixels() reads into a destination
texture that is marked with PIPE_USAGE_STAGING. Therefore, even if
the texture is rendered correctly to the monitor, when reading it
back we get unswapped/wrong values.

This patch makes the check_rgba() function in gl-1.0-readpixsanity
piglit test pass in big-endian.

v2: removed duplicate call to r600_colorformat_endian_swap() inside
evergreen_init_color_surface_rat()

Signed-off-by: Oded Gabbay <oded.gabbay@gmail.com>
Cc: "11.1 11.2" <mesa-stable@lists.freedesktop.org>
Reviewed-by: Marek Olšák <marek.olsak@amd.com>
src/gallium/drivers/r600/evergreen_state.c
src/gallium/drivers/r600/r600_state.c

index a12638a5bdb0e86a09e0f6a067585c86bb0fd8e3..83313cb28cf977875d2c478cbe0b8ea8bc43cac1 100644 (file)
@@ -989,13 +989,6 @@ void evergreen_init_color_surface_rat(struct r600_context *rctx,
                MAX2(64, rctx->screen->b.info.pipe_interleave_bytes / block_size);
        unsigned pitch = align(pipe_buffer->width0, pitch_alignment);
 
-       /* XXX: This is copied from evergreen_init_color_surface().  I don't
-        * know why this is necessary.
-        */
-       if (pipe_buffer->usage == PIPE_USAGE_STAGING) {
-               endian = ENDIAN_NONE;
-       }
-
        surf->cb_color_base = r600_resource(pipe_buffer)->gpu_address >> 8;
 
        surf->cb_color_pitch = (pitch / 8) - 1;
@@ -1146,11 +1139,7 @@ void evergreen_init_color_surface(struct r600_context *rctx,
        swap = r600_translate_colorswap(surf->base.format);
        assert(swap != ~0);
 
-       if (rtex->resource.b.b.usage == PIPE_USAGE_STAGING) {
-               endian = ENDIAN_NONE;
-       } else {
-               endian = r600_colorformat_endian_swap(format);
-       }
+       endian = r600_colorformat_endian_swap(format);
 
        /* blend clamp should be set for all NORM/SRGB types */
        if (ntype == V_028C70_NUMBER_UNORM || ntype == V_028C70_NUMBER_SNORM ||
index f60e30486a2db9c187c6c318782ee3fcfaa86347..f9026197b2617ccaa793875a09a6efd5819f12b0 100644 (file)
@@ -930,11 +930,7 @@ static void r600_init_color_surface(struct r600_context *rctx,
        swap = r600_translate_colorswap(surf->base.format);
        assert(swap != ~0);
 
-       if (rtex->resource.b.b.usage == PIPE_USAGE_STAGING) {
-               endian = ENDIAN_NONE;
-       } else {
-               endian = r600_colorformat_endian_swap(format);
-       }
+       endian = r600_colorformat_endian_swap(format);
 
        /* set blend bypass according to docs if SINT/UINT or
           8/24 COLOR variants */