Commit 3ac6d358 authored by Jani Nikula's avatar Jani Nikula
Browse files

drm/i915/pps: add vlv_pps_backlight_initial_pipe()



Add vlv_pps_backlight_initial_pipe() and move the VLV/CHV initial
backlight pipe logic there, hiding the PPS pipe details inside PPS code.

Reviewed-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/b0587f183d8bb06679a75b04f956762435d10181.1726681620.git.jani.nikula@intel.com


Signed-off-by: default avatarJani Nikula <jani.nikula@intel.com>
parent 75e57145
Loading
Loading
Loading
Loading
+2 −14
Original line number Diff line number Diff line
@@ -6629,20 +6629,8 @@ static void intel_edp_backlight_setup(struct intel_dp *intel_dp,
	struct drm_i915_private *i915 = dp_to_i915(intel_dp);
	enum pipe pipe = INVALID_PIPE;

	if (IS_VALLEYVIEW(i915) || IS_CHERRYVIEW(i915)) {
		/*
		 * Figure out the current pipe for the initial backlight setup.
		 * If the current pipe isn't valid, try the PPS pipe, and if that
		 * fails just assume pipe A.
		 */
		pipe = vlv_active_pipe(intel_dp);

		if (pipe != PIPE_A && pipe != PIPE_B)
			pipe = intel_dp->pps.vlv_pps_pipe;

		if (pipe != PIPE_A && pipe != PIPE_B)
			pipe = PIPE_A;
	}
	if (IS_VALLEYVIEW(i915) || IS_CHERRYVIEW(i915))
		pipe = vlv_pps_backlight_initial_pipe(intel_dp);

	intel_backlight_setup(connector, pipe);
}
+20 −0
Original line number Diff line number Diff line
@@ -1227,6 +1227,26 @@ void vlv_pps_pipe_reset(struct intel_dp *intel_dp)
		intel_dp->pps.vlv_active_pipe = vlv_active_pipe(intel_dp);
}

enum pipe vlv_pps_backlight_initial_pipe(struct intel_dp *intel_dp)
{
	enum pipe pipe;

	/*
	 * Figure out the current pipe for the initial backlight setup. If the
	 * current pipe isn't valid, try the PPS pipe, and if that fails just
	 * assume pipe A.
	 */
	pipe = vlv_active_pipe(intel_dp);

	if (pipe != PIPE_A && pipe != PIPE_B)
		pipe = intel_dp->pps.vlv_pps_pipe;

	if (pipe != PIPE_A && pipe != PIPE_B)
		pipe = PIPE_A;

	return pipe;
}

/* Call on all DP, not just eDP */
void vlv_pps_port_enable_unlocked(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state)
+1 −0
Original line number Diff line number Diff line
@@ -47,6 +47,7 @@ void intel_pps_reset_all(struct intel_display *display);

void vlv_pps_pipe_init(struct intel_dp *intel_dp);
void vlv_pps_pipe_reset(struct intel_dp *intel_dp);
enum pipe vlv_pps_backlight_initial_pipe(struct intel_dp *intel_dp);
void vlv_pps_port_enable_unlocked(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state);
void vlv_pps_port_disable(struct intel_encoder *encoder,