mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 10:45:49 +00:00
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: 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
This commit is contained in:
parent
0870d86eac
commit
00b5497d64
@ -26,11 +26,8 @@
|
||||
* 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
|
||||
*
|
||||
@ -41,11 +38,6 @@
|
||||
* . 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 @@ int drm_gem_plane_helper_prepare_fb(struct drm_plane *plane,
|
||||
}
|
||||
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
|
||||
*/
|
||||
|
@ -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);
|
||||
|
@ -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 = {
|
||||
|
@ -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 = {
|
||||
|
@ -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
|
||||
|
@ -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;
|
||||
|
||||
|
@ -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,
|
||||
|
Loading…
Reference in New Issue
Block a user