Re: [PATCH] drm/i915: Reject NV12 planes with odd width/start position

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Quoting Fritz Koenig (2018-05-17 20:07:14)
> Planes with an odd width will appear to have an incorrect
> stride. When the start position is odd the controller
> can lock up.
> 
> Signed-off-by: Fritz Koenig <frkoenig@xxxxxxxxxx>
> ---
> 
> Hi,
> 
> This appears to be a limitation of the hardware that is not being
> checked. Is this supported and am I not enabling it correctly?
> 
> 
>  drivers/gpu/drm/i915/intel_atomic_plane.c | 15 +++++++++++++++
>  1 file changed, 15 insertions(+)
> 
> diff --git a/drivers/gpu/drm/i915/intel_atomic_plane.c b/drivers/gpu/drm/i915/intel_atomic_plane.c
> index 7481ce85746b..ca4553592ab9 100644
> --- a/drivers/gpu/drm/i915/intel_atomic_plane.c
> +++ b/drivers/gpu/drm/i915/intel_atomic_plane.c
> @@ -188,6 +188,21 @@ int intel_plane_atomic_check_with_state(const struct intel_crtc_state *old_crtc_
>         else
>                 crtc_state->active_planes &= ~BIT(intel_plane->id);
>  
> +       /*
> +        * NV12 plane is not allowed to start from an odd position or
> +        * end on an odd position.
> +        */
> +       if (state->fb && (DRM_FORMAT_NV12 == state->fb->format->format)) {
> +               if ((intel_state->base.src_w >> 16) & 1) {
> +                       DRM_DEBUG_KMS("Invalid Source: Yuv format does not support odd width\n");

It may seem obvious from the message that src_w is odd, but it's always
nice to include as much information as possible for debugging; in this
case "%x", src_w.

if ((intel_state->base.src_w | intel_state->base.src_x) & BIT(16)) ?

I'd leave that question of style to Ville though.
-Chris
_______________________________________________
Intel-gfx mailing list
Intel-gfx@xxxxxxxxxxxxxxxxxxxxx
https://lists.freedesktop.org/mailman/listinfo/intel-gfx




[Index of Archives]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux