From: Jernej Skrabec <[email protected]>

YUV formats need scaler support due to chroma upscaling, but that's not
yet supported in the driver. Remove them from supported list until
DE33 scaler is properly supported.

Reviewed-by: Chen-Yu Tsai <[email protected]>
Signed-off-by: Jernej Skrabec <[email protected]>
---
Changes from v1:
- collected tag
- generalize check to be dependant on scaler feature

 drivers/gpu/drm/sun4i/sun8i_vi_layer.c | 40 ++++++++++++++++++++++++--
 1 file changed, 38 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/sun4i/sun8i_vi_layer.c 
b/drivers/gpu/drm/sun4i/sun8i_vi_layer.c
index cd8d6c2da0c7..afbd41a18a0e 100644
--- a/drivers/gpu/drm/sun4i/sun8i_vi_layer.c
+++ b/drivers/gpu/drm/sun4i/sun8i_vi_layer.c
@@ -380,6 +380,33 @@ static const u32 sun8i_vi_layer_de3_formats[] = {
        DRM_FORMAT_YVU422,
 };
 
+static const u32 sun8i_vi_layer_de3_no_yuv_formats[] = {
+       DRM_FORMAT_ABGR1555,
+       DRM_FORMAT_ABGR2101010,
+       DRM_FORMAT_ABGR4444,
+       DRM_FORMAT_ABGR8888,
+       DRM_FORMAT_ARGB1555,
+       DRM_FORMAT_ARGB2101010,
+       DRM_FORMAT_ARGB4444,
+       DRM_FORMAT_ARGB8888,
+       DRM_FORMAT_BGR565,
+       DRM_FORMAT_BGR888,
+       DRM_FORMAT_BGRA1010102,
+       DRM_FORMAT_BGRA5551,
+       DRM_FORMAT_BGRA4444,
+       DRM_FORMAT_BGRA8888,
+       DRM_FORMAT_BGRX8888,
+       DRM_FORMAT_RGB565,
+       DRM_FORMAT_RGB888,
+       DRM_FORMAT_RGBA1010102,
+       DRM_FORMAT_RGBA4444,
+       DRM_FORMAT_RGBA5551,
+       DRM_FORMAT_RGBA8888,
+       DRM_FORMAT_RGBX8888,
+       DRM_FORMAT_XBGR8888,
+       DRM_FORMAT_XRGB8888,
+};
+
 static const uint64_t sun8i_layer_modifiers[] = {
        DRM_FORMAT_MOD_LINEAR,
        DRM_FORMAT_MOD_INVALID
@@ -410,8 +437,17 @@ struct sun8i_layer *sun8i_vi_layer_init_one(struct 
drm_device *drm,
        layer->cfg = cfg;
 
        if (layer->cfg->de_type >= SUN8I_MIXER_DE3) {
-               formats = sun8i_vi_layer_de3_formats;
-               format_count = ARRAY_SIZE(sun8i_vi_layer_de3_formats);
+               /*
+                * TODO: DE33 drivers doesn't support scaling yet, which is a
+                * requirement for YUV support.
+                */
+               if (layer->cfg->scaler_mask & BIT(phy_index)) {
+                       formats = sun8i_vi_layer_de3_formats;
+                       format_count = ARRAY_SIZE(sun8i_vi_layer_de3_formats);
+               } else {
+                       formats = sun8i_vi_layer_de3_no_yuv_formats;
+                       format_count = 
ARRAY_SIZE(sun8i_vi_layer_de3_no_yuv_formats);
+               }
        } else {
                formats = sun8i_vi_layer_formats;
                format_count = ARRAY_SIZE(sun8i_vi_layer_formats);
-- 
2.54.0

Reply via email to