Commit 00b5497d authored by Thomas Zimmermann's avatar Thomas Zimmermann

drm/simple-kms: Remove drm_gem_simple_display_pipe_prepare_fb()

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: default avatarThomas Zimmermann <tzimmermann@suse.de>
Reviewed-by: default avatarNoralf Trønnes <noralf@tronnes.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20221202125644.7917-2-tzimmermann@suse.de
parent 0870d86e
...@@ -26,11 +26,8 @@ ...@@ -26,11 +26,8 @@
* call drm_gem_plane_helper_prepare_fb() from their implementation of * call drm_gem_plane_helper_prepare_fb() from their implementation of
* struct &drm_plane_helper.prepare_fb . It sets the plane's fence from * struct &drm_plane_helper.prepare_fb . It sets the plane's fence from
* the framebuffer so that the DRM core can synchronize access automatically. * the framebuffer so that the DRM core can synchronize access automatically.
*
* drm_gem_plane_helper_prepare_fb() can also be used directly as * drm_gem_plane_helper_prepare_fb() can also be used directly as
* implementation of prepare_fb. For drivers based on * implementation of prepare_fb.
* struct drm_simple_display_pipe, drm_gem_simple_display_pipe_prepare_fb()
* provides equivalent functionality.
* *
* .. code-block:: c * .. code-block:: c
* *
...@@ -41,11 +38,6 @@ ...@@ -41,11 +38,6 @@
* . prepare_fb = drm_gem_plane_helper_prepare_fb, * . 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 * 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 * into the HW's framebuffer memory during an atomic update. This requires
* a mapping of the shadow buffer into kernel address space. The mappings * a mapping of the shadow buffer into kernel address space. The mappings
...@@ -205,27 +197,6 @@ int drm_gem_plane_helper_prepare_fb(struct drm_plane *plane, ...@@ -205,27 +197,6 @@ int drm_gem_plane_helper_prepare_fb(struct drm_plane *plane,
} }
EXPORT_SYMBOL_GPL(drm_gem_plane_helper_prepare_fb); 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 * Shadow-buffered Planes
*/ */
......
...@@ -267,7 +267,7 @@ static int drm_simple_kms_plane_prepare_fb(struct drm_plane *plane, ...@@ -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); 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); return pipe->funcs->prepare_fb(pipe, state);
......
...@@ -581,7 +581,6 @@ static const struct drm_simple_display_pipe_funcs ili9341_dbi_funcs = { ...@@ -581,7 +581,6 @@ static const struct drm_simple_display_pipe_funcs ili9341_dbi_funcs = {
.enable = ili9341_dbi_enable, .enable = ili9341_dbi_enable,
.disable = mipi_dbi_pipe_disable, .disable = mipi_dbi_pipe_disable,
.update = mipi_dbi_pipe_update, .update = mipi_dbi_pipe_update,
.prepare_fb = drm_gem_simple_display_pipe_prepare_fb,
}; };
static const struct drm_display_mode ili9341_dbi_mode = { static const struct drm_display_mode ili9341_dbi_mode = {
......
...@@ -104,7 +104,6 @@ static const struct drm_simple_display_pipe_funcs ili9163_pipe_funcs = { ...@@ -104,7 +104,6 @@ static const struct drm_simple_display_pipe_funcs ili9163_pipe_funcs = {
.enable = yx240qv29_enable, .enable = yx240qv29_enable,
.disable = mipi_dbi_pipe_disable, .disable = mipi_dbi_pipe_disable,
.update = mipi_dbi_pipe_update, .update = mipi_dbi_pipe_update,
.prepare_fb = drm_gem_simple_display_pipe_prepare_fb,
}; };
static const struct drm_display_mode yx240qv29_mode = { static const struct drm_display_mode yx240qv29_mode = {
......
...@@ -15,8 +15,6 @@ struct drm_simple_display_pipe; ...@@ -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_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 * Helpers for planes with shadow buffers
......
...@@ -77,8 +77,8 @@ struct drm_plane_state { ...@@ -77,8 +77,8 @@ struct drm_plane_state {
* write this field directly for a driver's implicit fence. * write this field directly for a driver's implicit fence.
* *
* Drivers should store any implicit fence in this from their * Drivers should store any implicit fence in this from their
* &drm_plane_helper_funcs.prepare_fb callback. See drm_gem_plane_helper_prepare_fb() * &drm_plane_helper_funcs.prepare_fb callback. See
* and drm_gem_simple_display_pipe_prepare_fb() for suitable helpers. * drm_gem_plane_helper_prepare_fb() for a suitable helper.
*/ */
struct dma_fence *fence; struct dma_fence *fence;
......
...@@ -117,9 +117,9 @@ struct drm_simple_display_pipe_funcs { ...@@ -117,9 +117,9 @@ struct drm_simple_display_pipe_funcs {
* more details. * more details.
* *
* For GEM drivers who neither have a @prepare_fb nor @cleanup_fb hook * 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 * 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. * their @prepare_fb hook.
*/ */
int (*prepare_fb)(struct drm_simple_display_pipe *pipe, int (*prepare_fb)(struct drm_simple_display_pipe *pipe,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment