Commit 28cbe92b authored by Andrzej Hajda's avatar Andrzej Hajda Committed by Jani Nikula
Browse files

drm/i915/display/vlv: use intel_de_rmw if possible

parent fceeca7f
Loading
Loading
Loading
Loading
+37 −95
Original line number Original line Diff line number Diff line
@@ -331,32 +331,23 @@ static bool glk_dsi_enable_io(struct intel_encoder *encoder)
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 tmp;
	bool cold_boot = false;
	bool cold_boot = false;


	/* Set the MIPI mode
	/* Set the MIPI mode
	 * If MIPI_Mode is off, then writing to LP_Wake bit is not reflecting.
	 * If MIPI_Mode is off, then writing to LP_Wake bit is not reflecting.
	 * Power ON MIPI IO first and then write into IO reset and LP wake bits
	 * Power ON MIPI IO first and then write into IO reset and LP wake bits
	 */
	 */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports)
		tmp = intel_de_read(dev_priv, MIPI_CTRL(port));
		intel_de_rmw(dev_priv, MIPI_CTRL(port), 0, GLK_MIPIIO_ENABLE);
		intel_de_write(dev_priv, MIPI_CTRL(port),
			       tmp | GLK_MIPIIO_ENABLE);
	}


	/* Put the IO into reset */
	/* Put the IO into reset */
	tmp = intel_de_read(dev_priv, MIPI_CTRL(PORT_A));
	intel_de_rmw(dev_priv, MIPI_CTRL(PORT_A), GLK_MIPIIO_RESET_RELEASED, 0);
	tmp &= ~GLK_MIPIIO_RESET_RELEASED;
	intel_de_write(dev_priv, MIPI_CTRL(PORT_A), tmp);


	/* Program LP Wake */
	/* Program LP Wake */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
		tmp = intel_de_read(dev_priv, MIPI_CTRL(port));
		u32 tmp = intel_de_read(dev_priv, MIPI_DEVICE_READY(port));
		if (!(intel_de_read(dev_priv, MIPI_DEVICE_READY(port)) & DEVICE_READY))
		intel_de_rmw(dev_priv, MIPI_CTRL(port),
			tmp &= ~GLK_LP_WAKE;
			     GLK_LP_WAKE, (tmp & DEVICE_READY) ? GLK_LP_WAKE : 0);
		else
			tmp |= GLK_LP_WAKE;
		intel_de_write(dev_priv, MIPI_CTRL(port), tmp);
	}
	}


	/* Wait for Pwr ACK */
	/* Wait for Pwr ACK */
@@ -380,7 +371,6 @@ static void glk_dsi_device_ready(struct intel_encoder *encoder)
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 val;


	/* Wait for MIPI PHY status bit to set */
	/* Wait for MIPI PHY status bit to set */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
@@ -390,24 +380,18 @@ static void glk_dsi_device_ready(struct intel_encoder *encoder)
	}
	}


	/* Get IO out of reset */
	/* Get IO out of reset */
	val = intel_de_read(dev_priv, MIPI_CTRL(PORT_A));
	intel_de_rmw(dev_priv, MIPI_CTRL(PORT_A), 0, GLK_MIPIIO_RESET_RELEASED);
	intel_de_write(dev_priv, MIPI_CTRL(PORT_A),
		       val | GLK_MIPIIO_RESET_RELEASED);


	/* Get IO out of Low power state*/
	/* Get IO out of Low power state*/
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
		if (!(intel_de_read(dev_priv, MIPI_DEVICE_READY(port)) & DEVICE_READY)) {
		if (!(intel_de_read(dev_priv, MIPI_DEVICE_READY(port)) & DEVICE_READY)) {
			val = intel_de_read(dev_priv, MIPI_DEVICE_READY(port));
			intel_de_rmw(dev_priv, MIPI_DEVICE_READY(port),
			val &= ~ULPS_STATE_MASK;
				     ULPS_STATE_MASK, DEVICE_READY);
			val |= DEVICE_READY;
			intel_de_write(dev_priv, MIPI_DEVICE_READY(port), val);
			usleep_range(10, 15);
			usleep_range(10, 15);
		} else {
		} else {
			/* Enter ULPS */
			/* Enter ULPS */
			val = intel_de_read(dev_priv, MIPI_DEVICE_READY(port));
			intel_de_rmw(dev_priv, MIPI_DEVICE_READY(port),
			val &= ~ULPS_STATE_MASK;
				     ULPS_STATE_MASK, ULPS_STATE_ENTER | DEVICE_READY);
			val |= (ULPS_STATE_ENTER | DEVICE_READY);
			intel_de_write(dev_priv, MIPI_DEVICE_READY(port), val);


			/* Wait for ULPS active */
			/* Wait for ULPS active */
			if (intel_de_wait_for_clear(dev_priv, MIPI_CTRL(port),
			if (intel_de_wait_for_clear(dev_priv, MIPI_CTRL(port),
@@ -415,20 +399,15 @@ static void glk_dsi_device_ready(struct intel_encoder *encoder)
				drm_err(&dev_priv->drm, "ULPS not active\n");
				drm_err(&dev_priv->drm, "ULPS not active\n");


			/* Exit ULPS */
			/* Exit ULPS */
			val = intel_de_read(dev_priv, MIPI_DEVICE_READY(port));
			intel_de_rmw(dev_priv, MIPI_DEVICE_READY(port),
			val &= ~ULPS_STATE_MASK;
				     ULPS_STATE_MASK, ULPS_STATE_EXIT | DEVICE_READY);
			val |= (ULPS_STATE_EXIT | DEVICE_READY);
			intel_de_write(dev_priv, MIPI_DEVICE_READY(port), val);


			/* Enter Normal Mode */
			/* Enter Normal Mode */
			val = intel_de_read(dev_priv, MIPI_DEVICE_READY(port));
			intel_de_rmw(dev_priv, MIPI_DEVICE_READY(port),
			val &= ~ULPS_STATE_MASK;
				     ULPS_STATE_MASK,
			val |= (ULPS_STATE_NORMAL_OPERATION | DEVICE_READY);
				     ULPS_STATE_NORMAL_OPERATION | DEVICE_READY);
			intel_de_write(dev_priv, MIPI_DEVICE_READY(port), val);


			val = intel_de_read(dev_priv, MIPI_CTRL(port));
			intel_de_rmw(dev_priv, MIPI_CTRL(port), GLK_LP_WAKE, 0);
			val &= ~GLK_LP_WAKE;
			intel_de_write(dev_priv, MIPI_CTRL(port), val);
		}
		}
	}
	}


@@ -460,9 +439,7 @@ static void bxt_dsi_device_ready(struct intel_encoder *encoder)


	/* Enable MIPI PHY transparent latch */
	/* Enable MIPI PHY transparent latch */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
		val = intel_de_read(dev_priv, BXT_MIPI_PORT_CTRL(port));
		intel_de_rmw(dev_priv, BXT_MIPI_PORT_CTRL(port), 0, LP_OUTPUT_HOLD);
		intel_de_write(dev_priv, BXT_MIPI_PORT_CTRL(port),
			       val | LP_OUTPUT_HOLD);
		usleep_range(2000, 2500);
		usleep_range(2000, 2500);
	}
	}


@@ -482,7 +459,6 @@ static void vlv_dsi_device_ready(struct intel_encoder *encoder)
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 val;


	drm_dbg_kms(&dev_priv->drm, "\n");
	drm_dbg_kms(&dev_priv->drm, "\n");


