OSDN Git Service

drm/plane-helper: Warn if atomic drivers call non-atomic helpers
authorThomas Zimmermann <tzimmermann@suse.de>
Fri, 9 Sep 2022 10:59:46 +0000 (12:59 +0200)
committerThomas Zimmermann <tzimmermann@suse.de>
Tue, 20 Sep 2022 07:42:31 +0000 (09:42 +0200)
The plane update and disable helpers are only useful for non-atomic
drivers. Print a warning if an atomic driver calls them.

Suggested-by: Daniel Vetter <daniel@ffwll.ch>
Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Javier Martinez Canillas <javierm@redhat.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220909105947.6487-4-tzimmermann@suse.de
drivers/gpu/drm/drm_plane_helper.c

index db04d9a..865bd99 100644 (file)
 #include <drm/drm_atomic_uapi.h>
 #include <drm/drm_crtc_helper.h>
 #include <drm/drm_device.h>
+#include <drm/drm_drv.h>
 #include <drm/drm_encoder.h>
 #include <drm/drm_plane_helper.h>
+#include <drm/drm_print.h>
 #include <drm/drm_rect.h>
 
 #define SUBPIXEL_MASK 0xffff
@@ -195,10 +197,14 @@ int drm_plane_helper_update_primary(struct drm_plane *plane, struct drm_crtc *cr
                .x2 = crtc_x + crtc_w,
                .y2 = crtc_y + crtc_h,
        };
+       struct drm_device *dev = plane->dev;
        struct drm_connector **connector_list;
        int num_connectors, ret;
        bool visible;
 
+       if (drm_WARN_ON_ONCE(dev, drm_drv_uses_atomic_modeset(dev)))
+               return -EINVAL;
+
        ret = drm_plane_helper_check_update(plane, crtc, fb,
                                            &src, &dest,
                                            DRM_MODE_ROTATE_0,
@@ -260,6 +266,10 @@ EXPORT_SYMBOL(drm_plane_helper_update_primary);
 int drm_plane_helper_disable_primary(struct drm_plane *plane,
                                     struct drm_modeset_acquire_ctx *ctx)
 {
+       struct drm_device *dev = plane->dev;
+
+       drm_WARN_ON_ONCE(dev, drm_drv_uses_atomic_modeset(dev));
+
        return -EINVAL;
 }
 EXPORT_SYMBOL(drm_plane_helper_disable_primary);