Commit 5e4098f7 authored by Jani Nikula's avatar Jani Nikula
Browse files

drm/i915/lvds: convert intel_lvds.[ch] to struct intel_display



Going forward, struct intel_display is the main display device data
pointer. Convert as much as possible of intel_lvds.[ch] to struct
intel_display.

Reviewed-by: default avatarVille Syrjälä <ville.syrjala@linux.intel.com>
Link: https://lore.kernel.org/r/2b5205db60f956dba788cc894531cc74d0dd853d.1742554320.git.jani.nikula@intel.com


Signed-off-by: default avatarJani Nikula <jani.nikula@intel.com>
parent 87ec114e
Loading
Loading
Loading
Loading
+5 −6
Original line number Diff line number Diff line
@@ -2342,7 +2342,6 @@ static int intel_crtc_compute_pipe_src(struct intel_crtc_state *crtc_state)
{
	struct intel_display *display = to_intel_display(crtc_state);
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
	struct drm_i915_private *i915 = to_i915(crtc->base.dev);

	intel_joiner_compute_pipe_src(crtc_state);

@@ -2361,7 +2360,7 @@ static int intel_crtc_compute_pipe_src(struct intel_crtc_state *crtc_state)
		}

		if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_LVDS) &&
		    intel_is_dual_link_lvds(i915)) {
		    intel_is_dual_link_lvds(display)) {
			drm_dbg_kms(display->drm,
				    "[CRTC:%d:%s] Odd pipe source width not supported with dual link LVDS\n",
				    crtc->base.base.id, crtc->base.name);
@@ -7678,7 +7677,7 @@ void intel_setup_outputs(struct intel_display *display)
		 * to prevent the registration of both eDP and LVDS and the
		 * incorrect sharing of the PPS.
		 */
		intel_lvds_init(dev_priv);
		intel_lvds_init(display);
		intel_crt_init(display);

		dpd_is_edp = intel_dp_is_port_edp(display, PORT_D);
@@ -7755,13 +7754,13 @@ void intel_setup_outputs(struct intel_display *display)

		vlv_dsi_init(display);
	} else if (display->platform.pineview) {
		intel_lvds_init(dev_priv);
		intel_lvds_init(display);
		intel_crt_init(display);
	} else if (IS_DISPLAY_VER(display, 3, 4)) {
		bool found = false;

		if (display->platform.mobile)
			intel_lvds_init(dev_priv);
			intel_lvds_init(display);

		intel_crt_init(display);

@@ -7803,7 +7802,7 @@ void intel_setup_outputs(struct intel_display *display)
			intel_tv_init(display);
	} else if (DISPLAY_VER(display) == 2) {
		if (display->platform.i85x)
			intel_lvds_init(dev_priv);
			intel_lvds_init(display);

		intel_crt_init(display);
		intel_dvo_init(display);
+1 −1
Original line number Diff line number Diff line
@@ -6325,7 +6325,7 @@ static bool intel_edp_init_connector(struct intel_dp *intel_dp,
	 * eDP and LVDS bail out early in this case to prevent interfering
	 * with an already powered-on LVDS power sequencer.
	 */
	if (intel_get_lvds_encoder(dev_priv)) {
	if (intel_get_lvds_encoder(display)) {
		drm_WARN_ON(display->drm,
			    !(HAS_PCH_IBX(dev_priv) || HAS_PCH_CPT(dev_priv)));
		drm_info(display->drm,
+7 −6
Original line number Diff line number Diff line
@@ -421,6 +421,7 @@ void i9xx_dpll_get_hw_state(struct intel_crtc *crtc,
/* Returns the clock of the currently programmed mode of the given pipe. */
void i9xx_crtc_clock_get(struct intel_crtc_state *crtc_state)
{
	struct intel_display *display = to_intel_display(crtc_state);
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	const struct i9xx_dpll_hw_state *hw_state = &crtc_state->dpll_hw_state.i9xx;
@@ -476,7 +477,7 @@ void i9xx_crtc_clock_get(struct intel_crtc_state *crtc_state)
		enum pipe lvds_pipe;

		if (IS_I85X(dev_priv) &&
		    intel_lvds_port_enabled(dev_priv, LVDS, &lvds_pipe) &&
		    intel_lvds_port_enabled(display, LVDS, &lvds_pipe) &&
		    lvds_pipe == crtc->pipe) {
			u32 lvds = intel_de_read(dev_priv, LVDS);

@@ -620,7 +621,7 @@ i9xx_select_p2_div(const struct intel_limit *limit,
		   const struct intel_crtc_state *crtc_state,
		   int target)
{
	struct drm_i915_private *dev_priv = to_i915(crtc_state->uapi.crtc->dev);
	struct intel_display *display = to_intel_display(crtc_state);

	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_LVDS)) {
		/*
@@ -628,7 +629,7 @@ i9xx_select_p2_div(const struct intel_limit *limit,
		 * We haven't figured out how to reliably set up different
		 * single/dual channel state, if we even can.
		 */
		if (intel_is_dual_link_lvds(dev_priv))
		if (intel_is_dual_link_lvds(display))
			return limit->p2.p2_fast;
		else
			return limit->p2.p2_slow;
@@ -1246,7 +1247,7 @@ static int ilk_fb_cb_factor(const struct intel_crtc_state *crtc_state)

	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_LVDS) &&
	    ((intel_panel_use_ssc(display) && i915->display.vbt.lvds_ssc_freq == 100000) ||
	     (HAS_PCH_IBX(i915) && intel_is_dual_link_lvds(i915))))
	     (HAS_PCH_IBX(i915) && intel_is_dual_link_lvds(display))))
		return 25;

	if (crtc_state->sdvo_tv_clock)
@@ -1381,7 +1382,7 @@ static int ilk_crtc_compute_clock(struct intel_atomic_state *state,
			refclk = dev_priv->display.vbt.lvds_ssc_freq;
		}

		if (intel_is_dual_link_lvds(dev_priv)) {
		if (intel_is_dual_link_lvds(display)) {
			if (refclk == 100000)
				limit = &ilk_limits_dual_lvds_100m;
			else
@@ -1553,7 +1554,7 @@ static int g4x_crtc_compute_clock(struct intel_atomic_state *state,
				    refclk);
		}

		if (intel_is_dual_link_lvds(dev_priv))
		if (intel_is_dual_link_lvds(display))
			limit = &intel_limits_g4x_dual_channel_lvds;
		else
			limit = &intel_limits_g4x_single_channel_lvds;
+72 −70
Original line number Diff line number Diff line
@@ -84,12 +84,13 @@ static struct intel_lvds_encoder *to_lvds_encoder(struct intel_encoder *encoder)
	return container_of(encoder, struct intel_lvds_encoder, base);
}

bool intel_lvds_port_enabled(struct drm_i915_private *i915,
bool intel_lvds_port_enabled(struct intel_display *display,
			     i915_reg_t lvds_reg, enum pipe *pipe)
{
	struct drm_i915_private *i915 = to_i915(display->drm);
	u32 val;

	val = intel_de_read(i915, lvds_reg);
	val = intel_de_read(display, lvds_reg);

	/* asserts want to know the pipe even if the port is disabled */
	if (HAS_PCH_CPT(i915))
@@ -104,7 +105,6 @@ static bool intel_lvds_get_hw_state(struct intel_encoder *encoder,
				    enum pipe *pipe)
{
	struct intel_display *display = to_intel_display(encoder);
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	struct intel_lvds_encoder *lvds_encoder = to_lvds_encoder(encoder);
	intel_wakeref_t wakeref;
	bool ret;
@@ -113,7 +113,7 @@ static bool intel_lvds_get_hw_state(struct intel_encoder *encoder,
	if (!wakeref)
		return false;

	ret = intel_lvds_port_enabled(i915, lvds_encoder->reg, pipe);
	ret = intel_lvds_port_enabled(display, lvds_encoder->reg, pipe);

	intel_display_power_put(display, encoder->power_domain, wakeref);

@@ -123,13 +123,13 @@ static bool intel_lvds_get_hw_state(struct intel_encoder *encoder,
static void intel_lvds_get_config(struct intel_encoder *encoder,
				  struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_display *display = to_intel_display(encoder);
	struct intel_lvds_encoder *lvds_encoder = to_lvds_encoder(encoder);
	u32 tmp, flags = 0;

	crtc_state->output_types |= BIT(INTEL_OUTPUT_LVDS);

	tmp = intel_de_read(dev_priv, lvds_encoder->reg);
	tmp = intel_de_read(display, lvds_encoder->reg);
	if (tmp & LVDS_HSYNC_POLARITY)
		flags |= DRM_MODE_FLAG_NHSYNC;
	else
@@ -141,13 +141,13 @@ static void intel_lvds_get_config(struct intel_encoder *encoder,

	crtc_state->hw.adjusted_mode.flags |= flags;

	if (DISPLAY_VER(dev_priv) < 5)
	if (DISPLAY_VER(display) < 5)
		crtc_state->gmch_pfit.lvds_border_bits =
			tmp & LVDS_BORDER_ENABLE;

	/* gen2/3 store dither state in pfit control, needs to match */
	if (DISPLAY_VER(dev_priv) < 4) {
		tmp = intel_de_read(dev_priv, PFIT_CONTROL(dev_priv));
	if (DISPLAY_VER(display) < 4) {
		tmp = intel_de_read(display, PFIT_CONTROL(display));

		crtc_state->gmch_pfit.control |= tmp & PFIT_PANEL_8TO6_DITHER_ENABLE;
	}
@@ -155,24 +155,24 @@ static void intel_lvds_get_config(struct intel_encoder *encoder,
	crtc_state->hw.adjusted_mode.crtc_clock = crtc_state->port_clock;
}

static void intel_lvds_pps_get_hw_state(struct drm_i915_private *dev_priv,
static void intel_lvds_pps_get_hw_state(struct intel_display *display,
					struct intel_lvds_pps *pps)
{
	u32 val;

	pps->powerdown_on_reset = intel_de_read(dev_priv,
						PP_CONTROL(dev_priv, 0)) & PANEL_POWER_RESET;
	pps->powerdown_on_reset = intel_de_read(display,
						PP_CONTROL(display, 0)) & PANEL_POWER_RESET;

	val = intel_de_read(dev_priv, PP_ON_DELAYS(dev_priv, 0));
	val = intel_de_read(display, PP_ON_DELAYS(display, 0));
	pps->port = REG_FIELD_GET(PANEL_PORT_SELECT_MASK, val);
	pps->delays.power_up = REG_FIELD_GET(PANEL_POWER_UP_DELAY_MASK, val);
	pps->delays.backlight_on = REG_FIELD_GET(PANEL_LIGHT_ON_DELAY_MASK, val);

	val = intel_de_read(dev_priv, PP_OFF_DELAYS(dev_priv, 0));
	val = intel_de_read(display, PP_OFF_DELAYS(display, 0));
	pps->delays.power_down = REG_FIELD_GET(PANEL_POWER_DOWN_DELAY_MASK, val);
	pps->delays.backlight_off = REG_FIELD_GET(PANEL_LIGHT_OFF_DELAY_MASK, val);

	val = intel_de_read(dev_priv, PP_DIVISOR(dev_priv, 0));
	val = intel_de_read(display, PP_DIVISOR(display, 0));
	pps->divider = REG_FIELD_GET(PP_REFERENCE_DIVIDER_MASK, val);
	val = REG_FIELD_GET(PANEL_POWER_CYCLE_DELAY_MASK, val);
	/*
@@ -185,12 +185,12 @@ static void intel_lvds_pps_get_hw_state(struct drm_i915_private *dev_priv,
	/* Convert from 100ms to 100us units */
	pps->delays.power_cycle = val * 1000;

	if (DISPLAY_VER(dev_priv) < 5 &&
	if (DISPLAY_VER(display) < 5 &&
	    pps->delays.power_up == 0 &&
	    pps->delays.backlight_on == 0 &&
	    pps->delays.power_down == 0 &&
	    pps->delays.backlight_off == 0) {
		drm_dbg_kms(&dev_priv->drm,
		drm_dbg_kms(display->drm,
			    "Panel power timings uninitialized, "
			    "setting defaults\n");
		/* Set T2 to 40ms and T5 to 200ms in 100 usec units */
@@ -201,7 +201,7 @@ static void intel_lvds_pps_get_hw_state(struct drm_i915_private *dev_priv,
		pps->delays.backlight_off = 200 * 10;
	}

	drm_dbg(&dev_priv->drm, "LVDS PPS:power_up %d power_down %d power_cycle %d backlight_on %d backlight_off %d "
	drm_dbg(display->drm, "LVDS PPS:power_up %d power_down %d power_cycle %d backlight_on %d backlight_off %d "
		"divider %d port %d powerdown_on_reset %d\n",
		pps->delays.power_up, pps->delays.power_down,
		pps->delays.power_cycle, pps->delays.backlight_on,
@@ -209,28 +209,28 @@ static void intel_lvds_pps_get_hw_state(struct drm_i915_private *dev_priv,
		pps->port, pps->powerdown_on_reset);
}

static void intel_lvds_pps_init_hw(struct drm_i915_private *dev_priv,
static void intel_lvds_pps_init_hw(struct intel_display *display,
				   struct intel_lvds_pps *pps)
{
	u32 val;

	val = intel_de_read(dev_priv, PP_CONTROL(dev_priv, 0));
	drm_WARN_ON(&dev_priv->drm,
	val = intel_de_read(display, PP_CONTROL(display, 0));
	drm_WARN_ON(display->drm,
		    (val & PANEL_UNLOCK_MASK) != PANEL_UNLOCK_REGS);
	if (pps->powerdown_on_reset)
		val |= PANEL_POWER_RESET;
	intel_de_write(dev_priv, PP_CONTROL(dev_priv, 0), val);
	intel_de_write(display, PP_CONTROL(display, 0), val);

	intel_de_write(dev_priv, PP_ON_DELAYS(dev_priv, 0),
	intel_de_write(display, PP_ON_DELAYS(display, 0),
		       REG_FIELD_PREP(PANEL_PORT_SELECT_MASK, pps->port) |
		       REG_FIELD_PREP(PANEL_POWER_UP_DELAY_MASK, pps->delays.power_up) |
		       REG_FIELD_PREP(PANEL_LIGHT_ON_DELAY_MASK, pps->delays.backlight_on));

	intel_de_write(dev_priv, PP_OFF_DELAYS(dev_priv, 0),
	intel_de_write(display, PP_OFF_DELAYS(display, 0),
		       REG_FIELD_PREP(PANEL_POWER_DOWN_DELAY_MASK, pps->delays.power_down) |
		       REG_FIELD_PREP(PANEL_LIGHT_OFF_DELAY_MASK, pps->delays.backlight_off));

	intel_de_write(dev_priv, PP_DIVISOR(dev_priv, 0),
	intel_de_write(display, PP_DIVISOR(display, 0),
		       REG_FIELD_PREP(PP_REFERENCE_DIVIDER_MASK, pps->divider) |
		       REG_FIELD_PREP(PANEL_POWER_CYCLE_DELAY_MASK,
				      DIV_ROUND_UP(pps->delays.power_cycle, 1000) + 1));
@@ -256,7 +256,7 @@ static void intel_pre_enable_lvds(struct intel_atomic_state *state,
		assert_pll_disabled(display, pipe);
	}

	intel_lvds_pps_init_hw(i915, &lvds_encoder->init_pps);
	intel_lvds_pps_init_hw(display, &lvds_encoder->init_pps);

	temp = lvds_encoder->init_lvds_val;
	temp |= LVDS_PORT_EN | LVDS_A0A2_CLKA_POWER_UP;
@@ -296,7 +296,7 @@ static void intel_pre_enable_lvds(struct intel_atomic_state *state,
	 * special lvds dither control bit on pch-split platforms, dithering is
	 * only controlled through the TRANSCONF reg.
	 */
	if (DISPLAY_VER(i915) == 4) {
	if (DISPLAY_VER(display) == 4) {
		/*
		 * Bspec wording suggests that LVDS port dithering only exists
		 * for 18bpp panels.
@@ -312,7 +312,7 @@ static void intel_pre_enable_lvds(struct intel_atomic_state *state,
	if (adjusted_mode->flags & DRM_MODE_FLAG_NVSYNC)
		temp |= LVDS_VSYNC_POLARITY;

	intel_de_write(i915, lvds_encoder->reg, temp);
	intel_de_write(display, lvds_encoder->reg, temp);
}

/*
@@ -323,16 +323,16 @@ static void intel_enable_lvds(struct intel_atomic_state *state,
			      const struct intel_crtc_state *crtc_state,
			      const struct drm_connector_state *conn_state)
{
	struct intel_display *display = to_intel_display(encoder);
	struct intel_lvds_encoder *lvds_encoder = to_lvds_encoder(encoder);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);

	intel_de_rmw(dev_priv, lvds_encoder->reg, 0, LVDS_PORT_EN);
	intel_de_rmw(display, lvds_encoder->reg, 0, LVDS_PORT_EN);

	intel_de_rmw(dev_priv, PP_CONTROL(dev_priv, 0), 0, PANEL_POWER_ON);
	intel_de_posting_read(dev_priv, lvds_encoder->reg);
	intel_de_rmw(display, PP_CONTROL(display, 0), 0, PANEL_POWER_ON);
	intel_de_posting_read(display, lvds_encoder->reg);

	if (intel_de_wait_for_set(dev_priv, PP_STATUS(dev_priv, 0), PP_ON, 5000))
		drm_err(&dev_priv->drm,
	if (intel_de_wait_for_set(display, PP_STATUS(display, 0), PP_ON, 5000))
		drm_err(display->drm,
			"timed out waiting for panel to power on\n");

	intel_backlight_enable(crtc_state, conn_state);
@@ -343,16 +343,16 @@ static void intel_disable_lvds(struct intel_atomic_state *state,
			       const struct intel_crtc_state *old_crtc_state,
			       const struct drm_connector_state *old_conn_state)
{
	struct intel_display *display = to_intel_display(encoder);
	struct intel_lvds_encoder *lvds_encoder = to_lvds_encoder(encoder);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);

	intel_de_rmw(dev_priv, PP_CONTROL(dev_priv, 0), PANEL_POWER_ON, 0);
	if (intel_de_wait_for_clear(dev_priv, PP_STATUS(dev_priv, 0), PP_ON, 1000))
		drm_err(&dev_priv->drm,
	intel_de_rmw(display, PP_CONTROL(display, 0), PANEL_POWER_ON, 0);
	if (intel_de_wait_for_clear(display, PP_STATUS(display, 0), PP_ON, 1000))
		drm_err(display->drm,
			"timed out waiting for panel to power off\n");

	intel_de_rmw(dev_priv, lvds_encoder->reg, LVDS_PORT_EN, 0);
	intel_de_posting_read(dev_priv, lvds_encoder->reg);
	intel_de_rmw(display, lvds_encoder->reg, LVDS_PORT_EN, 0);
	intel_de_posting_read(display, lvds_encoder->reg);
}

static void gmch_disable_lvds(struct intel_atomic_state *state,
@@ -384,10 +384,10 @@ static void pch_post_disable_lvds(struct intel_atomic_state *state,

static void intel_lvds_shutdown(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_display *display = to_intel_display(encoder);

	if (intel_de_wait_for_clear(dev_priv, PP_STATUS(dev_priv, 0), PP_CYCLE_DELAY_ACTIVE, 5000))
		drm_err(&dev_priv->drm,
	if (intel_de_wait_for_clear(display, PP_STATUS(display, 0), PP_CYCLE_DELAY_ACTIVE, 5000))
		drm_err(display->drm,
			"timed out waiting for panel power cycle delay\n");
}

@@ -420,6 +420,7 @@ static int intel_lvds_compute_config(struct intel_encoder *encoder,
				     struct intel_crtc_state *crtc_state,
				     struct drm_connector_state *conn_state)
{
	struct intel_display *display = to_intel_display(encoder);
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	struct intel_lvds_encoder *lvds_encoder = to_lvds_encoder(encoder);
	struct intel_connector *connector = lvds_encoder->attached_connector;
@@ -429,8 +430,8 @@ static int intel_lvds_compute_config(struct intel_encoder *encoder,
	int ret;

	/* Should never happen!! */
	if (DISPLAY_VER(i915) < 4 && crtc->pipe == 0) {
		drm_err(&i915->drm, "Can't support LVDS on pipe A\n");
	if (DISPLAY_VER(display) < 4 && crtc->pipe == 0) {
		drm_err(display->drm, "Can't support LVDS on pipe A\n");
		return -EINVAL;
	}

@@ -447,7 +448,7 @@ static int intel_lvds_compute_config(struct intel_encoder *encoder,

	/* TODO: Check crtc_state->max_link_bpp_x16 instead of bw_constrained */
	if (lvds_bpp != crtc_state->pipe_bpp && !crtc_state->bw_constrained) {
		drm_dbg_kms(&i915->drm,
		drm_dbg_kms(display->drm,
			    "forcing display bpp (was %d) to LVDS (%d)\n",
			    crtc_state->pipe_bpp, lvds_bpp);
		crtc_state->pipe_bpp = lvds_bpp;
@@ -775,11 +776,11 @@ static const struct dmi_system_id intel_dual_link_lvds[] = {
	{ }	/* terminating entry */
};

struct intel_encoder *intel_get_lvds_encoder(struct drm_i915_private *i915)
struct intel_encoder *intel_get_lvds_encoder(struct intel_display *display)
{
	struct intel_encoder *encoder;

	for_each_intel_encoder(&i915->drm, encoder) {
	for_each_intel_encoder(display->drm, encoder) {
		if (encoder->type == INTEL_OUTPUT_LVDS)
			return encoder;
	}
@@ -787,15 +788,16 @@ struct intel_encoder *intel_get_lvds_encoder(struct drm_i915_private *i915)
	return NULL;
}

bool intel_is_dual_link_lvds(struct drm_i915_private *i915)
bool intel_is_dual_link_lvds(struct intel_display *display)
{
	struct intel_encoder *encoder = intel_get_lvds_encoder(i915);
	struct intel_encoder *encoder = intel_get_lvds_encoder(display);

	return encoder && to_lvds_encoder(encoder)->is_dual_link;
}

static bool compute_is_dual_link_lvds(struct intel_lvds_encoder *lvds_encoder)
{
	struct intel_display *display = to_intel_display(&lvds_encoder->base);
	struct drm_i915_private *i915 = to_i915(lvds_encoder->base.base.dev);
	struct intel_connector *connector = lvds_encoder->attached_connector;
	const struct drm_display_mode *fixed_mode =
@@ -803,8 +805,8 @@ static bool compute_is_dual_link_lvds(struct intel_lvds_encoder *lvds_encoder)
	unsigned int val;

	/* use the module option value if specified */
	if (i915->display.params.lvds_channel_mode > 0)
		return i915->display.params.lvds_channel_mode == 2;
	if (display->params.lvds_channel_mode > 0)
		return display->params.lvds_channel_mode == 2;

	/* single channel LVDS is limited to 112 MHz */
	if (fixed_mode->clock > 112999)
@@ -819,7 +821,7 @@ static bool compute_is_dual_link_lvds(struct intel_lvds_encoder *lvds_encoder)
	 * we need to check "the value to be set" in VBT when LVDS
	 * register is uninitialized.
	 */
	val = intel_de_read(i915, lvds_encoder->reg);
	val = intel_de_read(display, lvds_encoder->reg);
	if (HAS_PCH_CPT(i915))
		val &= ~(LVDS_DETECTED | LVDS_PIPE_SEL_MASK_CPT);
	else
@@ -837,14 +839,14 @@ static void intel_lvds_add_properties(struct drm_connector *connector)

/**
 * intel_lvds_init - setup LVDS connectors on this device
 * @i915: i915 device
 * @display: display device
 *
 * Create the connector, register the LVDS DDC bus, and try to figure out what
 * modes we can display on the LVDS panel (if present).
 */
void intel_lvds_init(struct drm_i915_private *i915)
void intel_lvds_init(struct intel_display *display)
{
	struct intel_display *display = &i915->display;
	struct drm_i915_private *i915 = to_i915(display->drm);
	struct intel_lvds_encoder *lvds_encoder;
	struct intel_connector *connector;
	const struct drm_edid *drm_edid;
@@ -855,13 +857,13 @@ void intel_lvds_init(struct drm_i915_private *i915)

	/* Skip init on machines we know falsely report LVDS */
	if (dmi_check_system(intel_no_lvds)) {
		drm_WARN(&i915->drm, !i915->display.vbt.int_lvds_support,
		drm_WARN(display->drm, !display->vbt.int_lvds_support,
			 "Useless DMI match. Internal LVDS support disabled by VBT\n");
		return;
	}

	if (!i915->display.vbt.int_lvds_support) {
		drm_dbg_kms(&i915->drm,
	if (!display->vbt.int_lvds_support) {
		drm_dbg_kms(display->drm,
			    "Internal LVDS support disabled by VBT\n");
		return;
	}
@@ -871,7 +873,7 @@ void intel_lvds_init(struct drm_i915_private *i915)
	else
		lvds_reg = LVDS;

	lvds = intel_de_read(i915, lvds_reg);
	lvds = intel_de_read(display, lvds_reg);

	if (HAS_PCH_SPLIT(i915)) {
		if ((lvds & LVDS_DETECTED) == 0)
@@ -881,11 +883,11 @@ void intel_lvds_init(struct drm_i915_private *i915)
	ddc_pin = GMBUS_PIN_PANEL;
	if (!intel_bios_is_lvds_present(display, &ddc_pin)) {
		if ((lvds & LVDS_PORT_EN) == 0) {
			drm_dbg_kms(&i915->drm,
			drm_dbg_kms(display->drm,
				    "LVDS is not present in VBT\n");
			return;
		}
		drm_dbg_kms(&i915->drm,
		drm_dbg_kms(display->drm,
			    "LVDS is not present in VBT, but enabled anyway\n");
	}

@@ -902,12 +904,12 @@ void intel_lvds_init(struct drm_i915_private *i915)
	lvds_encoder->attached_connector = connector;
	encoder = &lvds_encoder->base;

	drm_connector_init_with_ddc(&i915->drm, &connector->base,
	drm_connector_init_with_ddc(display->drm, &connector->base,
				    &intel_lvds_connector_funcs,
				    DRM_MODE_CONNECTOR_LVDS,
				    intel_gmbus_get_adapter(display, ddc_pin));

	drm_encoder_init(&i915->drm, &encoder->base, &intel_lvds_enc_funcs,
	drm_encoder_init(display->drm, &encoder->base, &intel_lvds_enc_funcs,
			 DRM_MODE_ENCODER_LVDS, "LVDS");

	encoder->enable = intel_enable_lvds;
@@ -931,7 +933,7 @@ void intel_lvds_init(struct drm_i915_private *i915)
	encoder->power_domain = POWER_DOMAIN_PORT_OTHER;
	encoder->port = PORT_NONE;
	encoder->cloneable = 0;
	if (DISPLAY_VER(i915) < 4)
	if (DISPLAY_VER(display) < 4)
		encoder->pipe_mask = BIT(PIPE_B);
	else
		encoder->pipe_mask = ~0;
@@ -943,7 +945,7 @@ void intel_lvds_init(struct drm_i915_private *i915)

	intel_lvds_add_properties(&connector->base);

	intel_lvds_pps_get_hw_state(i915, &lvds_encoder->init_pps);
	intel_lvds_pps_get_hw_state(display, &lvds_encoder->init_pps);
	lvds_encoder->init_lvds_val = lvds;

	/*
@@ -958,7 +960,7 @@ void intel_lvds_init(struct drm_i915_private *i915)
	 * Attempt to get the fixed panel mode from DDC.  Assume that the
	 * preferred mode is the right one.
	 */
	mutex_lock(&i915->drm.mode_config.mutex);
	mutex_lock(&display->drm->mode_config.mutex);
	if (vga_switcheroo_handler_flags() & VGA_SWITCHEROO_CAN_SWITCH_DDC)
		drm_edid = drm_edid_read_switcheroo(&connector->base, connector->base.ddc);
	else
@@ -991,7 +993,7 @@ void intel_lvds_init(struct drm_i915_private *i915)
	if (!intel_panel_preferred_fixed_mode(connector))
		intel_panel_add_encoder_fixed_mode(connector, encoder);

	mutex_unlock(&i915->drm.mode_config.mutex);
	mutex_unlock(&display->drm->mode_config.mutex);

	/* If we still don't have a mode after all that, give up. */
	if (!intel_panel_preferred_fixed_mode(connector))
@@ -1002,7 +1004,7 @@ void intel_lvds_init(struct drm_i915_private *i915)
	intel_backlight_setup(connector, INVALID_PIPE);

	lvds_encoder->is_dual_link = compute_is_dual_link_lvds(lvds_encoder);
	drm_dbg_kms(&i915->drm, "detected %s-link lvds configuration\n",
	drm_dbg_kms(display->drm, "detected %s-link lvds configuration\n",
		    lvds_encoder->is_dual_link ? "dual" : "single");

	lvds_encoder->a3_power = lvds & LVDS_A3_POWER_MASK;
@@ -1010,7 +1012,7 @@ void intel_lvds_init(struct drm_i915_private *i915)
	return;

failed:
	drm_dbg_kms(&i915->drm, "No LVDS modes found, disabling.\n");
	drm_dbg_kms(display->drm, "No LVDS modes found, disabling.\n");
	drm_connector_cleanup(&connector->base);
	drm_encoder_cleanup(&encoder->base);
	kfree(lvds_encoder);
+9 −9
Original line number Diff line number Diff line
@@ -11,28 +11,28 @@
#include "i915_reg_defs.h"

enum pipe;
struct drm_i915_private;
struct intel_display;

#ifdef I915
bool intel_lvds_port_enabled(struct drm_i915_private *dev_priv,
bool intel_lvds_port_enabled(struct intel_display *display,
			     i915_reg_t lvds_reg, enum pipe *pipe);
void intel_lvds_init(struct drm_i915_private *dev_priv);
struct intel_encoder *intel_get_lvds_encoder(struct drm_i915_private *dev_priv);
bool intel_is_dual_link_lvds(struct drm_i915_private *dev_priv);
void intel_lvds_init(struct intel_display *display);
struct intel_encoder *intel_get_lvds_encoder(struct intel_display *display);
bool intel_is_dual_link_lvds(struct intel_display *display);
#else
static inline bool intel_lvds_port_enabled(struct drm_i915_private *dev_priv,
static inline bool intel_lvds_port_enabled(struct intel_display *display,
					   i915_reg_t lvds_reg, enum pipe *pipe)
{
	return false;
}
static inline void intel_lvds_init(struct drm_i915_private *dev_priv)
static inline void intel_lvds_init(struct intel_display *display)
{
}
static inline struct intel_encoder *intel_get_lvds_encoder(struct drm_i915_private *dev_priv)
static inline struct intel_encoder *intel_get_lvds_encoder(struct intel_display *display)
{
	return NULL;
}
static inline bool intel_is_dual_link_lvds(struct drm_i915_private *dev_priv)
static inline bool intel_is_dual_link_lvds(struct intel_display *display)
{
	return false;
}
Loading