@@ -505,9 +481,7 @@ static void vlv_dsi_device_ready(struct intel_encoder *encoder)
		 * Common bit for both MIPI Port A & MIPI Port C
		 * Common bit for both MIPI Port A & MIPI Port C
		 * No similar bit in MIPI Port C reg
		 * No similar bit in MIPI Port C reg
		 */
		 */
		val = intel_de_read(dev_priv, MIPI_PORT_CTRL(PORT_A));
		intel_de_rmw(dev_priv, MIPI_PORT_CTRL(PORT_A), 0, LP_OUTPUT_HOLD);
		intel_de_write(dev_priv, MIPI_PORT_CTRL(PORT_A),
			       val | LP_OUTPUT_HOLD);
		usleep_range(1000, 1500);
		usleep_range(1000, 1500);


		intel_de_write(dev_priv, MIPI_DEVICE_READY(port),
		intel_de_write(dev_priv, MIPI_DEVICE_READY(port),
@@ -537,15 +511,11 @@ static void glk_dsi_enter_low_power_mode(struct intel_encoder *encoder)
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 val;


	/* Enter ULPS */
	/* Enter ULPS */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports)
		val = intel_de_read(dev_priv, MIPI_DEVICE_READY(port));
		intel_de_rmw(dev_priv, MIPI_DEVICE_READY(port),
		val &= ~ULPS_STATE_MASK;
			     ULPS_STATE_MASK, ULPS_STATE_ENTER | DEVICE_READY);
		val |= (ULPS_STATE_ENTER | DEVICE_READY);
		intel_de_write(dev_priv, MIPI_DEVICE_READY(port), val);
	}


	/* Wait for MIPI PHY status bit to unset */
	/* Wait for MIPI PHY status bit to unset */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
@@ -568,12 +538,9 @@ static void glk_dsi_disable_mipi_io(struct intel_encoder *encoder)
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 tmp;


	/* Put the IO into reset */
	/* Put the IO into reset */
	tmp = intel_de_read(dev_priv, MIPI_CTRL(PORT_A));
	intel_de_rmw(dev_priv, MIPI_CTRL(PORT_A), GLK_MIPIIO_RESET_RELEASED, 0);
	tmp &= ~GLK_MIPIIO_RESET_RELEASED;
	intel_de_write(dev_priv, MIPI_CTRL(PORT_A), tmp);


	/* Wait for MIPI PHY status bit to unset */
	/* Wait for MIPI PHY status bit to unset */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
@@ -583,11 +550,8 @@ static void glk_dsi_disable_mipi_io(struct intel_encoder *encoder)
	}
	}


	/* Clear MIPI mode */
	/* Clear MIPI mode */
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports)
		tmp = intel_de_read(dev_priv, MIPI_CTRL(port));
		intel_de_rmw(dev_priv, MIPI_CTRL(port), GLK_MIPIIO_ENABLE, 0);
		tmp &= ~GLK_MIPIIO_ENABLE;
		intel_de_write(dev_priv, MIPI_CTRL(port), tmp);
	}
}
}


static void glk_dsi_clear_device_ready(struct intel_encoder *encoder)
static void glk_dsi_clear_device_ready(struct intel_encoder *encoder)
@@ -607,7 +571,6 @@ static void vlv_dsi_clear_device_ready(struct intel_encoder *encoder)
		/* Common bit for both MIPI Port A & MIPI Port C on VLV/CHV */
		/* Common bit for both MIPI Port A & MIPI Port C on VLV/CHV */
		i915_reg_t port_ctrl = IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv) ?
		i915_reg_t port_ctrl = IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv) ?
			BXT_MIPI_PORT_CTRL(port) : MIPI_PORT_CTRL(PORT_A);
			BXT_MIPI_PORT_CTRL(port) : MIPI_PORT_CTRL(PORT_A);
		u32 val;


		intel_de_write(dev_priv, MIPI_DEVICE_READY(port),
		intel_de_write(dev_priv, MIPI_DEVICE_READY(port),
			       DEVICE_READY | ULPS_STATE_ENTER);
			       DEVICE_READY | ULPS_STATE_ENTER);
