[Mesa-dev] [PATCH] mesa: Add a helper function for shared code in get_tex_rgba_{un}compressed

Anuj Phogat anuj.phogat at gmail.com
Wed Jun 8 18:15:56 UTC 2016


On Mon, Dec 28, 2015 at 10:46 AM, Anuj Phogat <anuj.phogat at gmail.com> wrote:
> Signed-off-by: Anuj Phogat <anuj.phogat at gmail.com>
> ---
>  src/mesa/main/texgetimage.c | 83 +++++++++++++++++++++------------------------
>  1 file changed, 38 insertions(+), 45 deletions(-)
>
> diff --git a/src/mesa/main/texgetimage.c b/src/mesa/main/texgetimage.c
> index b273aaa..4399803 100644
> --- a/src/mesa/main/texgetimage.c
> +++ b/src/mesa/main/texgetimage.c
> @@ -265,6 +265,40 @@ get_tex_ycbcr(struct gl_context *ctx, GLuint dimensions,
>     }
>  }
>
> +/* Depending on the base format involved we may need to apply a rebase
> + * transform (for example: if we download to a Luminance format we want
> + * G=0 and B=0).
> + */
> +
> +static bool
> +teximage_needs_rebase(mesa_format texFormat, GLenum baseFormat,
> +                      bool is_compressed, uint8_t *rebaseSwizzle)
> +{
> +   bool needsRebase = false;
> +
> +   if (baseFormat == GL_LUMINANCE ||
> +       baseFormat == GL_INTENSITY) {
> +      needsRebase = true;
> +      rebaseSwizzle[0] = MESA_FORMAT_SWIZZLE_X;
> +      rebaseSwizzle[1] = MESA_FORMAT_SWIZZLE_ZERO;
> +      rebaseSwizzle[2] = MESA_FORMAT_SWIZZLE_ZERO;
> +      rebaseSwizzle[3] = MESA_FORMAT_SWIZZLE_ONE;
> +   } else if (baseFormat == GL_LUMINANCE_ALPHA) {
> +      needsRebase = true;
> +      rebaseSwizzle[0] = MESA_FORMAT_SWIZZLE_X;
> +      rebaseSwizzle[1] = MESA_FORMAT_SWIZZLE_ZERO;
> +      rebaseSwizzle[2] = MESA_FORMAT_SWIZZLE_ZERO;
> +      rebaseSwizzle[3] = MESA_FORMAT_SWIZZLE_W;
> +   } else if (!is_compressed && (baseFormat !=
> +               _mesa_get_format_base_format(texFormat))) {
> +      needsRebase =
> +         _mesa_compute_rgba2base2rgba_component_mapping(baseFormat,
> +                                                        rebaseSwizzle);
> +   }
> +
> +   return needsRebase;
> +}
> +
>
>  /**
>   * Get a color texture image with decompression.
> @@ -319,26 +353,8 @@ get_tex_rgba_compressed(struct gl_context *ctx, GLuint dimensions,
>        }
>     }
>
> -   /* Depending on the base format involved we may need to apply a rebase
> -    * transform (for example: if we download to a Luminance format we want
> -    * G=0 and B=0).
> -    */
> -   if (baseFormat == GL_LUMINANCE ||
> -       baseFormat == GL_INTENSITY) {
> -      needsRebase = true;
> -      rebaseSwizzle[0] = MESA_FORMAT_SWIZZLE_X;
> -      rebaseSwizzle[1] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[2] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[3] = MESA_FORMAT_SWIZZLE_ONE;
> -   } else if (baseFormat == GL_LUMINANCE_ALPHA) {
> -      needsRebase = true;
> -      rebaseSwizzle[0] = MESA_FORMAT_SWIZZLE_X;
> -      rebaseSwizzle[1] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[2] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[3] = MESA_FORMAT_SWIZZLE_W;
> -   } else {
> -      needsRebase = false;
> -   }
> +   needsRebase = teximage_needs_rebase(texFormat, baseFormat, true,
> +                                       rebaseSwizzle);
>
>     srcStride = 4 * width * sizeof(GLfloat);
>     dstStride = _mesa_image_row_stride(&ctx->Pack, width, format, type);
> @@ -423,31 +439,8 @@ get_tex_rgba_uncompressed(struct gl_context *ctx, GLuint dimensions,
>     bool needsRebase;
>     void *rgba = NULL;
>
> -   /* Depending on the base format involved we may need to apply a rebase
> -    * transform (for example: if we download to a Luminance format we want
> -    * G=0 and B=0).
> -    */
> -   if (texImage->_BaseFormat == GL_LUMINANCE ||
> -       texImage->_BaseFormat == GL_INTENSITY) {
> -      needsRebase = true;
> -      rebaseSwizzle[0] = MESA_FORMAT_SWIZZLE_X;
> -      rebaseSwizzle[1] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[2] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[3] = MESA_FORMAT_SWIZZLE_ONE;
> -   } else if (texImage->_BaseFormat == GL_LUMINANCE_ALPHA) {
> -      needsRebase = true;
> -      rebaseSwizzle[0] = MESA_FORMAT_SWIZZLE_X;
> -      rebaseSwizzle[1] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[2] = MESA_FORMAT_SWIZZLE_ZERO;
> -      rebaseSwizzle[3] = MESA_FORMAT_SWIZZLE_W;
> -    } else if (texImage->_BaseFormat !=
> -               _mesa_get_format_base_format(texFormat)) {
> -      needsRebase =
> -         _mesa_compute_rgba2base2rgba_component_mapping(texImage->_BaseFormat,
> -                                                        rebaseSwizzle);
> -    } else {
> -      needsRebase = false;
> -    }
> +   needsRebase = teximage_needs_rebase(texFormat, texImage->_BaseFormat, false,
> +                                       rebaseSwizzle);
>
>     /* Describe the dst format */
>     dst_is_integer = _mesa_is_enum_format_integer(format);
> --
> 2.5.0
>

Anyone want to review this old patch? It still applies cleanly on master.


More information about the mesa-dev mailing list