OMAP2 and OMAP3/AM4 have limitations with the scaler:
- OMAP2 can only scale XRGB8888
- OMAP3/AM4 can only scale XRGB8888, RGB565, YUYV and UYVY

The driver doesn't check these limitations, which leads to sync-lost
floods.

This patch adds a check for the pixel formats when scaling.

Signed-off-by: Tomi Valkeinen <tomi.valkei...@ti.com>
---
 drivers/gpu/drm/omapdrm/dss/dispc.c | 25 +++++++++++++++++++++++++
 1 file changed, 25 insertions(+)

diff --git a/drivers/gpu/drm/omapdrm/dss/dispc.c 
b/drivers/gpu/drm/omapdrm/dss/dispc.c
index c6da33e7014f..7d87d60edb80 100644
--- a/drivers/gpu/drm/omapdrm/dss/dispc.c
+++ b/drivers/gpu/drm/omapdrm/dss/dispc.c
@@ -114,6 +114,7 @@ struct dispc_features {
        const unsigned int num_reg_fields;
        const enum omap_overlay_caps *overlay_caps;
        const u32 **supported_color_modes;
+       const u32 *supported_scaler_color_modes;
        unsigned int num_mgrs;
        unsigned int num_ovls;
        unsigned int buffer_size_unit;
@@ -2498,6 +2499,19 @@ static int dispc_ovl_calc_scaling(struct dispc_device 
*dispc,
        if (width == out_width && height == out_height)
                return 0;
 
+       if (dispc->feat->supported_scaler_color_modes) {
+               const u32 *modes = dispc->feat->supported_scaler_color_modes;
+               int i;
+
+               for (i = 0; modes[i]; ++i) {
+                       if (modes[i] == fourcc)
+                               break;
+               }
+
+               if (modes[i] == 0)
+                       return -EINVAL;
+       }
+
        if (plane == OMAP_DSS_WB) {
                switch (fourcc) {
                case DRM_FORMAT_NV12:
@@ -4213,6 +4227,12 @@ static const u32 *omap4_dispc_supported_color_modes[] = {
        DRM_FORMAT_RGBX8888),
 };
 
+static const u32 omap3_dispc_supported_scaler_color_modes[] = {
+       DRM_FORMAT_XRGB8888, DRM_FORMAT_RGB565, DRM_FORMAT_YUYV,
+       DRM_FORMAT_UYVY,
+       0,
+};
+
 static const struct dispc_features omap24xx_dispc_feats = {
        .sw_start               =       5,
        .fp_start               =       15,
@@ -4241,6 +4261,7 @@ static const struct dispc_features omap24xx_dispc_feats = 
{
        .num_reg_fields         =       ARRAY_SIZE(omap2_dispc_reg_fields),
        .overlay_caps           =       omap2_dispc_overlay_caps,
        .supported_color_modes  =       omap2_dispc_supported_color_modes,
+       .supported_scaler_color_modes = COLOR_ARRAY(DRM_FORMAT_XRGB8888),
        .num_mgrs               =       2,
        .num_ovls               =       3,
        .buffer_size_unit       =       1,
@@ -4275,6 +4296,7 @@ static const struct dispc_features 
omap34xx_rev1_0_dispc_feats = {
        .num_reg_fields         =       ARRAY_SIZE(omap3_dispc_reg_fields),
        .overlay_caps           =       omap3430_dispc_overlay_caps,
        .supported_color_modes  =       omap3_dispc_supported_color_modes,
+       .supported_scaler_color_modes = 
omap3_dispc_supported_scaler_color_modes,
        .num_mgrs               =       2,
        .num_ovls               =       3,
        .buffer_size_unit       =       1,
@@ -4309,6 +4331,7 @@ static const struct dispc_features 
omap34xx_rev3_0_dispc_feats = {
        .num_reg_fields         =       ARRAY_SIZE(omap3_dispc_reg_fields),
        .overlay_caps           =       omap3430_dispc_overlay_caps,
        .supported_color_modes  =       omap3_dispc_supported_color_modes,
+       .supported_scaler_color_modes = 
omap3_dispc_supported_scaler_color_modes,
        .num_mgrs               =       2,
        .num_ovls               =       3,
        .buffer_size_unit       =       1,
@@ -4343,6 +4366,7 @@ static const struct dispc_features omap36xx_dispc_feats = 
{
        .num_reg_fields         =       ARRAY_SIZE(omap3_dispc_reg_fields),
        .overlay_caps           =       omap3630_dispc_overlay_caps,
        .supported_color_modes  =       omap3_dispc_supported_color_modes,
+       .supported_scaler_color_modes = 
omap3_dispc_supported_scaler_color_modes,
        .num_mgrs               =       2,
        .num_ovls               =       3,
        .buffer_size_unit       =       1,
@@ -4377,6 +4401,7 @@ static const struct dispc_features am43xx_dispc_feats = {
        .num_reg_fields         =       ARRAY_SIZE(omap3_dispc_reg_fields),
        .overlay_caps           =       omap3430_dispc_overlay_caps,
        .supported_color_modes  =       omap3_dispc_supported_color_modes,
+       .supported_scaler_color_modes = 
omap3_dispc_supported_scaler_color_modes,
        .num_mgrs               =       1,
        .num_ovls               =       3,
        .buffer_size_unit       =       1,
-- 
Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki.
Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki

_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to