@@ -631,8 +594,7 @@ static void vlv_dsi_clear_device_ready(struct intel_encoder *encoder)
			drm_err(&dev_priv->drm, "DSI LP not going Low\n");
			drm_err(&dev_priv->drm, "DSI LP not going Low\n");


		/* Disable MIPI PHY transparent latch */
		/* Disable MIPI PHY transparent latch */
		val = intel_de_read(dev_priv, port_ctrl);
		intel_de_rmw(dev_priv, port_ctrl, LP_OUTPUT_HOLD, 0);
		intel_de_write(dev_priv, port_ctrl, val & ~LP_OUTPUT_HOLD);
		usleep_range(1000, 1500);
		usleep_range(1000, 1500);


		intel_de_write(dev_priv, MIPI_DEVICE_READY(port), 0x00);
		intel_de_write(dev_priv, MIPI_DEVICE_READY(port), 0x00);
@@ -703,11 +665,9 @@ static void intel_dsi_port_disable(struct intel_encoder *encoder)
	for_each_dsi_port(port, intel_dsi->ports) {
	for_each_dsi_port(port, intel_dsi->ports) {
		i915_reg_t port_ctrl = IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv) ?
		i915_reg_t port_ctrl = IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv) ?
			BXT_MIPI_PORT_CTRL(port) : MIPI_PORT_CTRL(port);
			BXT_MIPI_PORT_CTRL(port) : MIPI_PORT_CTRL(port);
		u32 temp;


		/* de-assert ip_tg_enable signal */
		/* de-assert ip_tg_enable signal */
		temp = intel_de_read(dev_priv, port_ctrl);
		intel_de_rmw(dev_priv, port_ctrl, DPI_ENABLE, 0);
		intel_de_write(dev_priv, port_ctrl, temp & ~DPI_ENABLE);
		intel_de_posting_read(dev_priv, port_ctrl);
		intel_de_posting_read(dev_priv, port_ctrl);
	}
	}
}
}
@@ -781,7 +741,6 @@ static void intel_dsi_pre_enable(struct intel_atomic_state *state,
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	enum pipe pipe = crtc->pipe;
	enum pipe pipe = crtc->pipe;
	enum port port;
	enum port port;
	u32 val;
	bool glk_cold_boot = false;
	bool glk_cold_boot = false;


	drm_dbg_kms(&dev_priv->drm, "\n");
	drm_dbg_kms(&dev_priv->drm, "\n");
@@ -804,9 +763,7 @@ static void intel_dsi_pre_enable(struct intel_atomic_state *state,


	if (IS_BROXTON(dev_priv)) {
	if (IS_BROXTON(dev_priv)) {
		/* Add MIPI IO reset programming for modeset */
		/* Add MIPI IO reset programming for modeset */
		val = intel_de_read(dev_priv, BXT_P_CR_GT_DISP_PWRON);
		intel_de_rmw(dev_priv, BXT_P_CR_GT_DISP_PWRON, 0, MIPIO_RST_CTRL);
		intel_de_write(dev_priv, BXT_P_CR_GT_DISP_PWRON,
			       val | MIPIO_RST_CTRL);


		/* Power up DSI regulator */
		/* Power up DSI regulator */
		intel_de_write(dev_priv, BXT_P_DSI_REGULATOR_CFG, STAP_SELECT);
		intel_de_write(dev_priv, BXT_P_DSI_REGULATOR_CFG, STAP_SELECT);
@@ -814,12 +771,9 @@ static void intel_dsi_pre_enable(struct intel_atomic_state *state,
	}
	}


	if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) {
	if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) {
		u32 val;

		/* Disable DPOunit clock gating, can stall pipe */
		/* Disable DPOunit clock gating, can stall pipe */
		val = intel_de_read(dev_priv, DSPCLK_GATE_D(dev_priv));
		intel_de_rmw(dev_priv, DSPCLK_GATE_D(dev_priv),
		val |= DPOUNIT_CLOCK_GATE_DISABLE;
			     0, DPOUNIT_CLOCK_GATE_DISABLE);
		intel_de_write(dev_priv, DSPCLK_GATE_D(dev_priv), val);
	}
	}


	if (!IS_GEMINILAKE(dev_priv))
	if (!IS_GEMINILAKE(dev_priv))
@@ -943,7 +897,6 @@ static void intel_dsi_post_disable(struct intel_atomic_state *state,
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 val;


	drm_dbg_kms(&dev_priv->drm, "\n");
	drm_dbg_kms(&dev_priv->drm, "\n");


@@ -981,21 +934,16 @@ static void intel_dsi_post_disable(struct intel_atomic_state *state,
			       HS_IO_CTRL_SELECT);
			       HS_IO_CTRL_SELECT);


		/* Add MIPI IO reset programming for modeset */
		/* Add MIPI IO reset programming for modeset */
		val = intel_de_read(dev_priv, BXT_P_CR_GT_DISP_PWRON);
		intel_de_rmw(dev_priv, BXT_P_CR_GT_DISP_PWRON, MIPIO_RST_CTRL, 0);
		intel_de_write(dev_priv, BXT_P_CR_GT_DISP_PWRON,
			       val & ~MIPIO_RST_CTRL);
	}
	}


	if (IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv)) {
	if (IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv)) {
		bxt_dsi_pll_disable(encoder);
		bxt_dsi_pll_disable(encoder);
	} else {
	} else {
		u32 val;

		vlv_dsi_pll_disable(encoder);
		vlv_dsi_pll_disable(encoder);


		val = intel_de_read(dev_priv, DSPCLK_GATE_D(dev_priv));
		intel_de_rmw(dev_priv, DSPCLK_GATE_D(dev_priv),
		val &= ~DPOUNIT_CLOCK_GATE_DISABLE;
			     DPOUNIT_CLOCK_GATE_DISABLE, 0);
		intel_de_write(dev_priv, DSPCLK_GATE_D(dev_priv), val);
	}
	}


	/* Assert reset */
	/* Assert reset */
