return NULL;
 }
 
+static int sun4i_crtc_atomic_check(struct drm_crtc *crtc,
+                                   struct drm_crtc_state *state)
+{
+       struct sun4i_crtc *scrtc = drm_crtc_to_sun4i_crtc(crtc);
+       struct sunxi_engine *engine = scrtc->engine;
+       int ret = 0;
+
+       if (engine && engine->ops && engine->ops->atomic_check)
+               ret = engine->ops->atomic_check(engine, state);
+
+       return ret;
+}
+
 static void sun4i_crtc_atomic_begin(struct drm_crtc *crtc,
                                    struct drm_crtc_state *old_state)
 {
 }
 
 static const struct drm_crtc_helper_funcs sun4i_crtc_helper_funcs = {
+       .atomic_check   = sun4i_crtc_atomic_check,
        .atomic_begin   = sun4i_crtc_atomic_begin,
        .atomic_flush   = sun4i_crtc_atomic_flush,
        .atomic_enable  = sun4i_crtc_atomic_enable,
 
  * implement the proper behaviour.
  */
 struct sunxi_engine_ops {
+       /**
+        * @atomic_check:
+        *
+        * This callback allows to validate plane-update related CRTC
+        * constraints specific to engines. This is mirroring the
+        * &drm_crtc_helper_funcs.atomic_check callback, so any
+        * documentation there applies.
+        *
+        * This function is optional.
+        *
+        * RETURNS:
+        *
+        * 0 on success or a negative error code.
+        */
+       int (*atomic_check)(struct sunxi_engine *engine,
+                           struct drm_crtc_state *state);
+
        /**
         * @commit:
         *