[PATCH] drm/radeon/kms: allow "invalid" DB formats as a means to disable DB

Marek Olšák maraeo at gmail.com
Mon Jul 30 12:45:01 PDT 2012


After some discussion in private, we've come to the conclusion that
this is a very important fix. So if it's possible:

Cc: stable at kernel.org

Applicable to 3.5 stable kernel only.

Marek

On Sun, Jul 29, 2012 at 4:24 PM, Marek Olšák <maraeo at gmail.com> wrote:
> Signed-off-by: Marek Olšák <maraeo at gmail.com>
> ---
>  drivers/gpu/drm/radeon/evergreen_cs.c |    6 ++++--
>  drivers/gpu/drm/radeon/evergreend.h   |    2 ++
>  drivers/gpu/drm/radeon/r600_cs.c      |    6 ++++--
>  drivers/gpu/drm/radeon/radeon_drv.c   |    3 ++-
>  4 files changed, 12 insertions(+), 5 deletions(-)
>
> diff --git a/drivers/gpu/drm/radeon/evergreen_cs.c b/drivers/gpu/drm/radeon/evergreen_cs.c
> index c1655412..f2e5c54 100644
> --- a/drivers/gpu/drm/radeon/evergreen_cs.c
> +++ b/drivers/gpu/drm/radeon/evergreen_cs.c
> @@ -961,13 +961,15 @@ static int evergreen_cs_track_check(struct radeon_cs_parser *p)
>
>         if (track->db_dirty) {
>                 /* Check stencil buffer */
> -               if (G_028800_STENCIL_ENABLE(track->db_depth_control)) {
> +               if (G_028044_FORMAT(track->db_s_info) != V_028044_STENCIL_INVALID &&
> +                   G_028800_STENCIL_ENABLE(track->db_depth_control)) {
>                         r = evergreen_cs_track_validate_stencil(p);
>                         if (r)
>                                 return r;
>                 }
>                 /* Check depth buffer */
> -               if (G_028800_Z_ENABLE(track->db_depth_control)) {
> +               if (G_028040_FORMAT(track->db_z_info) != V_028040_Z_INVALID &&
> +                   G_028800_Z_ENABLE(track->db_depth_control)) {
>                         r = evergreen_cs_track_validate_depth(p);
>                         if (r)
>                                 return r;
> diff --git a/drivers/gpu/drm/radeon/evergreend.h b/drivers/gpu/drm/radeon/evergreend.h
> index b50b15c..4a43b46 100644
> --- a/drivers/gpu/drm/radeon/evergreend.h
> +++ b/drivers/gpu/drm/radeon/evergreend.h
> @@ -1273,6 +1273,8 @@
>  #define   S_028044_FORMAT(x)                           (((x) & 0x1) << 0)
>  #define   G_028044_FORMAT(x)                           (((x) >> 0) & 0x1)
>  #define   C_028044_FORMAT                              0xFFFFFFFE
> +#define            V_028044_STENCIL_INVALID                    0
> +#define            V_028044_STENCIL_8                          1
>  #define   G_028044_TILE_SPLIT(x)                       (((x) >> 8) & 0x7)
>  #define DB_Z_READ_BASE                                 0x28048
>  #define DB_STENCIL_READ_BASE                           0x2804c
> diff --git a/drivers/gpu/drm/radeon/r600_cs.c b/drivers/gpu/drm/radeon/r600_cs.c
> index ca87f7a..1119e31 100644
> --- a/drivers/gpu/drm/radeon/r600_cs.c
> +++ b/drivers/gpu/drm/radeon/r600_cs.c
> @@ -764,8 +764,10 @@ static int r600_cs_track_check(struct radeon_cs_parser *p)
>         }
>
>         /* Check depth buffer */
> -       if (track->db_dirty && (G_028800_STENCIL_ENABLE(track->db_depth_control) ||
> -               G_028800_Z_ENABLE(track->db_depth_control))) {
> +       if (track->db_dirty &&
> +           G_028010_FORMAT(track->db_depth_info) != V_028010_DEPTH_INVALID &&
> +           (G_028800_STENCIL_ENABLE(track->db_depth_control) ||
> +            G_028800_Z_ENABLE(track->db_depth_control))) {
>                 r = r600_cs_track_validate_db(p);
>                 if (r)
>                         return r;
> diff --git a/drivers/gpu/drm/radeon/radeon_drv.c b/drivers/gpu/drm/radeon/radeon_drv.c
> index 2c4d53f..ed13538 100644
> --- a/drivers/gpu/drm/radeon/radeon_drv.c
> +++ b/drivers/gpu/drm/radeon/radeon_drv.c
> @@ -59,9 +59,10 @@
>   *   2.15.0 - add max_pipes query
>   *   2.16.0 - fix evergreen 2D tiled surface calculation
>   *   2.17.0 - add STRMOUT_BASE_UPDATE for r7xx
> + *   2.18.0 - r600-eg: allow "invalid" DB formats
>   */
>  #define KMS_DRIVER_MAJOR       2
> -#define KMS_DRIVER_MINOR       17
> +#define KMS_DRIVER_MINOR       18
>  #define KMS_DRIVER_PATCHLEVEL  0
>  int radeon_driver_load_kms(struct drm_device *dev, unsigned long flags);
>  int radeon_driver_unload_kms(struct drm_device *dev);
> --
> 1.7.9.5
>


More information about the dri-devel mailing list