drm/simple-kms: Remove drm_gem_simple_display_pipe_prepare_fb()
authorThomas Zimmermann <tzimmermann@suse.de>
Fri, 2 Dec 2022 12:56:37 +0000 (13:56 +0100)
committerThomas Zimmermann <tzimmermann@suse.de>
Mon, 5 Dec 2022 12:35:37 +0000 (13:35 +0100)
The helper drm_gem_simple_display_pipe_prepare_fb() is simple-KMS'
default implementation for prepare_fb. Remove the call from drivers
that set it explicitly. Then inline the helper into the only caller
within simple-kms helpers. No functional changes.

Simple-KMS drivers that implement the prepare_fb callback should call
drm_gem_plane_helper_prepare_fb() directly.

v2:
* fix typo in commit message

Signed-off-by: Thomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: Noralf Trønnes <noralf@tronnes.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20221202125644.7917-2-tzimmermann@suse.de
drivers/gpu/drm/drm_gem_atomic_helper.c
drivers/gpu/drm/drm_simple_kms_helper.c
drivers/gpu/drm/panel/panel-ilitek-ili9341.c
drivers/gpu/drm/tiny/ili9163.c
include/drm/drm_gem_atomic_helper.h
include/drm/drm_plane.h
include/drm/drm_simple_kms_helper.h

index e428007..5d4b9cd 100644 (file)
  * call drm_gem_plane_helper_prepare_fb() from their implementation of
  * struct &drm_plane_helper.prepare_fb . It sets the plane's fence from
  * the framebuffer so that the DRM core can synchronize access automatically.
- *
  * drm_gem_plane_helper_prepare_fb() can also be used directly as
- * implementation of prepare_fb. For drivers based on
- * struct drm_simple_display_pipe, drm_gem_simple_display_pipe_prepare_fb()
- * provides equivalent functionality.
+ * implementation of prepare_fb.
  *
  * .. code-block:: c
  *
  *             . prepare_fb = drm_gem_plane_helper_prepare_fb,
  *     };
  *
- *     struct drm_simple_display_pipe_funcs driver_pipe_funcs = {
- *             ...,
- *             . prepare_fb = drm_gem_simple_display_pipe_prepare_fb,
- *     };
- *
  * A driver using a shadow buffer copies the content of the shadow buffers
  * into the HW's framebuffer memory during an atomic update. This requires
  * a mapping of the shadow buffer into kernel address space. The mappings
@@ -205,27 +197,6 @@ error:
 }
 EXPORT_SYMBOL_GPL(drm_gem_plane_helper_prepare_fb);
 
-/**
- * drm_gem_simple_display_pipe_prepare_fb - prepare_fb helper for &drm_simple_display_pipe
- * @pipe: Simple display pipe
- * @plane_state: Plane state
- *
- * This function uses drm_gem_plane_helper_prepare_fb() to extract the fences
- * from &drm_gem_object.resv and attaches them to the plane state for the atomic
- * helper to wait on. This is necessary to correctly implement implicit
- * synchronization for any buffers shared as a struct &dma_buf. Drivers can use
- * this as their &drm_simple_display_pipe_funcs.prepare_fb callback.
- *
- * See drm_gem_plane_helper_prepare_fb() for a discussion of implicit and
- * explicit fencing in atomic modeset updates.
- */
-int drm_gem_simple_display_pipe_prepare_fb(struct drm_simple_display_pipe *pipe,
-                                          struct drm_plane_state *plane_state)
-{
-       return drm_gem_plane_helper_prepare_fb(&pipe->plane, plane_state);
-}
-EXPORT_SYMBOL(drm_gem_simple_display_pipe_prepare_fb);
-
 /*
  * Shadow-buffered Planes
  */
index 3ef420e..270523a 100644 (file)
@@ -267,7 +267,7 @@ static int drm_simple_kms_plane_prepare_fb(struct drm_plane *plane,
 
                WARN_ON_ONCE(pipe->funcs && pipe->funcs->cleanup_fb);
 
-               return drm_gem_simple_display_pipe_prepare_fb(pipe, state);
+               return drm_gem_plane_helper_prepare_fb(plane, state);
        }
 
        return pipe->funcs->prepare_fb(pipe, state);
index 384a724..be08898 100644 (file)
@@ -581,7 +581,6 @@ static const struct drm_simple_display_pipe_funcs ili9341_dbi_funcs = {
        .enable = ili9341_dbi_enable,
        .disable = mipi_dbi_pipe_disable,
        .update = mipi_dbi_pipe_update,
-       .prepare_fb = drm_gem_simple_display_pipe_prepare_fb,
 };
 
 static const struct drm_display_mode ili9341_dbi_mode = {
index ca0451f..835ed12 100644 (file)
@@ -104,7 +104,6 @@ static const struct drm_simple_display_pipe_funcs ili9163_pipe_funcs = {
        .enable = yx240qv29_enable,
        .disable = mipi_dbi_pipe_disable,
        .update = mipi_dbi_pipe_update,
-       .prepare_fb = drm_gem_simple_display_pipe_prepare_fb,
 };
 
 static const struct drm_display_mode yx240qv29_mode = {
index 6970ccb..40b8b03 100644 (file)
@@ -15,8 +15,6 @@ struct drm_simple_display_pipe;
  */
 
 int drm_gem_plane_helper_prepare_fb(struct drm_plane *plane, struct drm_plane_state *state);
-int drm_gem_simple_display_pipe_prepare_fb(struct drm_simple_display_pipe *pipe,
-                                          struct drm_plane_state *plane_state);
 
 /*
  * Helpers for planes with shadow buffers
index 447e664..5129198 100644 (file)
@@ -77,8 +77,8 @@ struct drm_plane_state {
         * write this field directly for a driver's implicit fence.
         *
         * Drivers should store any implicit fence in this from their
-        * &drm_plane_helper_funcs.prepare_fb callback. See drm_gem_plane_helper_prepare_fb()
-        * and drm_gem_simple_display_pipe_prepare_fb() for suitable helpers.
+        * &drm_plane_helper_funcs.prepare_fb callback. See
+        * drm_gem_plane_helper_prepare_fb() for a suitable helper.
         */
        struct dma_fence *fence;
 
index 2298fe3..b2486d0 100644 (file)
@@ -117,9 +117,9 @@ struct drm_simple_display_pipe_funcs {
         * more details.
         *
         * For GEM drivers who neither have a @prepare_fb nor @cleanup_fb hook
-        * set drm_gem_simple_display_pipe_prepare_fb() is called automatically
+        * set, drm_gem_plane_helper_prepare_fb() is called automatically
         * to implement this. Other drivers which need additional plane
-        * processing can call drm_gem_simple_display_pipe_prepare_fb() from
+        * processing can call drm_gem_plane_helper_prepare_fb() from
         * their @prepare_fb hook.
         */
        int (*prepare_fb)(struct drm_simple_display_pipe *pipe,