mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-07 13:53:24 +00:00
drm/atomic-helper: Rename commmit_post/pre_planes
These names only make sense because of backwards compatability with the order used by the crtc helper library. There's not really any real requirement in the ordering here. So rename them to something more descriptive and update the kerneldoc a bit. Motivated in a discussion with Laurent about how to restore plane state for dpms for drivers with runtime pm. v2: Squash in fixup from Stephen Rothwell to fix a conflict with tegra. Cc: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> Reviewed-by: Rob Clark <robdclark@gmail.com> Acked-by: Laurent Pinchart <laurent.pinchart+renesas@ideasonboard.com> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
This commit is contained in:
parent
a072f809b6
commit
1af434a928
@ -768,34 +768,44 @@ crtc_set_mode(struct drm_device *dev, struct drm_atomic_state *old_state)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* drm_atomic_helper_commit_pre_planes - modeset commit before plane updates
|
* drm_atomic_helper_commit_modeset_disables - modeset commit to disable outputs
|
||||||
* @dev: DRM device
|
* @dev: DRM device
|
||||||
* @old_state: atomic state object with old state structures
|
* @old_state: atomic state object with old state structures
|
||||||
*
|
*
|
||||||
* This function commits the modeset changes that need to be committed before
|
* This function shuts down all the outputs that need to be shut down and
|
||||||
* updating planes. It shuts down all the outputs that need to be shut down and
|
|
||||||
* prepares them (if required) with the new mode.
|
* prepares them (if required) with the new mode.
|
||||||
|
*
|
||||||
|
* For compatability with legacy crtc helpers this should be called before
|
||||||
|
* drm_atomic_helper_commit_planes(), which is what the default commit function
|
||||||
|
* does. But drivers with different needs can group the modeset commits together
|
||||||
|
* and do the plane commits at the end. This is useful for drivers doing runtime
|
||||||
|
* PM since planes updates then only happen when the CRTC is actually enabled.
|
||||||
*/
|
*/
|
||||||
void drm_atomic_helper_commit_pre_planes(struct drm_device *dev,
|
void drm_atomic_helper_commit_modeset_disables(struct drm_device *dev,
|
||||||
struct drm_atomic_state *old_state)
|
struct drm_atomic_state *old_state)
|
||||||
{
|
{
|
||||||
disable_outputs(dev, old_state);
|
disable_outputs(dev, old_state);
|
||||||
set_routing_links(dev, old_state);
|
set_routing_links(dev, old_state);
|
||||||
crtc_set_mode(dev, old_state);
|
crtc_set_mode(dev, old_state);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_atomic_helper_commit_pre_planes);
|
EXPORT_SYMBOL(drm_atomic_helper_commit_modeset_disables);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* drm_atomic_helper_commit_post_planes - modeset commit after plane updates
|
* drm_atomic_helper_commit_modeset_enables - modeset commit to enable outputs
|
||||||
* @dev: DRM device
|
* @dev: DRM device
|
||||||
* @old_state: atomic state object with old state structures
|
* @old_state: atomic state object with old state structures
|
||||||
*
|
*
|
||||||
* This function commits the modeset changes that need to be committed after
|
* This function enables all the outputs with the new configuration which had to
|
||||||
* updating planes: It enables all the outputs with the new configuration which
|
* be turned off for the update.
|
||||||
* had to be turned off for the update.
|
*
|
||||||
|
* For compatability with legacy crtc helpers this should be called after
|
||||||
|
* drm_atomic_helper_commit_planes(), which is what the default commit function
|
||||||
|
* does. But drivers with different needs can group the modeset commits together
|
||||||
|
* and do the plane commits at the end. This is useful for drivers doing runtime
|
||||||
|
* PM since planes updates then only happen when the CRTC is actually enabled.
|
||||||
*/
|
*/
|
||||||
void drm_atomic_helper_commit_post_planes(struct drm_device *dev,
|
void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev,
|
||||||
struct drm_atomic_state *old_state)
|
struct drm_atomic_state *old_state)
|
||||||
{
|
{
|
||||||
int ncrtcs = old_state->dev->mode_config.num_crtc;
|
int ncrtcs = old_state->dev->mode_config.num_crtc;
|
||||||
int i;
|
int i;
|
||||||
@ -861,7 +871,7 @@ void drm_atomic_helper_commit_post_planes(struct drm_device *dev,
|
|||||||
encoder->bridge->funcs->enable(encoder->bridge);
|
encoder->bridge->funcs->enable(encoder->bridge);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_atomic_helper_commit_post_planes);
|
EXPORT_SYMBOL(drm_atomic_helper_commit_modeset_enables);
|
||||||
|
|
||||||
static void wait_for_fences(struct drm_device *dev,
|
static void wait_for_fences(struct drm_device *dev,
|
||||||
struct drm_atomic_state *state)
|
struct drm_atomic_state *state)
|
||||||
@ -1030,11 +1040,11 @@ int drm_atomic_helper_commit(struct drm_device *dev,
|
|||||||
|
|
||||||
wait_for_fences(dev, state);
|
wait_for_fences(dev, state);
|
||||||
|
|
||||||
drm_atomic_helper_commit_pre_planes(dev, state);
|
drm_atomic_helper_commit_modeset_disables(dev, state);
|
||||||
|
|
||||||
drm_atomic_helper_commit_planes(dev, state);
|
drm_atomic_helper_commit_planes(dev, state);
|
||||||
|
|
||||||
drm_atomic_helper_commit_post_planes(dev, state);
|
drm_atomic_helper_commit_modeset_enables(dev, state);
|
||||||
|
|
||||||
drm_atomic_helper_wait_for_vblanks(dev, state);
|
drm_atomic_helper_wait_for_vblanks(dev, state);
|
||||||
|
|
||||||
|
@ -134,9 +134,9 @@ int intel_atomic_commit(struct drm_device *dev,
|
|||||||
* FIXME: The proper sequence here will eventually be:
|
* FIXME: The proper sequence here will eventually be:
|
||||||
*
|
*
|
||||||
* drm_atomic_helper_swap_state(dev, state)
|
* drm_atomic_helper_swap_state(dev, state)
|
||||||
* drm_atomic_helper_commit_pre_planes(dev, state);
|
* drm_atomic_helper_commit_modeset_disables(dev, state);
|
||||||
* drm_atomic_helper_commit_planes(dev, state);
|
* drm_atomic_helper_commit_planes(dev, state);
|
||||||
* drm_atomic_helper_commit_post_planes(dev, state);
|
* drm_atomic_helper_commit_modeset_enables(dev, state);
|
||||||
* drm_atomic_helper_wait_for_vblanks(dev, state);
|
* drm_atomic_helper_wait_for_vblanks(dev, state);
|
||||||
* drm_atomic_helper_cleanup_planes(dev, state);
|
* drm_atomic_helper_cleanup_planes(dev, state);
|
||||||
* drm_atomic_state_free(state);
|
* drm_atomic_state_free(state);
|
||||||
|
@ -96,11 +96,11 @@ static void complete_commit(struct msm_commit *c)
|
|||||||
|
|
||||||
kms->funcs->prepare_commit(kms, state);
|
kms->funcs->prepare_commit(kms, state);
|
||||||
|
|
||||||
drm_atomic_helper_commit_pre_planes(dev, state);
|
drm_atomic_helper_commit_modeset_disables(dev, state);
|
||||||
|
|
||||||
drm_atomic_helper_commit_planes(dev, state);
|
drm_atomic_helper_commit_planes(dev, state);
|
||||||
|
|
||||||
drm_atomic_helper_commit_post_planes(dev, state);
|
drm_atomic_helper_commit_modeset_enables(dev, state);
|
||||||
|
|
||||||
/* NOTE: _wait_for_vblanks() only waits for vblank on
|
/* NOTE: _wait_for_vblanks() only waits for vblank on
|
||||||
* enabled CRTCs. So we end up faulting when disabling
|
* enabled CRTCs. So we end up faulting when disabling
|
||||||
|
@ -55,9 +55,9 @@ static void tegra_atomic_complete(struct tegra_drm *tegra,
|
|||||||
* current layout.
|
* current layout.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
drm_atomic_helper_commit_pre_planes(drm, state);
|
drm_atomic_helper_commit_modeset_disables(drm, state);
|
||||||
drm_atomic_helper_commit_planes(drm, state);
|
drm_atomic_helper_commit_planes(drm, state);
|
||||||
drm_atomic_helper_commit_post_planes(drm, state);
|
drm_atomic_helper_commit_modeset_enables(drm, state);
|
||||||
|
|
||||||
drm_atomic_helper_wait_for_vblanks(drm, state);
|
drm_atomic_helper_wait_for_vblanks(drm, state);
|
||||||
|
|
||||||
|
@ -43,9 +43,9 @@ int drm_atomic_helper_commit(struct drm_device *dev,
|
|||||||
void drm_atomic_helper_wait_for_vblanks(struct drm_device *dev,
|
void drm_atomic_helper_wait_for_vblanks(struct drm_device *dev,
|
||||||
struct drm_atomic_state *old_state);
|
struct drm_atomic_state *old_state);
|
||||||
|
|
||||||
void drm_atomic_helper_commit_pre_planes(struct drm_device *dev,
|
void drm_atomic_helper_commit_modeset_disables(struct drm_device *dev,
|
||||||
struct drm_atomic_state *state);
|
struct drm_atomic_state *state);
|
||||||
void drm_atomic_helper_commit_post_planes(struct drm_device *dev,
|
void drm_atomic_helper_commit_modeset_enables(struct drm_device *dev,
|
||||||
struct drm_atomic_state *old_state);
|
struct drm_atomic_state *old_state);
|
||||||
|
|
||||||
int drm_atomic_helper_prepare_planes(struct drm_device *dev,
|
int drm_atomic_helper_prepare_planes(struct drm_device *dev,
|
||||||
|
Loading…
Reference in New Issue
Block a user