[Mesa-dev] [PATCH] radeonsi: Fix anisotropic filtering state setup

Alex Deucher alexdeucher at gmail.com
Wed May 14 06:49:47 PDT 2014


On Wed, May 14, 2014 at 3:32 AM, Michel Dänzer <michel at daenzer.net> wrote:
> From: Michel Dänzer <michel.daenzer at amd.com>
>
> Bring it back in line with r600g. I broke this in the original radeonsi
> bringup. :(
>
> Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=78537
> Signed-off-by: Michel Dänzer <michel.daenzer at amd.com>

CC stable?

Reviewed-by: Alex Deucher <alexander.deucher at amd.com>

> ---
>  src/gallium/drivers/r600/r600_pipe.h          | 9 ---------
>  src/gallium/drivers/radeon/r600_pipe_common.h | 9 +++++++++
>  src/gallium/drivers/radeonsi/si_state.c       | 7 +++----
>  3 files changed, 12 insertions(+), 13 deletions(-)
>
> diff --git a/src/gallium/drivers/r600/r600_pipe.h b/src/gallium/drivers/r600/r600_pipe.h
> index 952b6bd..4120359 100644
> --- a/src/gallium/drivers/r600/r600_pipe.h
> +++ b/src/gallium/drivers/r600/r600_pipe.h
> @@ -829,15 +829,6 @@ static INLINE uint32_t S_FIXED(float value, uint32_t frac_bits)
>  }
>  #define ALIGN_DIVUP(x, y) (((x) + (y) - 1) / (y))
>
> -static inline unsigned r600_tex_aniso_filter(unsigned filter)
> -{
> -       if (filter <= 1)   return 0;
> -       if (filter <= 2)   return 1;
> -       if (filter <= 4)   return 2;
> -       if (filter <= 8)   return 3;
> -        /* else */        return 4;
> -}
> -
>  /* 12.4 fixed-point */
>  static INLINE unsigned r600_pack_float_12p4(float x)
>  {
> diff --git a/src/gallium/drivers/radeon/r600_pipe_common.h b/src/gallium/drivers/radeon/r600_pipe_common.h
> index ada124f..bbfcdf9 100644
> --- a/src/gallium/drivers/radeon/r600_pipe_common.h
> +++ b/src/gallium/drivers/radeon/r600_pipe_common.h
> @@ -489,6 +489,15 @@ r600_resource_reference(struct r600_resource **ptr, struct r600_resource *res)
>                                 (struct pipe_resource *)res);
>  }
>
> +static inline unsigned r600_tex_aniso_filter(unsigned filter)
> +{
> +       if (filter <= 1)   return 0;
> +       if (filter <= 2)   return 1;
> +       if (filter <= 4)   return 2;
> +       if (filter <= 8)   return 3;
> +        /* else */        return 4;
> +}
> +
>  #define R600_ERR(fmt, args...) \
>         fprintf(stderr, "EE %s:%d %s - "fmt, __FILE__, __LINE__, __func__, ##args)
>
> diff --git a/src/gallium/drivers/radeonsi/si_state.c b/src/gallium/drivers/radeonsi/si_state.c
> index a98be24..e3b72c2 100644
> --- a/src/gallium/drivers/radeonsi/si_state.c
> +++ b/src/gallium/drivers/radeonsi/si_state.c
> @@ -2601,16 +2601,15 @@ static void *si_create_sampler_state(struct pipe_context *ctx,
>         rstate->val[0] = (S_008F30_CLAMP_X(si_tex_wrap(state->wrap_s)) |
>                           S_008F30_CLAMP_Y(si_tex_wrap(state->wrap_t)) |
>                           S_008F30_CLAMP_Z(si_tex_wrap(state->wrap_r)) |
> -                         (state->max_anisotropy & 0x7) << 9 | /* XXX */
> +                         r600_tex_aniso_filter(state->max_anisotropy) << 9 |
>                           S_008F30_DEPTH_COMPARE_FUNC(si_tex_compare(state->compare_func)) |
>                           S_008F30_FORCE_UNNORMALIZED(!state->normalized_coords) |
> -                         aniso_flag_offset << 16 | /* XXX */
>                           S_008F30_DISABLE_CUBE_WRAP(!state->seamless_cube_map));
>         rstate->val[1] = (S_008F34_MIN_LOD(S_FIXED(CLAMP(state->min_lod, 0, 15), 8)) |
>                           S_008F34_MAX_LOD(S_FIXED(CLAMP(state->max_lod, 0, 15), 8)));
>         rstate->val[2] = (S_008F38_LOD_BIAS(S_FIXED(CLAMP(state->lod_bias, -16, 16), 8)) |
> -                         S_008F38_XY_MAG_FILTER(si_tex_filter(state->mag_img_filter)) |
> -                         S_008F38_XY_MIN_FILTER(si_tex_filter(state->min_img_filter)) |
> +                         S_008F38_XY_MAG_FILTER(si_tex_filter(state->mag_img_filter) | aniso_flag_offset) |
> +                         S_008F38_XY_MIN_FILTER(si_tex_filter(state->min_img_filter) | aniso_flag_offset) |
>                           S_008F38_MIP_FILTER(si_tex_mipfilter(state->min_mip_filter)));
>         rstate->val[3] = S_008F3C_BORDER_COLOR_TYPE(border_color_type);
>
> --
> 2.0.0.rc0
>
> _______________________________________________
> 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