aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_atomic.c
diff options
context:
space:
mode:
authorChandra Konduru <chandra.konduru@intel.com>2015-04-07 15:28:44 -0700
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-04-13 11:44:09 +0200
commitf76f35dc040e44d63369fdba3124701feec714f0 (patch)
treebfee53d2985b7f0a4ec56522c2c10c25f753eebb /drivers/gpu/drm/i915/intel_atomic.c
parentdrm/i915: Ensure setting up scalers into staged crtc_state (diff)
downloadlinux-dev-f76f35dc040e44d63369fdba3124701feec714f0.tar.xz
linux-dev-f76f35dc040e44d63369fdba3124701feec714f0.zip
drm/i915: copy staged scaler state from drm state to crtc->config.
This is required for commit to perform as per staged assignment of scalers until atomic crtc commit function is available. As a place holder doing this copy from intel_atomic_commit for scaling to operate correctly. Signed-off-by: Chandra Konduru <chandra.konduru@intel.com> Reviewed-by: Matt Roper <matthew.d.roper@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to '')
-rw-r--r--drivers/gpu/drm/i915/intel_atomic.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_atomic.c b/drivers/gpu/drm/i915/intel_atomic.c
index 42045ce29898..3c4b7cdeab77 100644
--- a/drivers/gpu/drm/i915/intel_atomic.c
+++ b/drivers/gpu/drm/i915/intel_atomic.c
@@ -168,6 +168,18 @@ int intel_atomic_commit(struct drm_device *dev,
swap(state->plane_states[i], plane->state);
plane->state->state = NULL;
}
+
+ /* swap crtc_state */
+ for (i = 0; i < dev->mode_config.num_crtc; i++) {
+ struct drm_crtc *crtc = state->crtcs[i];
+ if (!crtc) {
+ continue;
+ }
+
+ to_intel_crtc(crtc)->config->scaler_state =
+ to_intel_crtc_state(state->crtc_states[i])->scaler_state;
+ }
+
drm_atomic_helper_commit_planes(dev, state);
drm_atomic_helper_wait_for_vblanks(dev, state);
drm_atomic_helper_cleanup_planes(dev, state);