[Mesa-dev] [PATCH V3 03/30] swrast: Add support for fetching from MESA_FORMAT_R10G10B10A2_UNORM

Brian Paul brianp at vmware.com
Wed Apr 2 07:29:51 PDT 2014


On 04/02/2014 02:04 AM, Chris Forbes wrote:
> Signed-off-by: Chris Forbes <chrisf at ijw.co.nz>
> ---
>   src/mesa/swrast/s_texfetch.c     |  6 +++---
>   src/mesa/swrast/s_texfetch_tmp.h | 16 ++++++++++++++++
>   2 files changed, 19 insertions(+), 3 deletions(-)
>
> diff --git a/src/mesa/swrast/s_texfetch.c b/src/mesa/swrast/s_texfetch.c
> index cd09827..4084bbd 100644
> --- a/src/mesa/swrast/s_texfetch.c
> +++ b/src/mesa/swrast/s_texfetch.c
> @@ -325,9 +325,9 @@ texfetch_funcs[] =
>      },
>      {
>         MESA_FORMAT_R10G10B10A2_UNORM,
> -      NULL,
> -      NULL,
> -      NULL
> +      fetch_texel_1d_f_rgba1010102,
> +      fetch_texel_2d_f_rgba1010102,
> +      fetch_texel_3d_f_rgba1010102
>      },
>      {
>         MESA_FORMAT_S8_UINT_Z24_UNORM,
> diff --git a/src/mesa/swrast/s_texfetch_tmp.h b/src/mesa/swrast/s_texfetch_tmp.h
> index f749b49..39e55c5 100644
> --- a/src/mesa/swrast/s_texfetch_tmp.h
> +++ b/src/mesa/swrast/s_texfetch_tmp.h
> @@ -685,6 +685,22 @@ static void FETCH(f_argb2101010)( const struct swrast_texture_image *texImage,
>
>
>
> +/* MESA_FORMAT_R10G10B10A2_UNORM ***************************************************/
> +
> +/* Fetch texel from 1D, 2D or 3D argb2101010 texture, return 4 GLchans */
> +static void FETCH(f_rgba1010102)( const struct swrast_texture_image *texImage,
> +                                  GLint i, GLint j, GLint k, GLfloat *texel )
> +{
> +   const GLuint *src = TEXEL_ADDR(GLuint, texImage, i, j, k, 1);
> +   const GLuint s = *src;
> +   texel[RCOMP] = ((s >> 00) & 0x3ff) * (1.0F / 1023.0F);
> +   texel[GCOMP] = ((s >> 10) & 0x3ff) * (1.0F / 1023.0F);
> +   texel[BCOMP] = ((s >> 20) & 0x3ff) * (1.0F / 1023.0F);
> +   texel[ACOMP] = ((s >> 30) & 0x03) * (1.0F / 3.0F);
> +}
> +
> +
> +
>
>   /* MESA_FORMAT_R8G8_UNORM **********************************************************/
>
>

I'd like to eventually rename all the functions in that file to be 
consistent with the format names.  So, how about renaming that function 
to "R10G10B10A2_UNORM" (dropping the "f_" too)?

Other than that,
Reviewed-by: Brian Paul <brianp at vmware.com>




More information about the mesa-dev mailing list