@@ -1426,11 +1374,8 @@ static void intel_dsi_prepare(struct intel_encoder *intel_encoder,
		} else if (IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv)) {
		} else if (IS_GEMINILAKE(dev_priv) || IS_BROXTON(dev_priv)) {
			enum pipe pipe = crtc->pipe;
			enum pipe pipe = crtc->pipe;


			tmp = intel_de_read(dev_priv, MIPI_CTRL(port));
			intel_de_rmw(dev_priv, MIPI_CTRL(port),
			tmp &= ~BXT_PIPE_SELECT_MASK;
				     BXT_PIPE_SELECT_MASK, BXT_PIPE_SELECT(pipe));

			tmp |= BXT_PIPE_SELECT(pipe);
			intel_de_write(dev_priv, MIPI_CTRL(port), tmp);
		}
		}


		/* XXX: why here, why like this? handling in irq handler?! */
		/* XXX: why here, why like this? handling in irq handler?! */
@@ -1599,7 +1544,6 @@ static void intel_dsi_unprepare(struct intel_encoder *encoder)
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 val;


	if (IS_GEMINILAKE(dev_priv))
	if (IS_GEMINILAKE(dev_priv))
		return;
		return;
@@ -1614,9 +1558,7 @@ static void intel_dsi_unprepare(struct intel_encoder *encoder)
			vlv_dsi_reset_clocks(encoder, port);
			vlv_dsi_reset_clocks(encoder, port);
		intel_de_write(dev_priv, MIPI_EOT_DISABLE(port), CLOCKSTOP);
		intel_de_write(dev_priv, MIPI_EOT_DISABLE(port), CLOCKSTOP);


		val = intel_de_read(dev_priv, MIPI_DSI_FUNC_PRG(port));
		intel_de_rmw(dev_priv, MIPI_DSI_FUNC_PRG(port), VID_MODE_FORMAT_MASK, 0);
		val &= ~VID_MODE_FORMAT_MASK;
		intel_de_write(dev_priv, MIPI_DSI_FUNC_PRG(port), val);


		intel_de_write(dev_priv, MIPI_DEVICE_READY(port), 0x1);
		intel_de_write(dev_priv, MIPI_DEVICE_READY(port), 0x1);
	}
	}
