]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
drm/ingenic: ipu: Remove YUV422 from supported formats on JZ4725B
authorPaul Cercueil <paul@crapouillou.net>
Thu, 30 Jul 2020 14:48:29 +0000 (16:48 +0200)
committerPaul Cercueil <paul@crapouillou.net>
Thu, 30 Jul 2020 16:19:52 +0000 (18:19 +0200)
When configuring the IPU for packed YUV 4:2:2, depending on the scaling
ratios given by the source and destination resolutions, it is possible
to crash the IPU block, to the point where a software reset of the IP
does not fix it. This can happen anytime, in the first few frames, or
after dozens of minutes. The same crash also happens when the IPU is
fully controlled by the LCD controller (in that case no HW register is
written at any moment after startup), which points towards a hardware
bug.

Thanksfully multiplanar YUV is not affected.

Until this bug is fixed or worked around, address this issue by removing
support for YUV 4:2:2 on the IPU of the JZ4725B.

v2: Update commit message (remove the "crash beyond repair" bit)

Reviewed-by: Sam Ravnborg <sam@ravnborg.org>
Signed-off-by: Paul Cercueil <paul@crapouillou.net>
Link: https://patchwork.freedesktop.org/patch/msgid/20200730144830.10479-3-paul@crapouillou.net
drivers/gpu/drm/ingenic/ingenic-ipu.c

index 7eae56fa92ea2c6b4f33b58c35baa617da8b2f76..7dd2a6ae49946c349b473f4fcc29995d755e4d6f 100644 (file)
@@ -795,10 +795,16 @@ static int ingenic_ipu_remove(struct platform_device *pdev)
 }
 
 static const u32 jz4725b_ipu_formats[] = {
+       /*
+        * While officially supported, packed YUV 4:2:2 formats can cause
+        * random hardware crashes on JZ4725B under certain circumstances.
+        * It seems to happen with some specific resize ratios.
+        * Until a proper workaround or fix is found, disable these formats.
        DRM_FORMAT_YUYV,
        DRM_FORMAT_YVYU,
        DRM_FORMAT_UYVY,
        DRM_FORMAT_VYUY,
+       */
        DRM_FORMAT_YUV411,
        DRM_FORMAT_YUV420,
        DRM_FORMAT_YUV422,