diff options
| author | Dave Airlie <airlied@redhat.com> | 2019-08-06 12:41:39 +1000 | 
|---|---|---|
| committer | Dave Airlie <airlied@redhat.com> | 2019-08-06 12:49:12 +1000 | 
| commit | dce14e36aea23183ccd315fbc6b0fca027bf73f5 (patch) | |
| tree | d1ab64f087b43df1c5f3499cab23fffd2bd7f694 /drivers/gpu/drm/i915/display/intel_atomic_plane.c | |
| parent | e21a712a9685488f5ce80495b37b9fdbe96c230d (diff) | |
| parent | e0e712fe42ef67bdf45fc348767d1d0a4eeba77f (diff) | |
Merge tag 'drm-intel-next-2019-07-30' of git://anongit.freedesktop.org/drm/drm-intel into drm-next
- More changes on simplifying locking mechanisms (Chris)
- Selftests fixes and improvements (Chris)
- More work around engine tracking for better handling (Chris, Tvrtko)
- HDCP debug and info improvements (Ram, Ashuman)
- Add DSI properties (Vandita)
- Rework on sdvo support for better debuggability before fixing bugs (Ville)
- Display PLLs fixes and improvements, specially targeting Ice Lake (Imre, Matt, Ville)
- Perf fixes and improvements (Lionel)
- Enumerate scratch buffers (Lionel)
- Add infra to hold off preemption on a request (Lionel)
- Ice Lake color space fixes (Uma)
- Type-C fixes and improvements (Lucas)
- Fix and improvements around workarounds (Chris, John, Tvrtko)
- GuC related fixes and improvements (Chris, Daniele, Michal, Tvrtko)
- Fix on VLV/CHV display power domain (Ville)
- Improvements around Watermark (Ville)
- Favor intel_ types on intel_atomic functions (Ville)
- Don’t pass stack garbage to pcode (Ville)
- Improve display tracepoints (Steven)
- Don’t overestimate 4:2:0 link symbol clock (Ville)
- Add support for 4th pipe and transcoder (Lucas)
- Introduce initial support for Tiger Lake platform (Daniele, Lucas, Mahesh, Jose, Imre, Mika, Vandita, Rodrigo, Michel)
- PPGTT allocation simplification (Chris)
- Standardize function names and suffixes to make clean, symmetric and let checkpatch happy (Janusz)
- Skip SINK_COUNT read on CH7511 (Ville)
- Fix on kernel documentation (Chris, Michal)
- Add modular FIA (Anusha, Lucas)
- Fix EHL display (Matt, Vivek)
- Enable hotplug retry (Imre, Jose)
- Disable preemption under GVT (Chris)
- OA; Reconfigure context on the fly (Chris)
- Fixes and improvements around engine reset. (Chris)
- Small clean up on display pipe fault mask (Ville)
- Make sure cdclk is high enough for DP audio on VLV/CHV (Ville)
- Drop some wmb() and improve pwrite flush (Chris)
- Fix critical PSR regression (DK)
- Remove unused variables (YueHaibing)
- Use dev_get_drvdata for simplification (Chunhong)
- Use upstream version of header tests (Jani)
drm-intel-next-2019-07-08:
- Signal fence completion from i915_request_wait (Chris)
- Fixes and improvements around rings pin/unpin (Chris)
- Display uncore prep patches (Daniele)
- Execlists preemption improvements (Chris)
- Selftests fixes and improvements (Chris)
- More Elkhartlake enabling work (Vandita, Jose, Matt, Vivek)
- Defer address space cleanup to an RCU worker (Chris)
- Implicit dev_priv removal and GT compartmentalization and other related follow-ups (Tvrtko, Chris)
- Prevent dereference of engine before NULL check in error capture (Chris)
- GuC related fixes (Daniele, Robert)
- Many changes on active tracking, timelines and locking mechanisms (Chris)
- Disable SAMPLER_STATE prefetching on Gen11 (HW W/a) (Kenneth)
- I915_perf fixes (Lionel)
- Add Ice Lake PCI ID (Mika)
- eDP backlight fix (Lee)
- Fix various gen2 tracepoints (Ville)
- Some irq vfunc clean-up and improvements (Ville)
- Move OA files to separated folder (Michal)
- Display self contained headers clean-up (Jani)
- Preparation for 4th pile (Lucas)
- Move atomic commit, watermark and other places to use more intel_crtc_state (Maarten)
- Many Ice Lake Type C and Thunderbolt fixes (Imre)
- Fix some Ice Lake hw w/a whitelist regs (Lionel)
- Fix memleak in runtime wakeref tracking (Mika)
- Remove unused Private PPAT manager (Michal)
- Don't check PPGTT presence on PPGTT-only platforms (Michal)
- Fix ICL DSI suspend/resume (Chris)
- Fix ICL Bandwidth issues (Ville)
- Add N & CTS values for 10/12 bit deep color (Aditya)
- Moving more GT related stuff under gt folder (Chris)
- Forcewake related fixes (Chris)
- Show support for accurate sw PMU busyness tracking (Chris)
- Handle gtt double alloc failures (Chris)
- Upgrade to new GuC version (Michal)
- Improve w/a debug dumps and pull engine w/a initialization into a common (Chris)
- Look for instdone on all engines at hangcheck (Tvrtko)
- Engine lookup simplification  (Chris)
- Many plane color formats fixes and improvements (Ville)
- Fix some compilation issues (YueHaibing)
- GTT page directory clean up and improvements (Mika)
Signed-off-by: Dave Airlie <airlied@redhat.com>
From: Rodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190801201314.GA23635@intel.com
Diffstat (limited to 'drivers/gpu/drm/i915/display/intel_atomic_plane.c')
| -rw-r--r-- | drivers/gpu/drm/i915/display/intel_atomic_plane.c | 54 | 
1 files changed, 35 insertions, 19 deletions
| diff --git a/drivers/gpu/drm/i915/display/intel_atomic_plane.c b/drivers/gpu/drm/i915/display/intel_atomic_plane.c index 30bd4e76fff9..ab411d5e093c 100644 --- a/drivers/gpu/drm/i915/display/intel_atomic_plane.c +++ b/drivers/gpu/drm/i915/display/intel_atomic_plane.c @@ -176,33 +176,49 @@ int intel_plane_atomic_check_with_state(const struct intel_crtc_state *old_crtc_  	new_crtc_state->data_rate[plane->id] =  		intel_plane_data_rate(new_crtc_state, new_plane_state); -	return intel_plane_atomic_calc_changes(old_crtc_state, -					       &new_crtc_state->base, -					       old_plane_state, -					       &new_plane_state->base); +	return intel_plane_atomic_calc_changes(old_crtc_state, new_crtc_state, +					       old_plane_state, new_plane_state);  } -static int intel_plane_atomic_check(struct drm_plane *plane, -				    struct drm_plane_state *new_plane_state) +static struct intel_crtc * +get_crtc_from_states(const struct intel_plane_state *old_plane_state, +		     const struct intel_plane_state *new_plane_state)  { -	struct drm_atomic_state *state = new_plane_state->state; -	const struct drm_plane_state *old_plane_state = -		drm_atomic_get_old_plane_state(state, plane); -	struct drm_crtc *crtc = new_plane_state->crtc ?: old_plane_state->crtc; -	const struct drm_crtc_state *old_crtc_state; -	struct drm_crtc_state *new_crtc_state; +	if (new_plane_state->base.crtc) +		return to_intel_crtc(new_plane_state->base.crtc); -	new_plane_state->visible = false; +	if (old_plane_state->base.crtc) +		return to_intel_crtc(old_plane_state->base.crtc); + +	return NULL; +} + +static int intel_plane_atomic_check(struct drm_plane *_plane, +				    struct drm_plane_state *_new_plane_state) +{ +	struct intel_plane *plane = to_intel_plane(_plane); +	struct intel_atomic_state *state = +		to_intel_atomic_state(_new_plane_state->state); +	struct intel_plane_state *new_plane_state = +		to_intel_plane_state(_new_plane_state); +	const struct intel_plane_state *old_plane_state = +		intel_atomic_get_old_plane_state(state, plane); +	struct intel_crtc *crtc = +		get_crtc_from_states(old_plane_state, new_plane_state); +	const struct intel_crtc_state *old_crtc_state; +	struct intel_crtc_state *new_crtc_state; + +	new_plane_state->base.visible = false;  	if (!crtc)  		return 0; -	old_crtc_state = drm_atomic_get_old_crtc_state(state, crtc); -	new_crtc_state = drm_atomic_get_new_crtc_state(state, crtc); +	old_crtc_state = intel_atomic_get_old_crtc_state(state, crtc); +	new_crtc_state = intel_atomic_get_new_crtc_state(state, crtc); -	return intel_plane_atomic_check_with_state(to_intel_crtc_state(old_crtc_state), -						   to_intel_crtc_state(new_crtc_state), -						   to_intel_plane_state(old_plane_state), -						   to_intel_plane_state(new_plane_state)); +	return intel_plane_atomic_check_with_state(old_crtc_state, +						   new_crtc_state, +						   old_plane_state, +						   new_plane_state);  }  static struct intel_plane * | 