+4 −14
Original line number Original line Diff line number Diff line
@@ -302,13 +302,10 @@ bool bxt_dsi_pll_is_enabled(struct drm_i915_private *dev_priv)
void bxt_dsi_pll_disable(struct intel_encoder *encoder)
void bxt_dsi_pll_disable(struct intel_encoder *encoder)
{
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	u32 val;


	drm_dbg_kms(&dev_priv->drm, "\n");
	drm_dbg_kms(&dev_priv->drm, "\n");


	val = intel_de_read(dev_priv, BXT_DSI_PLL_ENABLE);
	intel_de_rmw(dev_priv, BXT_DSI_PLL_ENABLE, BXT_DSI_PLL_DO_ENABLE, 0);
	val &= ~BXT_DSI_PLL_DO_ENABLE;
	intel_de_write(dev_priv, BXT_DSI_PLL_ENABLE, val);


	/*
	/*
	 * PLL lock should deassert within 200us.
	 * PLL lock should deassert within 200us.
@@ -542,7 +539,6 @@ void bxt_dsi_pll_enable(struct intel_encoder *encoder,
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	struct intel_dsi *intel_dsi = enc_to_intel_dsi(encoder);
	enum port port;
	enum port port;
	u32 val;


	drm_dbg_kms(&dev_priv->drm, "\n");
	drm_dbg_kms(&dev_priv->drm, "\n");


@@ -559,9 +555,7 @@ void bxt_dsi_pll_enable(struct intel_encoder *encoder,
	}
	}


	/* Enable DSI PLL */
	/* Enable DSI PLL */
	val = intel_de_read(dev_priv, BXT_DSI_PLL_ENABLE);
	intel_de_rmw(dev_priv, BXT_DSI_PLL_ENABLE, 0, BXT_DSI_PLL_DO_ENABLE);
	val |= BXT_DSI_PLL_DO_ENABLE;
	intel_de_write(dev_priv, BXT_DSI_PLL_ENABLE, val);


	/* Timeout and fail if PLL not locked */
	/* Timeout and fail if PLL not locked */
	if (intel_de_wait_for_set(dev_priv, BXT_DSI_PLL_ENABLE,
	if (intel_de_wait_for_set(dev_priv, BXT_DSI_PLL_ENABLE,
@@ -589,13 +583,9 @@ void bxt_dsi_reset_clocks(struct intel_encoder *encoder, enum port port)
		tmp &= ~(BXT_MIPI_RX_ESCLK_LOWER_FIXDIV_MASK(port));
		tmp &= ~(BXT_MIPI_RX_ESCLK_LOWER_FIXDIV_MASK(port));
		intel_de_write(dev_priv, BXT_MIPI_CLOCK_CTL, tmp);
		intel_de_write(dev_priv, BXT_MIPI_CLOCK_CTL, tmp);
	} else {
	} else {
		tmp = intel_de_read(dev_priv, MIPIO_TXESC_CLK_DIV1);
		intel_de_rmw(dev_priv, MIPIO_TXESC_CLK_DIV1, GLK_TX_ESC_CLK_DIV1_MASK, 0);
		tmp &= ~GLK_TX_ESC_CLK_DIV1_MASK;
		intel_de_write(dev_priv, MIPIO_TXESC_CLK_DIV1, tmp);


		tmp = intel_de_read(dev_priv, MIPIO_TXESC_CLK_DIV2);
		intel_de_rmw(dev_priv, MIPIO_TXESC_CLK_DIV2, GLK_TX_ESC_CLK_DIV2_MASK, 0);
		tmp &= ~GLK_TX_ESC_CLK_DIV2_MASK;
		intel_de_write(dev_priv, MIPIO_TXESC_CLK_DIV2, tmp);
	}
	}
	intel_de_write(dev_priv, MIPI_EOT_DISABLE(port), CLOCKSTOP);
	intel_de_write(dev_priv, MIPI_EOT_DISABLE(port), CLOCKSTOP);
}
}