intel_ddi.c 128.0 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
/*
 * Copyright © 2012 Intel Corporation
 *
 * Permission is hereby granted, free of charge, to any person obtaining a
 * copy of this software and associated documentation files (the "Software"),
 * to deal in the Software without restriction, including without limitation
 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
 * and/or sell copies of the Software, and to permit persons to whom the
 * Software is furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice (including the next
 * paragraph) shall be included in all copies or substantial portions of the
 * Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 * IN THE SOFTWARE.
 *
 * Authors:
 *    Eugeni Dodonov <eugeni.dodonov@intel.com>
 *
 */

28
#include <drm/drm_scdc_helper.h>
29

30
#include "i915_drv.h"
31
#include "i915_trace.h"
32
#include "intel_audio.h"
33
#include "intel_combo_phy.h"
34
#include "intel_connector.h"
35
#include "intel_ddi.h"
36
#include "intel_ddi_buf_trans.h"
37
#include "intel_display_types.h"
38
#include "intel_dp.h"
39
#include "intel_dp_link_training.h"
40
#include "intel_dp_mst.h"
41
#include "intel_dpio_phy.h"
42
#include "intel_dsi.h"
43
#include "intel_fdi.h"
44
#include "intel_fifo_underrun.h"
45
#include "intel_gmbus.h"
46
#include "intel_hdcp.h"
47
#include "intel_hdmi.h"
48
#include "intel_hotplug.h"
49
#include "intel_lspcon.h"
50
#include "intel_panel.h"
51
#include "intel_pps.h"
52
#include "intel_psr.h"
53
#include "intel_sprite.h"
54
#include "intel_tc.h"
55
#include "intel_vdsc.h"
56
#include "intel_vrr.h"
57
#include "skl_scaler.h"
58
#include "skl_universal_plane.h"
59

60 61 62 63 64 65 66 67 68 69 70 71 72
static const u8 index_to_dp_signal_levels[] = {
	[0] = DP_TRAIN_VOLTAGE_SWING_LEVEL_0 | DP_TRAIN_PRE_EMPH_LEVEL_0,
	[1] = DP_TRAIN_VOLTAGE_SWING_LEVEL_0 | DP_TRAIN_PRE_EMPH_LEVEL_1,
	[2] = DP_TRAIN_VOLTAGE_SWING_LEVEL_0 | DP_TRAIN_PRE_EMPH_LEVEL_2,
	[3] = DP_TRAIN_VOLTAGE_SWING_LEVEL_0 | DP_TRAIN_PRE_EMPH_LEVEL_3,
	[4] = DP_TRAIN_VOLTAGE_SWING_LEVEL_1 | DP_TRAIN_PRE_EMPH_LEVEL_0,
	[5] = DP_TRAIN_VOLTAGE_SWING_LEVEL_1 | DP_TRAIN_PRE_EMPH_LEVEL_1,
	[6] = DP_TRAIN_VOLTAGE_SWING_LEVEL_1 | DP_TRAIN_PRE_EMPH_LEVEL_2,
	[7] = DP_TRAIN_VOLTAGE_SWING_LEVEL_2 | DP_TRAIN_PRE_EMPH_LEVEL_0,
	[8] = DP_TRAIN_VOLTAGE_SWING_LEVEL_2 | DP_TRAIN_PRE_EMPH_LEVEL_1,
	[9] = DP_TRAIN_VOLTAGE_SWING_LEVEL_3 | DP_TRAIN_PRE_EMPH_LEVEL_0,
};

73 74
static int intel_ddi_hdmi_level(struct intel_encoder *encoder,
				const struct intel_crtc_state *crtc_state)
75
{
76
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
77
	int n_entries, level, default_entry;
78

79 80
	n_entries = intel_ddi_hdmi_num_entries(encoder, crtc_state, &default_entry);
	if (n_entries == 0)
81
		return 0;
82 83
	level = intel_bios_hdmi_level_shift(encoder);
	if (level < 0)
84 85
		level = default_entry;

86
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
87
		level = n_entries - 1;
88

89
	return level;
90 91
}

92 93
/*
 * Starting with Haswell, DDI port buffers must be programmed with correct
94 95
 * values in advance. This function programs the correct values for
 * DP/eDP/FDI use cases.
96
 */
97 98
void intel_prepare_dp_ddi_buffers(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state)
99
{
100
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
101
	u32 iboost_bit = 0;
102
	int i, n_entries;
103
	enum port port = encoder->port;
104
	const struct ddi_buf_trans *ddi_translations;
105

106 107 108 109
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_ANALOG))
		ddi_translations = intel_ddi_get_buf_trans_fdi(dev_priv,
							       &n_entries);
	else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP))
110
		ddi_translations = intel_ddi_get_buf_trans_edp(encoder,
111
							       &n_entries);
112
	else
113
		ddi_translations = intel_ddi_get_buf_trans_dp(encoder,
114
							      &n_entries);
115

116
	/* If we're boosting the current, set bit 31 of trans1 */
117
	if (IS_GEN9_BC(dev_priv) && intel_bios_dp_boost_level(encoder))
118
		iboost_bit = DDI_BUF_BALANCE_LEG_ENABLE;
119

120
	for (i = 0; i < n_entries; i++) {
121 122 123 124
		intel_de_write(dev_priv, DDI_BUF_TRANS_LO(port, i),
			       ddi_translations[i].trans1 | iboost_bit);
		intel_de_write(dev_priv, DDI_BUF_TRANS_HI(port, i),
			       ddi_translations[i].trans2);
125
	}
126 127 128 129 130 131 132
}

/*
 * Starting with Haswell, DDI port buffers must be programmed with correct
 * values in advance. This function programs the correct values for
 * HDMI/DVI use cases.
 */
133
static void intel_prepare_hdmi_ddi_buffers(struct intel_encoder *encoder,
134
					   int level)
135 136 137
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	u32 iboost_bit = 0;
138
	int n_entries;
139
	enum port port = encoder->port;
140
	const struct ddi_buf_trans *ddi_translations;
141

142
	ddi_translations = intel_ddi_get_buf_trans_hdmi(encoder, &n_entries);
143

144
	if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
145
		return;
146
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
147
		level = n_entries - 1;
148

149
	/* If we're boosting the current, set bit 31 of trans1 */
150
	if (IS_GEN9_BC(dev_priv) && intel_bios_hdmi_boost_level(encoder))
151
		iboost_bit = DDI_BUF_BALANCE_LEG_ENABLE;
152

153
	/* Entry 9 is for HDMI: */
154 155 156 157
	intel_de_write(dev_priv, DDI_BUF_TRANS_LO(port, 9),
		       ddi_translations[level].trans1 | iboost_bit);
	intel_de_write(dev_priv, DDI_BUF_TRANS_HI(port, 9),
		       ddi_translations[level].trans2);
158 159
}

160 161
void intel_wait_ddi_buf_idle(struct drm_i915_private *dev_priv,
			     enum port port)
162
{
163 164 165
	if (IS_BROXTON(dev_priv)) {
		udelay(16);
		return;
166
	}
167 168 169 170 171

	if (wait_for_us((intel_de_read(dev_priv, DDI_BUF_CTL(port)) &
			 DDI_BUF_IS_IDLE), 8))
		drm_err(&dev_priv->drm, "Timeout waiting for DDI BUF %c to get idle\n",
			port_name(port));
172
}
173

174 175 176 177 178 179 180 181 182 183 184 185 186 187 188
static void intel_wait_ddi_buf_active(struct drm_i915_private *dev_priv,
				      enum port port)
{
	/* Wait > 518 usecs for DDI_BUF_CTL to be non idle */
	if (INTEL_GEN(dev_priv) < 10 && !IS_GEMINILAKE(dev_priv)) {
		usleep_range(518, 1000);
		return;
	}

	if (wait_for_us(!(intel_de_read(dev_priv, DDI_BUF_CTL(port)) &
			  DDI_BUF_IS_IDLE), 500))
		drm_err(&dev_priv->drm, "Timeout waiting for DDI BUF %c to get active\n",
			port_name(port));
}

189
static u32 hsw_pll_to_ddi_pll_sel(const struct intel_shared_dpll *pll)
190
{
191
	switch (pll->info->id) {
192 193 194 195 196 197 198 199 200 201 202 203 204
	case DPLL_ID_WRPLL1:
		return PORT_CLK_SEL_WRPLL1;
	case DPLL_ID_WRPLL2:
		return PORT_CLK_SEL_WRPLL2;
	case DPLL_ID_SPLL:
		return PORT_CLK_SEL_SPLL;
	case DPLL_ID_LCPLL_810:
		return PORT_CLK_SEL_LCPLL_810;
	case DPLL_ID_LCPLL_1350:
		return PORT_CLK_SEL_LCPLL_1350;
	case DPLL_ID_LCPLL_2700:
		return PORT_CLK_SEL_LCPLL_2700;
	default:
205
		MISSING_CASE(pll->info->id);
206 207 208 209
		return PORT_CLK_SEL_NONE;
	}
}

210
static u32 icl_pll_to_ddi_clk_sel(struct intel_encoder *encoder,
211
				  const struct intel_crtc_state *crtc_state)
212
{
213 214
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
	int clock = crtc_state->port_clock;
215 216 217 218
	const enum intel_dpll_id id = pll->info->id;

	switch (id) {
	default:
219 220 221 222
		/*
		 * DPLL_ID_ICL_DPLL0 and DPLL_ID_ICL_DPLL1 should not be used
		 * here, so do warn if this get passed in
		 */
223 224
		MISSING_CASE(id);
		return DDI_CLK_SEL_NONE;
225 226 227 228 229 230 231 232 233 234 235 236
	case DPLL_ID_ICL_TBTPLL:
		switch (clock) {
		case 162000:
			return DDI_CLK_SEL_TBT_162;
		case 270000:
			return DDI_CLK_SEL_TBT_270;
		case 540000:
			return DDI_CLK_SEL_TBT_540;
		case 810000:
			return DDI_CLK_SEL_TBT_810;
		default:
			MISSING_CASE(clock);
237
			return DDI_CLK_SEL_NONE;
238
		}
239 240 241 242
	case DPLL_ID_ICL_MGPLL1:
	case DPLL_ID_ICL_MGPLL2:
	case DPLL_ID_ICL_MGPLL3:
	case DPLL_ID_ICL_MGPLL4:
243 244
	case DPLL_ID_TGL_MGPLL5:
	case DPLL_ID_TGL_MGPLL6:
245 246 247 248
		return DDI_CLK_SEL_MG;
	}
}

249 250
static void intel_ddi_init_dp_buf_reg(struct intel_encoder *encoder,
				      const struct intel_crtc_state *crtc_state)
251
{
252
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
253
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
254

255
	intel_dp->DP = dig_port->saved_port_bits |
256
		DDI_BUF_CTL_ENABLE | DDI_BUF_TRANS_SELECT(0);
257
	intel_dp->DP |= DDI_PORT_WIDTH(crtc_state->lane_count);
258 259
}

260 261 262
static int icl_calc_tbt_pll_link(struct drm_i915_private *dev_priv,
				 enum port port)
{
263
	u32 val = intel_de_read(dev_priv, DDI_CLK_SEL(port)) & DDI_CLK_SEL_MASK;
264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281

	switch (val) {
	case DDI_CLK_SEL_NONE:
		return 0;
	case DDI_CLK_SEL_TBT_162:
		return 162000;
	case DDI_CLK_SEL_TBT_270:
		return 270000;
	case DDI_CLK_SEL_TBT_540:
		return 540000;
	case DDI_CLK_SEL_TBT_810:
		return 810000;
	default:
		MISSING_CASE(val);
		return 0;
	}
}

282 283 284 285 286 287 288
static void ddi_dotclock_get(struct intel_crtc_state *pipe_config)
{
	int dotclock;

	if (pipe_config->has_pch_encoder)
		dotclock = intel_dotclock_calculate(pipe_config->port_clock,
						    &pipe_config->fdi_m_n);
289
	else if (intel_crtc_has_dp_encoder(pipe_config))
290 291
		dotclock = intel_dotclock_calculate(pipe_config->port_clock,
						    &pipe_config->dp_m_n);
292 293
	else if (pipe_config->has_hdmi_sink && pipe_config->pipe_bpp > 24)
		dotclock = pipe_config->port_clock * 24 / pipe_config->pipe_bpp;
294 295 296
	else
		dotclock = pipe_config->port_clock;

297 298
	if (pipe_config->output_format == INTEL_OUTPUT_FORMAT_YCBCR420 &&
	    !intel_crtc_has_dp_encoder(pipe_config))
299 300
		dotclock *= 2;

301 302 303
	if (pipe_config->pixel_multiplier)
		dotclock /= pipe_config->pixel_multiplier;

304
	pipe_config->hw.adjusted_mode.crtc_clock = dotclock;
305
}
306

307 308
static void intel_ddi_clock_get(struct intel_encoder *encoder,
				struct intel_crtc_state *pipe_config)
309
{
310
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
311
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
312

313
	if (intel_phy_is_tc(dev_priv, phy) &&
314 315 316 317 318
	    intel_get_shared_dpll_id(dev_priv, pipe_config->shared_dpll) ==
	    DPLL_ID_ICL_TBTPLL)
		pipe_config->port_clock = icl_calc_tbt_pll_link(dev_priv,
								encoder->port);
	else
319
		pipe_config->port_clock =
320 321
			intel_dpll_get_freq(dev_priv, pipe_config->shared_dpll,
					    &pipe_config->dpll_hw_state);
322 323

	ddi_dotclock_get(pipe_config);
324 325
}

326 327
void intel_ddi_set_dp_msa(const struct intel_crtc_state *crtc_state,
			  const struct drm_connector_state *conn_state)
328
{
329
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
330
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
331
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
332
	u32 temp;
333

334 335
	if (!intel_crtc_has_dp_encoder(crtc_state))
		return;
J
Jani Nikula 已提交
336

337
	drm_WARN_ON(&dev_priv->drm, transcoder_is_dsi(cpu_transcoder));
338

339
	temp = DP_MSA_MISC_SYNC_CLOCK;
340

341 342
	switch (crtc_state->pipe_bpp) {
	case 18:
343
		temp |= DP_MSA_MISC_6_BPC;
344 345
		break;
	case 24:
346
		temp |= DP_MSA_MISC_8_BPC;
347 348
		break;
	case 30:
349
		temp |= DP_MSA_MISC_10_BPC;
350 351
		break;
	case 36:
352
		temp |= DP_MSA_MISC_12_BPC;
353 354 355 356
		break;
	default:
		MISSING_CASE(crtc_state->pipe_bpp);
		break;
357
	}
358

359
	/* nonsense combination */
360 361
	drm_WARN_ON(&dev_priv->drm, crtc_state->limited_color_range &&
		    crtc_state->output_format != INTEL_OUTPUT_FORMAT_RGB);
362 363

	if (crtc_state->limited_color_range)
364
		temp |= DP_MSA_MISC_COLOR_CEA_RGB;
365

366 367 368
	/*
	 * As per DP 1.2 spec section 2.3.4.3 while sending
	 * YCBCR 444 signals we should program MSA MISC1/0 fields with
369
	 * colorspace information.
370 371
	 */
	if (crtc_state->output_format == INTEL_OUTPUT_FORMAT_YCBCR444)
372
		temp |= DP_MSA_MISC_COLOR_YCBCR_444_BT709;
373

374 375 376
	/*
	 * As per DP 1.4a spec section 2.2.4.3 [MSA Field for Indication
	 * of Color Encoding Format and Content Color Gamut] while sending
377 378
	 * YCBCR 420, HDR BT.2020 signals we should program MSA MISC1 fields
	 * which indicate VSC SDP for the Pixel Encoding/Colorimetry Format.
379
	 */
380
	if (intel_dp_needs_vsc_sdp(crtc_state, conn_state))
381
		temp |= DP_MSA_MISC_COLOR_VSC_SDP;
382

383
	intel_de_write(dev_priv, TRANS_MSA_MISC(cpu_transcoder), temp);
384 385
}

386 387 388 389 390 391 392 393
static u32 bdw_trans_port_sync_master_select(enum transcoder master_transcoder)
{
	if (master_transcoder == TRANSCODER_EDP)
		return 0;
	else
		return master_transcoder + 1;
}

394 395 396 397 398 399 400
/*
 * Returns the TRANS_DDI_FUNC_CTL value based on CRTC state.
 *
 * Only intended to be used by intel_ddi_enable_transcoder_func() and
 * intel_ddi_config_transcoder_func().
 */
static u32
401 402
intel_ddi_transcoder_func_reg_val_get(struct intel_encoder *encoder,
				      const struct intel_crtc_state *crtc_state)
403
{
404
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
405 406
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	enum pipe pipe = crtc->pipe;
407
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
408
	enum port port = encoder->port;
409
	u32 temp;
410

411 412
	/* Enable TRANS_DDI_FUNC_CTL for the pipe to work in HDMI mode */
	temp = TRANS_DDI_FUNC_ENABLE;
413 414 415 416
	if (INTEL_GEN(dev_priv) >= 12)
		temp |= TGL_TRANS_DDI_SELECT_PORT(port);
	else
		temp |= TRANS_DDI_SELECT_PORT(port);
417

418
	switch (crtc_state->pipe_bpp) {
419
	case 18:
420
		temp |= TRANS_DDI_BPC_6;
421 422
		break;
	case 24:
423
		temp |= TRANS_DDI_BPC_8;
424 425
		break;
	case 30:
426
		temp |= TRANS_DDI_BPC_10;
427 428
		break;
	case 36:
429
		temp |= TRANS_DDI_BPC_12;
430 431
		break;
	default:
432
		BUG();
433
	}
434

435
	if (crtc_state->hw.adjusted_mode.flags & DRM_MODE_FLAG_PVSYNC)
436
		temp |= TRANS_DDI_PVSYNC;
437
	if (crtc_state->hw.adjusted_mode.flags & DRM_MODE_FLAG_PHSYNC)
438
		temp |= TRANS_DDI_PHSYNC;
439

440 441 442
	if (cpu_transcoder == TRANSCODER_EDP) {
		switch (pipe) {
		case PIPE_A:
443 444 445 446
			/* On Haswell, can only use the always-on power well for
			 * eDP when not using the panel fitter, and when not
			 * using motion blur mitigation (which we don't
			 * support). */
447
			if (crtc_state->pch_pfit.force_thru)
448 449 450
				temp |= TRANS_DDI_EDP_INPUT_A_ONOFF;
			else
				temp |= TRANS_DDI_EDP_INPUT_A_ON;
451 452 453 454 455 456 457 458 459 460 461 462 463
			break;
		case PIPE_B:
			temp |= TRANS_DDI_EDP_INPUT_B_ONOFF;
			break;
		case PIPE_C:
			temp |= TRANS_DDI_EDP_INPUT_C_ONOFF;
			break;
		default:
			BUG();
			break;
		}
	}

464
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
465
		if (crtc_state->has_hdmi_sink)
466
			temp |= TRANS_DDI_MODE_SELECT_HDMI;
467
		else
468
			temp |= TRANS_DDI_MODE_SELECT_DVI;
S
Shashank Sharma 已提交
469 470

		if (crtc_state->hdmi_scrambling)
471
			temp |= TRANS_DDI_HDMI_SCRAMBLING;
S
Shashank Sharma 已提交
472 473
		if (crtc_state->hdmi_high_tmds_clock_ratio)
			temp |= TRANS_DDI_HIGH_TMDS_CHAR_RATE;
474
	} else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_ANALOG)) {
475
		temp |= TRANS_DDI_MODE_SELECT_FDI;
476
		temp |= (crtc_state->fdi_lanes - 1) << 1;
477
	} else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST)) {
478
		temp |= TRANS_DDI_MODE_SELECT_DP_MST;
479
		temp |= DDI_PORT_WIDTH(crtc_state->lane_count);
480

481 482 483 484
		if (INTEL_GEN(dev_priv) >= 12) {
			enum transcoder master;

			master = crtc_state->mst_master_transcoder;
485 486
			drm_WARN_ON(&dev_priv->drm,
				    master == INVALID_TRANSCODER);
487 488
			temp |= TRANS_DDI_MST_TRANSPORT_SELECT(master);
		}
489
	} else {
490 491
		temp |= TRANS_DDI_MODE_SELECT_DP_SST;
		temp |= DDI_PORT_WIDTH(crtc_state->lane_count);
492 493
	}

494 495 496 497 498 499 500 501 502
	if (IS_GEN_RANGE(dev_priv, 8, 10) &&
	    crtc_state->master_transcoder != INVALID_TRANSCODER) {
		u8 master_select =
			bdw_trans_port_sync_master_select(crtc_state->master_transcoder);

		temp |= TRANS_DDI_PORT_SYNC_ENABLE |
			TRANS_DDI_PORT_SYNC_MASTER_SELECT(master_select);
	}

503 504 505
	return temp;
}

506 507
void intel_ddi_enable_transcoder_func(struct intel_encoder *encoder,
				      const struct intel_crtc_state *crtc_state)
508
{
509
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
510 511
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
512 513 514 515 516 517

	if (INTEL_GEN(dev_priv) >= 11) {
		enum transcoder master_transcoder = crtc_state->master_transcoder;
		u32 ctl2 = 0;

		if (master_transcoder != INVALID_TRANSCODER) {
518 519
			u8 master_select =
				bdw_trans_port_sync_master_select(master_transcoder);
520

521
			ctl2 |= PORT_SYNC_MODE_ENABLE |
522
				PORT_SYNC_MODE_MASTER_SELECT(master_select);
523 524 525 526 527 528
		}

		intel_de_write(dev_priv,
			       TRANS_DDI_FUNC_CTL2(cpu_transcoder), ctl2);
	}

529 530 531
	intel_de_write(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder),
		       intel_ddi_transcoder_func_reg_val_get(encoder,
							     crtc_state));
532 533 534 535 536 537 538
}

/*
 * Same as intel_ddi_enable_transcoder_func(), but it does not set the enable
 * bit.
 */
static void
539 540
intel_ddi_config_transcoder_func(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
541
{
542
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
543 544
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
545
	u32 ctl;
546

547
	ctl = intel_ddi_transcoder_func_reg_val_get(encoder, crtc_state);
548 549
	ctl &= ~TRANS_DDI_FUNC_ENABLE;
	intel_de_write(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder), ctl);
550
}
551

552
void intel_ddi_disable_transcoder_func(const struct intel_crtc_state *crtc_state)
553
{
554
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
555 556
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
557
	u32 ctl;
558

559 560 561 562 563
	if (INTEL_GEN(dev_priv) >= 11)
		intel_de_write(dev_priv,
			       TRANS_DDI_FUNC_CTL2(cpu_transcoder), 0);

	ctl = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder));
564

565 566
	drm_WARN_ON(crtc->base.dev, ctl & TRANS_DDI_HDCP_SIGNALLING);

567
	ctl &= ~TRANS_DDI_FUNC_ENABLE;
568

569 570 571 572
	if (IS_GEN_RANGE(dev_priv, 8, 10))
		ctl &= ~(TRANS_DDI_PORT_SYNC_ENABLE |
			 TRANS_DDI_PORT_SYNC_MASTER_SELECT_MASK);

573
	if (INTEL_GEN(dev_priv) >= 12) {
574
		if (!intel_dp_mst_is_master_trans(crtc_state)) {
575
			ctl &= ~(TGL_TRANS_DDI_PORT_MASK |
576 577
				 TRANS_DDI_MODE_SELECT_MASK);
		}
578
	} else {
579
		ctl &= ~(TRANS_DDI_PORT_MASK | TRANS_DDI_MODE_SELECT_MASK);
580
	}
581

582
	intel_de_write(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder), ctl);
583 584 585

	if (dev_priv->quirks & QUIRK_INCREASE_DDI_DISABLED_TIME &&
	    intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
586 587
		drm_dbg_kms(&dev_priv->drm,
			    "Quirk Increase DDI disabled time\n");
588 589 590
		/* Quirk time at 100ms for reliable operation */
		msleep(100);
	}
591 592
}

593 594 595
int intel_ddi_toggle_hdcp_bits(struct intel_encoder *intel_encoder,
			       enum transcoder cpu_transcoder,
			       bool enable, u32 hdcp_mask)
S
Sean Paul 已提交
596 597 598
{
	struct drm_device *dev = intel_encoder->base.dev;
	struct drm_i915_private *dev_priv = to_i915(dev);
599
	intel_wakeref_t wakeref;
S
Sean Paul 已提交
600
	int ret = 0;
601
	u32 tmp;
S
Sean Paul 已提交
602

603 604
	wakeref = intel_display_power_get_if_enabled(dev_priv,
						     intel_encoder->power_domain);
605
	if (drm_WARN_ON(dev, !wakeref))
S
Sean Paul 已提交
606 607
		return -ENXIO;

608
	tmp = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder));
S
Sean Paul 已提交
609
	if (enable)
610
		tmp |= hdcp_mask;
S
Sean Paul 已提交
611
	else
612
		tmp &= ~hdcp_mask;
613
	intel_de_write(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder), tmp);
614
	intel_display_power_put(dev_priv, intel_encoder->power_domain, wakeref);
S
Sean Paul 已提交
615 616 617
	return ret;
}

618 619 620
bool intel_ddi_connector_get_hw_state(struct intel_connector *intel_connector)
{
	struct drm_device *dev = intel_connector->base.dev;
621
	struct drm_i915_private *dev_priv = to_i915(dev);
622
	struct intel_encoder *encoder = intel_attached_encoder(intel_connector);
623
	int type = intel_connector->base.connector_type;
624
	enum port port = encoder->port;
625
	enum transcoder cpu_transcoder;
626 627
	intel_wakeref_t wakeref;
	enum pipe pipe = 0;
628
	u32 tmp;
629
	bool ret;
630

631 632 633
	wakeref = intel_display_power_get_if_enabled(dev_priv,
						     encoder->power_domain);
	if (!wakeref)
634 635
		return false;

636
	if (!encoder->get_hw_state(encoder, &pipe)) {
637 638 639
		ret = false;
		goto out;
	}
640

641
	if (HAS_TRANSCODER(dev_priv, TRANSCODER_EDP) && port == PORT_A)
642 643
		cpu_transcoder = TRANSCODER_EDP;
	else
D
Daniel Vetter 已提交
644
		cpu_transcoder = (enum transcoder) pipe;
645

646
	tmp = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder));
647 648 649 650

	switch (tmp & TRANS_DDI_MODE_SELECT_MASK) {
	case TRANS_DDI_MODE_SELECT_HDMI:
	case TRANS_DDI_MODE_SELECT_DVI:
651 652
		ret = type == DRM_MODE_CONNECTOR_HDMIA;
		break;
653 654

	case TRANS_DDI_MODE_SELECT_DP_SST:
655 656 657 658
		ret = type == DRM_MODE_CONNECTOR_eDP ||
		      type == DRM_MODE_CONNECTOR_DisplayPort;
		break;

659 660 661
	case TRANS_DDI_MODE_SELECT_DP_MST:
		/* if the transcoder is in MST state then
		 * connector isn't connected */
662 663
		ret = false;
		break;
664 665

	case TRANS_DDI_MODE_SELECT_FDI:
666 667
		ret = type == DRM_MODE_CONNECTOR_VGA;
		break;
668 669

	default:
670 671
		ret = false;
		break;
672
	}
673 674

out:
675
	intel_display_power_put(dev_priv, encoder->power_domain, wakeref);
676 677

	return ret;
678 679
}

680 681
static void intel_ddi_get_encoder_pipes(struct intel_encoder *encoder,
					u8 *pipe_mask, bool *is_dp_mst)
682 683
{
	struct drm_device *dev = encoder->base.dev;
684
	struct drm_i915_private *dev_priv = to_i915(dev);
685
	enum port port = encoder->port;
686
	intel_wakeref_t wakeref;
687
	enum pipe p;
688
	u32 tmp;
689 690 691 692
	u8 mst_pipe_mask;

	*pipe_mask = 0;
	*is_dp_mst = false;
693

694 695 696
	wakeref = intel_display_power_get_if_enabled(dev_priv,
						     encoder->power_domain);
	if (!wakeref)
697
		return;
698

699
	tmp = intel_de_read(dev_priv, DDI_BUF_CTL(port));
700
	if (!(tmp & DDI_BUF_CTL_ENABLE))
701
		goto out;
702

703
	if (HAS_TRANSCODER(dev_priv, TRANSCODER_EDP) && port == PORT_A) {
704 705
		tmp = intel_de_read(dev_priv,
				    TRANS_DDI_FUNC_CTL(TRANSCODER_EDP));
706

707
		switch (tmp & TRANS_DDI_EDP_INPUT_MASK) {
708 709
		default:
			MISSING_CASE(tmp & TRANS_DDI_EDP_INPUT_MASK);
710
			fallthrough;
711 712
		case TRANS_DDI_EDP_INPUT_A_ON:
		case TRANS_DDI_EDP_INPUT_A_ONOFF:
713
			*pipe_mask = BIT(PIPE_A);
714 715
			break;
		case TRANS_DDI_EDP_INPUT_B_ONOFF:
716
			*pipe_mask = BIT(PIPE_B);
717 718
			break;
		case TRANS_DDI_EDP_INPUT_C_ONOFF:
719
			*pipe_mask = BIT(PIPE_C);
720 721 722
			break;
		}

723 724
		goto out;
	}
725

726
	mst_pipe_mask = 0;
727
	for_each_pipe(dev_priv, p) {
728
		enum transcoder cpu_transcoder = (enum transcoder)p;
729
		unsigned int port_mask, ddi_select;
730 731 732 733 734 735
		intel_wakeref_t trans_wakeref;

		trans_wakeref = intel_display_power_get_if_enabled(dev_priv,
								   POWER_DOMAIN_TRANSCODER(cpu_transcoder));
		if (!trans_wakeref)
			continue;
736 737 738 739 740 741 742 743

		if (INTEL_GEN(dev_priv) >= 12) {
			port_mask = TGL_TRANS_DDI_PORT_MASK;
			ddi_select = TGL_TRANS_DDI_SELECT_PORT(port);
		} else {
			port_mask = TRANS_DDI_PORT_MASK;
			ddi_select = TRANS_DDI_SELECT_PORT(port);
		}
744

745 746
		tmp = intel_de_read(dev_priv,
				    TRANS_DDI_FUNC_CTL(cpu_transcoder));
747 748
		intel_display_power_put(dev_priv, POWER_DOMAIN_TRANSCODER(cpu_transcoder),
					trans_wakeref);
749

750
		if ((tmp & port_mask) != ddi_select)
751
			continue;
752

753 754 755
		if ((tmp & TRANS_DDI_MODE_SELECT_MASK) ==
		    TRANS_DDI_MODE_SELECT_DP_MST)
			mst_pipe_mask |= BIT(p);
756

757
		*pipe_mask |= BIT(p);
758 759
	}

760
	if (!*pipe_mask)
761 762 763
		drm_dbg_kms(&dev_priv->drm,
			    "No pipe for [ENCODER:%d:%s] found\n",
			    encoder->base.base.id, encoder->base.name);
764 765

	if (!mst_pipe_mask && hweight8(*pipe_mask) > 1) {
766 767 768 769
		drm_dbg_kms(&dev_priv->drm,
			    "Multiple pipes for [ENCODER:%d:%s] (pipe_mask %02x)\n",
			    encoder->base.base.id, encoder->base.name,
			    *pipe_mask);
770 771 772 773
		*pipe_mask = BIT(ffs(*pipe_mask) - 1);
	}

	if (mst_pipe_mask && mst_pipe_mask != *pipe_mask)
774 775 776 777
		drm_dbg_kms(&dev_priv->drm,
			    "Conflicting MST and non-MST state for [ENCODER:%d:%s] (pipe_mask %02x mst_pipe_mask %02x)\n",
			    encoder->base.base.id, encoder->base.name,
			    *pipe_mask, mst_pipe_mask);
778 779
	else
		*is_dp_mst = mst_pipe_mask;
780

781
out:
782
	if (*pipe_mask && IS_GEN9_LP(dev_priv)) {
783
		tmp = intel_de_read(dev_priv, BXT_PHY_CTL(port));
784 785
		if ((tmp & (BXT_PHY_CMNLANE_POWERDOWN_ACK |
			    BXT_PHY_LANE_POWERDOWN_ACK |
786
			    BXT_PHY_LANE_ENABLED)) != BXT_PHY_LANE_ENABLED)
787 788 789
			drm_err(&dev_priv->drm,
				"[ENCODER:%d:%s] enabled but PHY powered down? (PHY_CTL %08x)\n",
				encoder->base.base.id, encoder->base.name, tmp);
790 791
	}

792
	intel_display_power_put(dev_priv, encoder->power_domain, wakeref);
793
}
794

795 796 797 798 799 800 801 802 803 804 805 806 807 808
bool intel_ddi_get_hw_state(struct intel_encoder *encoder,
			    enum pipe *pipe)
{
	u8 pipe_mask;
	bool is_mst;

	intel_ddi_get_encoder_pipes(encoder, &pipe_mask, &is_mst);

	if (is_mst || !pipe_mask)
		return false;

	*pipe = ffs(pipe_mask) - 1;

	return true;
809 810
}

811
static enum intel_display_power_domain
I
Imre Deak 已提交
812
intel_ddi_main_link_aux_domain(struct intel_digital_port *dig_port)
813
{
814
	/* CNL+ HW requires corresponding AUX IOs to be powered up for PSR with
815 816 817 818 819 820 821 822 823 824 825
	 * DC states enabled at the same time, while for driver initiated AUX
	 * transfers we need the same AUX IOs to be powered but with DC states
	 * disabled. Accordingly use the AUX power domain here which leaves DC
	 * states enabled.
	 * However, for non-A AUX ports the corresponding non-EDP transcoders
	 * would have already enabled power well 2 and DC_OFF. This means we can
	 * acquire a wider POWER_DOMAIN_AUX_{B,C,D,F} reference instead of a
	 * specific AUX_IO reference without powering up any extra wells.
	 * Note that PSR is enabled only on Port A even though this function
	 * returns the correct domain for other ports too.
	 */
826
	return dig_port->aux_ch == AUX_CH_A ? POWER_DOMAIN_AUX_IO_A :
827
					      intel_aux_power_domain(dig_port);
828 829
}

830 831
static void intel_ddi_get_power_domains(struct intel_encoder *encoder,
					struct intel_crtc_state *crtc_state)
832
{
833
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
834
	struct intel_digital_port *dig_port;
835
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
836

837 838
	/*
	 * TODO: Add support for MST encoders. Atm, the following should never
839 840
	 * happen since fake-MST encoders don't set their get_power_domains()
	 * hook.
841
	 */
842 843
	if (drm_WARN_ON(&dev_priv->drm,
			intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST)))
844
		return;
845

846
	dig_port = enc_to_dig_port(encoder);
847 848

	if (!intel_phy_is_tc(dev_priv, phy) ||
849 850 851 852 853
	    dig_port->tc_mode != TC_PORT_TBT_ALT) {
		drm_WARN_ON(&dev_priv->drm, dig_port->ddi_io_wakeref);
		dig_port->ddi_io_wakeref = intel_display_power_get(dev_priv,
								   dig_port->ddi_io_power_domain);
	}
854

855 856 857 858 859
	/*
	 * AUX power is only needed for (e)DP mode, and for HDMI mode on TC
	 * ports.
	 */
	if (intel_crtc_has_dp_encoder(crtc_state) ||
860 861 862 863 864 865
	    intel_phy_is_tc(dev_priv, phy)) {
		drm_WARN_ON(&dev_priv->drm, dig_port->aux_wakeref);
		dig_port->aux_wakeref =
			intel_display_power_get(dev_priv,
						intel_ddi_main_link_aux_domain(dig_port));
	}
866 867
}

868 869
void intel_ddi_enable_pipe_clock(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
870
{
871
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
872
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
873
	enum port port = encoder->port;
874
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
875

876 877
	if (cpu_transcoder != TRANSCODER_EDP) {
		if (INTEL_GEN(dev_priv) >= 12)
878 879 880
			intel_de_write(dev_priv,
				       TRANS_CLK_SEL(cpu_transcoder),
				       TGL_TRANS_CLK_SEL_PORT(port));
881
		else
882 883 884
			intel_de_write(dev_priv,
				       TRANS_CLK_SEL(cpu_transcoder),
				       TRANS_CLK_SEL_PORT(port));
885
	}
886 887
}

888
void intel_ddi_disable_pipe_clock(const struct intel_crtc_state *crtc_state)
889
{
890
	struct drm_i915_private *dev_priv = to_i915(crtc_state->uapi.crtc->dev);
891
	enum transcoder cpu_transcoder = crtc_state->cpu_transcoder;
892

893 894
	if (cpu_transcoder != TRANSCODER_EDP) {
		if (INTEL_GEN(dev_priv) >= 12)
895 896 897
			intel_de_write(dev_priv,
				       TRANS_CLK_SEL(cpu_transcoder),
				       TGL_TRANS_CLK_SEL_DISABLED);
898
		else
899 900 901
			intel_de_write(dev_priv,
				       TRANS_CLK_SEL(cpu_transcoder),
				       TRANS_CLK_SEL_DISABLED);
902
	}
903 904
}

905
static void _skl_ddi_set_iboost(struct drm_i915_private *dev_priv,
906
				enum port port, u8 iboost)
907
{
908 909
	u32 tmp;

910
	tmp = intel_de_read(dev_priv, DISPIO_CR_TX_BMU_CR0);
911 912 913 914 915
	tmp &= ~(BALANCE_LEG_MASK(port) | BALANCE_LEG_DISABLE(port));
	if (iboost)
		tmp |= iboost << BALANCE_LEG_SHIFT(port);
	else
		tmp |= BALANCE_LEG_DISABLE(port);
916
	intel_de_write(dev_priv, DISPIO_CR_TX_BMU_CR0, tmp);
917 918
}

919
static void skl_ddi_set_iboost(struct intel_encoder *encoder,
920 921
			       const struct intel_crtc_state *crtc_state,
			       int level)
922
{
923
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
924
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
925
	u8 iboost;
926

927
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
928
		iboost = intel_bios_hdmi_boost_level(encoder);
929
	else
930
		iboost = intel_bios_dp_boost_level(encoder);
931

932 933 934 935
	if (iboost == 0) {
		const struct ddi_buf_trans *ddi_translations;
		int n_entries;

936
		if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
937
			ddi_translations = intel_ddi_get_buf_trans_hdmi(encoder, &n_entries);
938 939
		else if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP))
			ddi_translations = intel_ddi_get_buf_trans_edp(encoder, &n_entries);
940
		else
941
			ddi_translations = intel_ddi_get_buf_trans_dp(encoder, &n_entries);
942

943
		if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
944
			return;
945
		if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
946 947
			level = n_entries - 1;

948
		iboost = ddi_translations[level].i_boost;
949 950 951 952
	}

	/* Make sure that the requested I_boost is valid */
	if (iboost && iboost != 0x1 && iboost != 0x3 && iboost != 0x7) {
953
		drm_err(&dev_priv->drm, "Invalid I_boost value %u\n", iboost);
954 955 956
		return;
	}

957
	_skl_ddi_set_iboost(dev_priv, encoder->port, iboost);
958

959
	if (encoder->port == PORT_A && dig_port->max_lanes == 4)
960
		_skl_ddi_set_iboost(dev_priv, PORT_E, iboost);
961 962
}

963
static void bxt_ddi_vswing_sequence(struct intel_encoder *encoder,
964 965
				    const struct intel_crtc_state *crtc_state,
				    int level)
966
{
967
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
968
	const struct bxt_ddi_buf_trans *ddi_translations;
969
	enum port port = encoder->port;
970
	int n_entries;
971

972
	ddi_translations = bxt_get_buf_trans(encoder, crtc_state, &n_entries);
973
	if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
974
		return;
975
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
976 977
		level = n_entries - 1;

978 979 980 981 982
	bxt_ddi_phy_set_signal_level(dev_priv, port,
				     ddi_translations[level].margin,
				     ddi_translations[level].scale,
				     ddi_translations[level].enable,
				     ddi_translations[level].deemphasis);
983 984
}

985 986
static u8 intel_ddi_dp_voltage_max(struct intel_dp *intel_dp,
				   const struct intel_crtc_state *crtc_state)
987
{
988
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
989
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
990
	enum port port = encoder->port;
991
	enum phy phy = intel_port_to_phy(dev_priv, port);
992 993
	int n_entries;

994 995
	if (INTEL_GEN(dev_priv) >= 12) {
		if (intel_phy_is_combo(dev_priv, phy))
996
			tgl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
997
		else
998
			tgl_get_dkl_buf_trans(encoder, crtc_state, &n_entries);
999
	} else if (INTEL_GEN(dev_priv) == 11) {
1000 1001 1002
		if (IS_PLATFORM(dev_priv, INTEL_JASPERLAKE))
			jsl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
		else if (IS_PLATFORM(dev_priv, INTEL_ELKHARTLAKE))
1003
			ehl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
1004
		else if (intel_phy_is_combo(dev_priv, phy))
1005
			icl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
1006
		else
1007
			icl_get_mg_buf_trans(encoder, crtc_state, &n_entries);
1008
	} else if (IS_CANNONLAKE(dev_priv)) {
1009
		cnl_get_buf_trans(encoder, crtc_state, &n_entries);
1010
	} else if (IS_GEN9_LP(dev_priv)) {
1011
		bxt_get_buf_trans(encoder, crtc_state, &n_entries);
R
Rodrigo Vivi 已提交
1012
	} else {
1013
		if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP))
1014
			intel_ddi_get_buf_trans_edp(encoder, &n_entries);
R
Rodrigo Vivi 已提交
1015
		else
1016
			intel_ddi_get_buf_trans_dp(encoder, &n_entries);
R
Rodrigo Vivi 已提交
1017
	}
1018

1019
	if (drm_WARN_ON(&dev_priv->drm, n_entries < 1))
1020
		n_entries = 1;
1021 1022
	if (drm_WARN_ON(&dev_priv->drm,
			n_entries > ARRAY_SIZE(index_to_dp_signal_levels)))
1023 1024 1025 1026 1027 1028
		n_entries = ARRAY_SIZE(index_to_dp_signal_levels);

	return index_to_dp_signal_levels[n_entries - 1] &
		DP_TRAIN_VOLTAGE_SWING_MASK;
}

1029 1030 1031 1032 1033
/*
 * We assume that the full set of pre-emphasis values can be
 * used on all DDI platforms. Should that change we need to
 * rethink this code.
 */
1034
static u8 intel_ddi_dp_preemph_max(struct intel_dp *intel_dp)
1035
{
1036
	return DP_TRAIN_PRE_EMPH_LEVEL_3;
1037 1038
}

1039
static void cnl_ddi_vswing_program(struct intel_encoder *encoder,
1040 1041
				   const struct intel_crtc_state *crtc_state,
				   int level)
1042
{
1043 1044
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	const struct cnl_ddi_buf_trans *ddi_translations;
1045
	enum port port = encoder->port;
1046 1047
	int n_entries, ln;
	u32 val;
1048

1049
	ddi_translations = cnl_get_buf_trans(encoder, crtc_state, &n_entries);
1050

1051
	if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
1052
		return;
1053
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
1054 1055 1056
		level = n_entries - 1;

	/* Set PORT_TX_DW5 Scaling Mode Sel to 010b. */
1057
	val = intel_de_read(dev_priv, CNL_PORT_TX_DW5_LN0(port));
1058
	val &= ~SCALING_MODE_SEL_MASK;
1059
	val |= SCALING_MODE_SEL(2);
1060
	intel_de_write(dev_priv, CNL_PORT_TX_DW5_GRP(port), val);
1061 1062

	/* Program PORT_TX_DW2 */
1063
	val = intel_de_read(dev_priv, CNL_PORT_TX_DW2_LN0(port));
1064 1065
	val &= ~(SWING_SEL_LOWER_MASK | SWING_SEL_UPPER_MASK |
		 RCOMP_SCALAR_MASK);
1066 1067 1068 1069
	val |= SWING_SEL_UPPER(ddi_translations[level].dw2_swing_sel);
	val |= SWING_SEL_LOWER(ddi_translations[level].dw2_swing_sel);
	/* Rcomp scalar is fixed as 0x98 for every table entry */
	val |= RCOMP_SCALAR(0x98);
1070
	intel_de_write(dev_priv, CNL_PORT_TX_DW2_GRP(port), val);
1071

1072
	/* Program PORT_TX_DW4 */
1073 1074
	/* We cannot write to GRP. It would overrite individual loadgen */
	for (ln = 0; ln < 4; ln++) {
1075
		val = intel_de_read(dev_priv, CNL_PORT_TX_DW4_LN(ln, port));
1076 1077
		val &= ~(POST_CURSOR_1_MASK | POST_CURSOR_2_MASK |
			 CURSOR_COEFF_MASK);
1078 1079 1080
		val |= POST_CURSOR_1(ddi_translations[level].dw4_post_cursor_1);
		val |= POST_CURSOR_2(ddi_translations[level].dw4_post_cursor_2);
		val |= CURSOR_COEFF(ddi_translations[level].dw4_cursor_coeff);
1081
		intel_de_write(dev_priv, CNL_PORT_TX_DW4_LN(ln, port), val);
1082 1083
	}

1084
	/* Program PORT_TX_DW5 */
1085
	/* All DW5 values are fixed for every table entry */
1086
	val = intel_de_read(dev_priv, CNL_PORT_TX_DW5_LN0(port));
1087
	val &= ~RTERM_SELECT_MASK;
1088 1089
	val |= RTERM_SELECT(6);
	val |= TAP3_DISABLE;
1090
	intel_de_write(dev_priv, CNL_PORT_TX_DW5_GRP(port), val);
1091

1092
	/* Program PORT_TX_DW7 */
1093
	val = intel_de_read(dev_priv, CNL_PORT_TX_DW7_LN0(port));
1094
	val &= ~N_SCALAR_MASK;
1095
	val |= N_SCALAR(ddi_translations[level].dw7_n_scalar);
1096
	intel_de_write(dev_priv, CNL_PORT_TX_DW7_GRP(port), val);
1097 1098
}

1099
static void cnl_ddi_vswing_sequence(struct intel_encoder *encoder,
1100 1101
				    const struct intel_crtc_state *crtc_state,
				    int level)
1102
{
1103
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1104
	enum port port = encoder->port;
1105
	int width, rate, ln;
1106
	u32 val;
1107

1108 1109
	width = crtc_state->lane_count;
	rate = crtc_state->port_clock;
1110 1111 1112 1113 1114 1115

	/*
	 * 1. If port type is eDP or DP,
	 * set PORT_PCS_DW1 cmnkeeper_enable to 1b,
	 * else clear to 0b.
	 */
1116
	val = intel_de_read(dev_priv, CNL_PORT_PCS_DW1_LN0(port));
1117
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
1118
		val &= ~COMMON_KEEPER_EN;
1119 1120
	else
		val |= COMMON_KEEPER_EN;
1121
	intel_de_write(dev_priv, CNL_PORT_PCS_DW1_GRP(port), val);
1122 1123 1124

	/* 2. Program loadgen select */
	/*
1125 1126 1127 1128
	 * Program PORT_TX_DW4_LN depending on Bit rate and used lanes
	 * <= 6 GHz and 4 lanes (LN0=0, LN1=1, LN2=1, LN3=1)
	 * <= 6 GHz and 1,2 lanes (LN0=0, LN1=1, LN2=1, LN3=0)
	 * > 6 GHz (LN0=0, LN1=0, LN2=0, LN3=0)
1129
	 */
1130
	for (ln = 0; ln <= 3; ln++) {
1131
		val = intel_de_read(dev_priv, CNL_PORT_TX_DW4_LN(ln, port));
1132 1133
		val &= ~LOADGEN_SELECT;

1134 1135
		if ((rate <= 600000 && width == 4 && ln >= 1)  ||
		    (rate <= 600000 && width < 4 && (ln == 1 || ln == 2))) {
1136 1137
			val |= LOADGEN_SELECT;
		}
1138
		intel_de_write(dev_priv, CNL_PORT_TX_DW4_LN(ln, port), val);
1139
	}
1140 1141

	/* 3. Set PORT_CL_DW5 SUS Clock Config to 11b */
1142
	val = intel_de_read(dev_priv, CNL_PORT_CL1CM_DW5);
1143
	val |= SUS_CLOCK_CONFIG;
1144
	intel_de_write(dev_priv, CNL_PORT_CL1CM_DW5, val);
1145 1146

	/* 4. Clear training enable to change swing values */
1147
	val = intel_de_read(dev_priv, CNL_PORT_TX_DW5_LN0(port));
1148
	val &= ~TX_TRAINING_EN;
1149
	intel_de_write(dev_priv, CNL_PORT_TX_DW5_GRP(port), val);
1150 1151

	/* 5. Program swing and de-emphasis */
1152
	cnl_ddi_vswing_program(encoder, crtc_state, level);
1153 1154

	/* 6. Set training enable to trigger update */
1155
	val = intel_de_read(dev_priv, CNL_PORT_TX_DW5_LN0(port));
1156
	val |= TX_TRAINING_EN;
1157
	intel_de_write(dev_priv, CNL_PORT_TX_DW5_GRP(port), val);
1158 1159
}

1160
static void icl_ddi_combo_vswing_program(struct intel_encoder *encoder,
1161 1162
					 const struct intel_crtc_state *crtc_state,
					 int level)
1163
{
1164
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1165
	const struct cnl_ddi_buf_trans *ddi_translations;
1166
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1167 1168
	int n_entries, ln;
	u32 val;
1169

1170
	if (INTEL_GEN(dev_priv) >= 12)
1171
		ddi_translations = tgl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
1172 1173 1174
	else if (IS_PLATFORM(dev_priv, INTEL_JASPERLAKE))
		ddi_translations = jsl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
	else if (IS_PLATFORM(dev_priv, INTEL_ELKHARTLAKE))
1175
		ddi_translations = ehl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
1176
	else
1177
		ddi_translations = icl_get_combo_buf_trans(encoder, crtc_state, &n_entries);
1178

1179 1180 1181
	if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
		return;
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
1182 1183
		level = n_entries - 1;

1184
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_EDP)) {
1185 1186 1187 1188 1189 1190 1191 1192
		struct intel_dp *intel_dp = enc_to_intel_dp(encoder);

		val = EDP4K2K_MODE_OVRD_EN | EDP4K2K_MODE_OVRD_OPTIMIZED;
		intel_dp->hobl_active = is_hobl_buf_trans(ddi_translations);
		intel_de_rmw(dev_priv, ICL_PORT_CL_DW10(phy), val,
			     intel_dp->hobl_active ? val : 0);
	}

1193
	/* Set PORT_TX_DW5 */
1194
	val = intel_de_read(dev_priv, ICL_PORT_TX_DW5_LN0(phy));
1195 1196 1197
	val &= ~(SCALING_MODE_SEL_MASK | RTERM_SELECT_MASK |
		  TAP2_DISABLE | TAP3_DISABLE);
	val |= SCALING_MODE_SEL(0x2);
1198
	val |= RTERM_SELECT(0x6);
1199
	val |= TAP3_DISABLE;
1200
	intel_de_write(dev_priv, ICL_PORT_TX_DW5_GRP(phy), val);
1201 1202

	/* Program PORT_TX_DW2 */
1203
	val = intel_de_read(dev_priv, ICL_PORT_TX_DW2_LN0(phy));
1204 1205
	val &= ~(SWING_SEL_LOWER_MASK | SWING_SEL_UPPER_MASK |
		 RCOMP_SCALAR_MASK);
1206 1207
	val |= SWING_SEL_UPPER(ddi_translations[level].dw2_swing_sel);
	val |= SWING_SEL_LOWER(ddi_translations[level].dw2_swing_sel);
1208
	/* Program Rcomp scalar for every table entry */
1209
	val |= RCOMP_SCALAR(0x98);
1210
	intel_de_write(dev_priv, ICL_PORT_TX_DW2_GRP(phy), val);
1211 1212 1213 1214

	/* Program PORT_TX_DW4 */
	/* We cannot write to GRP. It would overwrite individual loadgen. */
	for (ln = 0; ln <= 3; ln++) {
1215
		val = intel_de_read(dev_priv, ICL_PORT_TX_DW4_LN(ln, phy));
1216 1217
		val &= ~(POST_CURSOR_1_MASK | POST_CURSOR_2_MASK |
			 CURSOR_COEFF_MASK);
1218 1219 1220
		val |= POST_CURSOR_1(ddi_translations[level].dw4_post_cursor_1);
		val |= POST_CURSOR_2(ddi_translations[level].dw4_post_cursor_2);
		val |= CURSOR_COEFF(ddi_translations[level].dw4_cursor_coeff);
1221
		intel_de_write(dev_priv, ICL_PORT_TX_DW4_LN(ln, phy), val);
1222
	}
1223 1224

	/* Program PORT_TX_DW7 */
1225
	val = intel_de_read(dev_priv, ICL_PORT_TX_DW7_LN0(phy));
1226 1227
	val &= ~N_SCALAR_MASK;
	val |= N_SCALAR(ddi_translations[level].dw7_n_scalar);
1228
	intel_de_write(dev_priv, ICL_PORT_TX_DW7_GRP(phy), val);
1229 1230 1231
}

static void icl_combo_phy_ddi_vswing_sequence(struct intel_encoder *encoder,
1232 1233
					      const struct intel_crtc_state *crtc_state,
					      int level)
1234 1235
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1236
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1237
	int width, rate, ln;
1238 1239
	u32 val;

1240 1241
	width = crtc_state->lane_count;
	rate = crtc_state->port_clock;
1242 1243 1244 1245 1246 1247

	/*
	 * 1. If port type is eDP or DP,
	 * set PORT_PCS_DW1 cmnkeeper_enable to 1b,
	 * else clear to 0b.
	 */
1248
	val = intel_de_read(dev_priv, ICL_PORT_PCS_DW1_LN0(phy));
1249
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
1250 1251 1252
		val &= ~COMMON_KEEPER_EN;
	else
		val |= COMMON_KEEPER_EN;
1253
	intel_de_write(dev_priv, ICL_PORT_PCS_DW1_GRP(phy), val);
1254 1255 1256 1257 1258 1259 1260 1261 1262

	/* 2. Program loadgen select */
	/*
	 * Program PORT_TX_DW4_LN depending on Bit rate and used lanes
	 * <= 6 GHz and 4 lanes (LN0=0, LN1=1, LN2=1, LN3=1)
	 * <= 6 GHz and 1,2 lanes (LN0=0, LN1=1, LN2=1, LN3=0)
	 * > 6 GHz (LN0=0, LN1=0, LN2=0, LN3=0)
	 */
	for (ln = 0; ln <= 3; ln++) {
1263
		val = intel_de_read(dev_priv, ICL_PORT_TX_DW4_LN(ln, phy));
1264 1265 1266 1267 1268 1269
		val &= ~LOADGEN_SELECT;

		if ((rate <= 600000 && width == 4 && ln >= 1) ||
		    (rate <= 600000 && width < 4 && (ln == 1 || ln == 2))) {
			val |= LOADGEN_SELECT;
		}
1270
		intel_de_write(dev_priv, ICL_PORT_TX_DW4_LN(ln, phy), val);
1271 1272 1273
	}

	/* 3. Set PORT_CL_DW5 SUS Clock Config to 11b */
1274
	val = intel_de_read(dev_priv, ICL_PORT_CL_DW5(phy));
1275
	val |= SUS_CLOCK_CONFIG;
1276
	intel_de_write(dev_priv, ICL_PORT_CL_DW5(phy), val);
1277 1278

	/* 4. Clear training enable to change swing values */
1279
	val = intel_de_read(dev_priv, ICL_PORT_TX_DW5_LN0(phy));
1280
	val &= ~TX_TRAINING_EN;
1281
	intel_de_write(dev_priv, ICL_PORT_TX_DW5_GRP(phy), val);
1282 1283

	/* 5. Program swing and de-emphasis */
1284
	icl_ddi_combo_vswing_program(encoder, crtc_state, level);
1285 1286

	/* 6. Set training enable to trigger update */
1287
	val = intel_de_read(dev_priv, ICL_PORT_TX_DW5_LN0(phy));
1288
	val |= TX_TRAINING_EN;
1289
	intel_de_write(dev_priv, ICL_PORT_TX_DW5_GRP(phy), val);
1290 1291
}

1292
static void icl_mg_phy_ddi_vswing_sequence(struct intel_encoder *encoder,
1293 1294
					   const struct intel_crtc_state *crtc_state,
					   int level)
1295 1296
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1297
	enum tc_port tc_port = intel_port_to_tc(dev_priv, encoder->port);
1298
	const struct icl_mg_phy_ddi_buf_trans *ddi_translations;
1299 1300
	int n_entries, ln;
	u32 val;
1301

1302 1303 1304
	if (enc_to_dig_port(encoder)->tc_mode == TC_PORT_TBT_ALT)
		return;

1305
	ddi_translations = icl_get_mg_buf_trans(encoder, crtc_state, &n_entries);
1306 1307 1308 1309

	if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
		return;
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
1310
		level = n_entries - 1;
1311 1312 1313

	/* Set MG_TX_LINK_PARAMS cri_use_fs32 to 0. */
	for (ln = 0; ln < 2; ln++) {
1314
		val = intel_de_read(dev_priv, MG_TX1_LINK_PARAMS(ln, tc_port));
1315
		val &= ~CRI_USE_FS32;
1316
		intel_de_write(dev_priv, MG_TX1_LINK_PARAMS(ln, tc_port), val);
1317

1318
		val = intel_de_read(dev_priv, MG_TX2_LINK_PARAMS(ln, tc_port));
1319
		val &= ~CRI_USE_FS32;
1320
		intel_de_write(dev_priv, MG_TX2_LINK_PARAMS(ln, tc_port), val);
1321 1322 1323 1324
	}

	/* Program MG_TX_SWINGCTRL with values from vswing table */
	for (ln = 0; ln < 2; ln++) {
1325
		val = intel_de_read(dev_priv, MG_TX1_SWINGCTRL(ln, tc_port));
1326 1327 1328
		val &= ~CRI_TXDEEMPH_OVERRIDE_17_12_MASK;
		val |= CRI_TXDEEMPH_OVERRIDE_17_12(
			ddi_translations[level].cri_txdeemph_override_17_12);
1329
		intel_de_write(dev_priv, MG_TX1_SWINGCTRL(ln, tc_port), val);
1330

1331
		val = intel_de_read(dev_priv, MG_TX2_SWINGCTRL(ln, tc_port));
1332 1333 1334
		val &= ~CRI_TXDEEMPH_OVERRIDE_17_12_MASK;
		val |= CRI_TXDEEMPH_OVERRIDE_17_12(
			ddi_translations[level].cri_txdeemph_override_17_12);
1335
		intel_de_write(dev_priv, MG_TX2_SWINGCTRL(ln, tc_port), val);
1336 1337 1338 1339
	}

	/* Program MG_TX_DRVCTRL with values from vswing table */
	for (ln = 0; ln < 2; ln++) {
1340
		val = intel_de_read(dev_priv, MG_TX1_DRVCTRL(ln, tc_port));
1341 1342 1343 1344 1345 1346 1347
		val &= ~(CRI_TXDEEMPH_OVERRIDE_11_6_MASK |
			 CRI_TXDEEMPH_OVERRIDE_5_0_MASK);
		val |= CRI_TXDEEMPH_OVERRIDE_5_0(
			ddi_translations[level].cri_txdeemph_override_5_0) |
			CRI_TXDEEMPH_OVERRIDE_11_6(
				ddi_translations[level].cri_txdeemph_override_11_6) |
			CRI_TXDEEMPH_OVERRIDE_EN;
1348
		intel_de_write(dev_priv, MG_TX1_DRVCTRL(ln, tc_port), val);
1349

1350
		val = intel_de_read(dev_priv, MG_TX2_DRVCTRL(ln, tc_port));
1351 1352 1353 1354 1355 1356 1357
		val &= ~(CRI_TXDEEMPH_OVERRIDE_11_6_MASK |
			 CRI_TXDEEMPH_OVERRIDE_5_0_MASK);
		val |= CRI_TXDEEMPH_OVERRIDE_5_0(
			ddi_translations[level].cri_txdeemph_override_5_0) |
			CRI_TXDEEMPH_OVERRIDE_11_6(
				ddi_translations[level].cri_txdeemph_override_11_6) |
			CRI_TXDEEMPH_OVERRIDE_EN;
1358
		intel_de_write(dev_priv, MG_TX2_DRVCTRL(ln, tc_port), val);
1359 1360 1361 1362 1363 1364 1365 1366 1367 1368

		/* FIXME: Program CRI_LOADGEN_SEL after the spec is updated */
	}

	/*
	 * Program MG_CLKHUB<LN, port being used> with value from frequency table
	 * In case of Legacy mode on MG PHY, both TX1 and TX2 enabled so use the
	 * values from table for which TX1 and TX2 enabled.
	 */
	for (ln = 0; ln < 2; ln++) {
1369
		val = intel_de_read(dev_priv, MG_CLKHUB(ln, tc_port));
1370
		if (crtc_state->port_clock < 300000)
1371 1372 1373
			val |= CFG_LOW_RATE_LKREN_EN;
		else
			val &= ~CFG_LOW_RATE_LKREN_EN;
1374
		intel_de_write(dev_priv, MG_CLKHUB(ln, tc_port), val);
1375 1376 1377 1378
	}

	/* Program the MG_TX_DCC<LN, port being used> based on the link frequency */
	for (ln = 0; ln < 2; ln++) {
1379
		val = intel_de_read(dev_priv, MG_TX1_DCC(ln, tc_port));
1380
		val &= ~CFG_AMI_CK_DIV_OVERRIDE_VAL_MASK;
1381
		if (crtc_state->port_clock <= 500000) {
1382 1383 1384 1385 1386
			val &= ~CFG_AMI_CK_DIV_OVERRIDE_EN;
		} else {
			val |= CFG_AMI_CK_DIV_OVERRIDE_EN |
				CFG_AMI_CK_DIV_OVERRIDE_VAL(1);
		}
1387
		intel_de_write(dev_priv, MG_TX1_DCC(ln, tc_port), val);
1388

1389
		val = intel_de_read(dev_priv, MG_TX2_DCC(ln, tc_port));
1390
		val &= ~CFG_AMI_CK_DIV_OVERRIDE_VAL_MASK;
1391
		if (crtc_state->port_clock <= 500000) {
1392 1393 1394 1395 1396
			val &= ~CFG_AMI_CK_DIV_OVERRIDE_EN;
		} else {
			val |= CFG_AMI_CK_DIV_OVERRIDE_EN |
				CFG_AMI_CK_DIV_OVERRIDE_VAL(1);
		}
1397
		intel_de_write(dev_priv, MG_TX2_DCC(ln, tc_port), val);
1398 1399 1400 1401
	}

	/* Program MG_TX_PISO_READLOAD with values from vswing table */
	for (ln = 0; ln < 2; ln++) {
1402 1403
		val = intel_de_read(dev_priv,
				    MG_TX1_PISO_READLOAD(ln, tc_port));
1404
		val |= CRI_CALCINIT;
1405 1406
		intel_de_write(dev_priv, MG_TX1_PISO_READLOAD(ln, tc_port),
			       val);
1407

1408 1409
		val = intel_de_read(dev_priv,
				    MG_TX2_PISO_READLOAD(ln, tc_port));
1410
		val |= CRI_CALCINIT;
1411 1412
		intel_de_write(dev_priv, MG_TX2_PISO_READLOAD(ln, tc_port),
			       val);
1413 1414 1415 1416
	}
}

static void icl_ddi_vswing_sequence(struct intel_encoder *encoder,
1417 1418
				    const struct intel_crtc_state *crtc_state,
				    int level)
1419
{
1420
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1421
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1422

1423
	if (intel_phy_is_combo(dev_priv, phy))
1424
		icl_combo_phy_ddi_vswing_sequence(encoder, crtc_state, level);
1425
	else
1426
		icl_mg_phy_ddi_vswing_sequence(encoder, crtc_state, level);
1427 1428
}

1429
static void
1430 1431 1432
tgl_dkl_phy_ddi_vswing_sequence(struct intel_encoder *encoder,
				const struct intel_crtc_state *crtc_state,
				int level)
1433 1434 1435 1436
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum tc_port tc_port = intel_port_to_tc(dev_priv, encoder->port);
	const struct tgl_dkl_phy_ddi_buf_trans *ddi_translations;
1437 1438
	u32 val, dpcnt_mask, dpcnt_val;
	int n_entries, ln;
1439

1440 1441 1442
	if (enc_to_dig_port(encoder)->tc_mode == TC_PORT_TBT_ALT)
		return;

1443
	ddi_translations = tgl_get_dkl_buf_trans(encoder, crtc_state, &n_entries);
1444

1445 1446 1447
	if (drm_WARN_ON_ONCE(&dev_priv->drm, !ddi_translations))
		return;
	if (drm_WARN_ON_ONCE(&dev_priv->drm, level >= n_entries))
1448 1449 1450 1451 1452 1453 1454 1455 1456 1457
		level = n_entries - 1;

	dpcnt_mask = (DKL_TX_PRESHOOT_COEFF_MASK |
		      DKL_TX_DE_EMPAHSIS_COEFF_MASK |
		      DKL_TX_VSWING_CONTROL_MASK);
	dpcnt_val = DKL_TX_VSWING_CONTROL(ddi_translations[level].dkl_vswing_control);
	dpcnt_val |= DKL_TX_DE_EMPHASIS_COEFF(ddi_translations[level].dkl_de_emphasis_control);
	dpcnt_val |= DKL_TX_PRESHOOT_COEFF(ddi_translations[level].dkl_preshoot_control);

	for (ln = 0; ln < 2; ln++) {
1458 1459
		intel_de_write(dev_priv, HIP_INDEX_REG(tc_port),
			       HIP_INDEX_VAL(tc_port, ln));
1460

1461
		intel_de_write(dev_priv, DKL_TX_PMD_LANE_SUS(tc_port), 0);
1462

1463
		/* All the registers are RMW */
1464
		val = intel_de_read(dev_priv, DKL_TX_DPCNTL0(tc_port));
1465 1466
		val &= ~dpcnt_mask;
		val |= dpcnt_val;
1467
		intel_de_write(dev_priv, DKL_TX_DPCNTL0(tc_port), val);
1468

1469
		val = intel_de_read(dev_priv, DKL_TX_DPCNTL1(tc_port));
1470 1471
		val &= ~dpcnt_mask;
		val |= dpcnt_val;
1472
		intel_de_write(dev_priv, DKL_TX_DPCNTL1(tc_port), val);
1473

1474
		val = intel_de_read(dev_priv, DKL_TX_DPCNTL2(tc_port));
1475
		val &= ~DKL_TX_DP20BITMODE;
1476
		intel_de_write(dev_priv, DKL_TX_DPCNTL2(tc_port), val);
1477 1478 1479 1480
	}
}

static void tgl_ddi_vswing_sequence(struct intel_encoder *encoder,
1481 1482
				    const struct intel_crtc_state *crtc_state,
				    int level)
1483 1484 1485 1486 1487
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);

	if (intel_phy_is_combo(dev_priv, phy))
1488
		icl_combo_phy_ddi_vswing_sequence(encoder, crtc_state, level);
1489
	else
1490
		tgl_dkl_phy_ddi_vswing_sequence(encoder, crtc_state, level);
1491 1492
}

1493 1494
static int translate_signal_level(struct intel_dp *intel_dp,
				  u8 signal_levels)
1495
{
1496
	struct drm_i915_private *i915 = dp_to_i915(intel_dp);
1497
	int i;
1498

1499 1500 1501
	for (i = 0; i < ARRAY_SIZE(index_to_dp_signal_levels); i++) {
		if (index_to_dp_signal_levels[i] == signal_levels)
			return i;
1502 1503
	}

1504 1505 1506
	drm_WARN(&i915->drm, 1,
		 "Unsupported voltage swing/pre-emphasis level: 0x%x\n",
		 signal_levels);
1507 1508

	return 0;
1509 1510
}

1511
static int intel_ddi_dp_level(struct intel_dp *intel_dp)
1512
{
1513
	u8 train_set = intel_dp->train_set[0];
1514 1515
	u8 signal_levels = train_set & (DP_TRAIN_VOLTAGE_SWING_MASK |
					DP_TRAIN_PRE_EMPHASIS_MASK);
1516

1517
	return translate_signal_level(intel_dp, signal_levels);
1518 1519
}

1520
static void
1521 1522
tgl_set_signal_levels(struct intel_dp *intel_dp,
		      const struct intel_crtc_state *crtc_state)
1523
{
1524
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
1525
	int level = intel_ddi_dp_level(intel_dp);
1526

1527
	tgl_ddi_vswing_sequence(encoder, crtc_state, level);
1528
}
1529

1530
static void
1531 1532
icl_set_signal_levels(struct intel_dp *intel_dp,
		      const struct intel_crtc_state *crtc_state)
1533 1534 1535 1536
{
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	int level = intel_ddi_dp_level(intel_dp);

1537
	icl_ddi_vswing_sequence(encoder, crtc_state, level);
1538 1539
}

1540
static void
1541 1542
cnl_set_signal_levels(struct intel_dp *intel_dp,
		      const struct intel_crtc_state *crtc_state)
1543
{
1544
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
1545
	int level = intel_ddi_dp_level(intel_dp);
1546

1547
	cnl_ddi_vswing_sequence(encoder, crtc_state, level);
1548 1549 1550
}

static void
1551 1552
bxt_set_signal_levels(struct intel_dp *intel_dp,
		      const struct intel_crtc_state *crtc_state)
1553 1554 1555 1556
{
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	int level = intel_ddi_dp_level(intel_dp);

1557
	bxt_ddi_vswing_sequence(encoder, crtc_state, level);
1558 1559 1560
}

static void
1561 1562
hsw_set_signal_levels(struct intel_dp *intel_dp,
		      const struct intel_crtc_state *crtc_state)
1563 1564 1565 1566 1567 1568 1569 1570 1571 1572 1573 1574 1575 1576 1577
{
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	int level = intel_ddi_dp_level(intel_dp);
	enum port port = encoder->port;
	u32 signal_levels;

	signal_levels = DDI_BUF_TRANS_SELECT(level);

	drm_dbg_kms(&dev_priv->drm, "Using signal levels %08x\n",
		    signal_levels);

	intel_dp->DP &= ~DDI_BUF_EMP_MASK;
	intel_dp->DP |= signal_levels;

1578
	if (IS_GEN9_BC(dev_priv))
1579
		skl_ddi_set_iboost(encoder, crtc_state, level);
1580

1581 1582
	intel_de_write(dev_priv, DDI_BUF_CTL(port), intel_dp->DP);
	intel_de_posting_read(dev_priv, DDI_BUF_CTL(port));
1583 1584
}

1585 1586
static u32 icl_dpclka_cfgcr0_clk_off(struct drm_i915_private *dev_priv,
				     enum phy phy)
1587
{
1588 1589 1590
	if (IS_ROCKETLAKE(dev_priv)) {
		return RKL_DPCLKA_CFGCR0_DDI_CLK_OFF(phy);
	} else if (intel_phy_is_combo(dev_priv, phy)) {
1591 1592 1593 1594
		return ICL_DPCLKA_CFGCR0_DDI_CLK_OFF(phy);
	} else if (intel_phy_is_tc(dev_priv, phy)) {
		enum tc_port tc_port = intel_port_to_tc(dev_priv,
							(enum port)phy);
1595 1596 1597 1598 1599 1600 1601

		return ICL_DPCLKA_CFGCR0_TC_CLK_OFF(tc_port);
	}

	return 0;
}

1602 1603 1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 1634 1635
static void dg1_map_plls_to_ports(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	struct intel_shared_dpll *pll = crtc_state->shared_dpll;
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
	u32 val;

	/*
	 * If we fail this, something went very wrong: first 2 PLLs should be
	 * used by first 2 phys and last 2 PLLs by last phys
	 */
	if (drm_WARN_ON(&dev_priv->drm,
			(pll->info->id < DPLL_ID_DG1_DPLL2 && phy >= PHY_C) ||
			(pll->info->id >= DPLL_ID_DG1_DPLL2 && phy < PHY_C)))
		return;

	mutex_lock(&dev_priv->dpll.lock);

	val = intel_de_read(dev_priv, DG1_DPCLKA_CFGCR0(phy));
	drm_WARN_ON(&dev_priv->drm,
		    (val & DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy)) == 0);

	val &= ~DG1_DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(phy);
	val |= DG1_DPCLKA_CFGCR0_DDI_CLK_SEL(pll->info->id, phy);
	intel_de_write(dev_priv, DG1_DPCLKA_CFGCR0(phy), val);
	intel_de_posting_read(dev_priv, DG1_DPCLKA_CFGCR0(phy));

	val &= ~DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy);
	intel_de_write(dev_priv, DG1_DPCLKA_CFGCR0(phy), val);

	mutex_unlock(&dev_priv->dpll.lock);
}

1636 1637
static void icl_map_plls_to_ports(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state)
1638
{
1639
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1640
	struct intel_shared_dpll *pll = crtc_state->shared_dpll;
1641
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1642 1643 1644 1645 1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657
	u32 val, mask, sel;
	i915_reg_t reg;

	if (IS_ALDERLAKE_S(dev_priv)) {
		reg = ADLS_DPCLKA_CFGCR(phy);
		mask = ADLS_DPCLKA_CFGCR_DDI_CLK_SEL_MASK(phy);
		sel = ((pll->info->id) << ADLS_DPCLKA_CFGCR_DDI_SHIFT(phy));
	} else if (IS_ROCKETLAKE(dev_priv)) {
		reg = ICL_DPCLKA_CFGCR0;
		mask = RKL_DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(phy);
		sel = RKL_DPCLKA_CFGCR0_DDI_CLK_SEL(pll->info->id, phy);
	} else {
		reg = ICL_DPCLKA_CFGCR0;
		mask = ICL_DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(phy);
		sel = ICL_DPCLKA_CFGCR0_DDI_CLK_SEL(pll->info->id, phy);
	}
1658

1659
	mutex_lock(&dev_priv->dpll.lock);
1660

1661
	val = intel_de_read(dev_priv, reg);
1662 1663
	drm_WARN_ON(&dev_priv->drm,
		    (val & icl_dpclka_cfgcr0_clk_off(dev_priv, phy)) == 0);
1664

1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675
	if (intel_phy_is_combo(dev_priv, phy)) {
		/*
		 * Even though this register references DDIs, note that we
		 * want to pass the PHY rather than the port (DDI).  For
		 * ICL, port=phy in all cases so it doesn't matter, but for
		 * EHL the bspec notes the following:
		 *
		 *   "DDID clock tied to DDIA clock, so DPCLKA_CFGCR0 DDIA
		 *   Clock Select chooses the PLL for both DDIA and DDID and
		 *   drives port A in all cases."
		 */
1676 1677
		val &= ~mask;
		val |= sel;
1678 1679
		intel_de_write(dev_priv, reg, val);
		intel_de_posting_read(dev_priv, reg);
1680
	}
1681

1682
	val &= ~icl_dpclka_cfgcr0_clk_off(dev_priv, phy);
1683
	intel_de_write(dev_priv, reg, val);
1684

1685
	mutex_unlock(&dev_priv->dpll.lock);
1686 1687
}

1688 1689 1690 1691 1692 1693 1694 1695 1696 1697 1698 1699 1700
static void dg1_unmap_plls_to_ports(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);

	mutex_lock(&dev_priv->dpll.lock);

	intel_de_rmw(dev_priv, DG1_DPCLKA_CFGCR0(phy), 0,
		     DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy));

	mutex_unlock(&dev_priv->dpll.lock);
}

1701
static void icl_unmap_plls_to_ports(struct intel_encoder *encoder)
1702
{
1703
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1704
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1705
	u32 val;
1706
	i915_reg_t reg;
1707

1708
	mutex_lock(&dev_priv->dpll.lock);
1709

1710 1711 1712 1713 1714 1715
	if (IS_ALDERLAKE_S(dev_priv))
		reg = ADLS_DPCLKA_CFGCR(phy);
	else
		reg = ICL_DPCLKA_CFGCR0;

	val = intel_de_read(dev_priv, reg);
1716
	val |= icl_dpclka_cfgcr0_clk_off(dev_priv, phy);
1717 1718

	intel_de_write(dev_priv, reg, val);
1719

1720
	mutex_unlock(&dev_priv->dpll.lock);
1721 1722
}

1723 1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737 1738 1739 1740 1741 1742 1743 1744 1745 1746 1747 1748 1749 1750 1751 1752 1753
static void dg1_sanitize_port_clk_off(struct drm_i915_private *dev_priv,
				      u32 port_mask, bool ddi_clk_needed)
{
	enum port port;
	u32 val;

	for_each_port_masked(port, port_mask) {
		enum phy phy = intel_port_to_phy(dev_priv, port);
		bool ddi_clk_off;

		val = intel_de_read(dev_priv, DG1_DPCLKA_CFGCR0(phy));
		ddi_clk_off = val & DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy);

		if (ddi_clk_needed == !ddi_clk_off)
			continue;

		/*
		 * Punt on the case now where clock is gated, but it would
		 * be needed by the port. Something else is really broken then.
		 */
		if (drm_WARN_ON(&dev_priv->drm, ddi_clk_needed))
			continue;

		drm_notice(&dev_priv->drm,
			   "PHY %c is disabled with an ungated DDI clock, gate it\n",
			   phy_name(phy));
		val |= DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy);
		intel_de_write(dev_priv, DG1_DPCLKA_CFGCR0(phy), val);
	}
}

1754 1755 1756 1757
static void icl_sanitize_port_clk_off(struct drm_i915_private *dev_priv,
				      u32 port_mask, bool ddi_clk_needed)
{
	enum port port;
1758
	bool ddi_clk_off;
1759
	u32 val;
1760
	i915_reg_t reg;
1761 1762 1763

	for_each_port_masked(port, port_mask) {
		enum phy phy = intel_port_to_phy(dev_priv, port);
1764 1765 1766 1767 1768 1769 1770 1771 1772

		if (IS_ALDERLAKE_S(dev_priv))
			reg = ADLS_DPCLKA_CFGCR(phy);
		else
			reg = ICL_DPCLKA_CFGCR0;

		val = intel_de_read(dev_priv, reg);
		ddi_clk_off = val & icl_dpclka_cfgcr0_clk_off(dev_priv,
							      phy);
1773

1774
		if (ddi_clk_needed == !ddi_clk_off)
1775 1776 1777 1778 1779 1780
			continue;

		/*
		 * Punt on the case now where clock is gated, but it would
		 * be needed by the port. Something else is really broken then.
		 */
1781
		if (drm_WARN_ON(&dev_priv->drm, ddi_clk_needed))
1782 1783
			continue;

1784 1785 1786
		drm_notice(&dev_priv->drm,
			   "PHY %c is disabled/in DSI mode with an ungated DDI clock, gate it\n",
			   phy_name(phy));
1787
		val |= icl_dpclka_cfgcr0_clk_off(dev_priv, phy);
1788
		intel_de_write(dev_priv, reg, val);
1789 1790 1791
	}
}

1792 1793 1794
void icl_sanitize_encoder_pll_mapping(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1795 1796
	u32 port_mask;
	bool ddi_clk_needed;
1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812 1813

	/*
	 * In case of DP MST, we sanitize the primary encoder only, not the
	 * virtual ones.
	 */
	if (encoder->type == INTEL_OUTPUT_DP_MST)
		return;

	if (!encoder->base.crtc && intel_encoder_is_dp(encoder)) {
		u8 pipe_mask;
		bool is_mst;

		intel_ddi_get_encoder_pipes(encoder, &pipe_mask, &is_mst);
		/*
		 * In the unlikely case that BIOS enables DP in MST mode, just
		 * warn since our MST HW readout is incomplete.
		 */
1814
		if (drm_WARN_ON(&dev_priv->drm, is_mst))
1815 1816
			return;
	}
1817

1818 1819
	port_mask = BIT(encoder->port);
	ddi_clk_needed = encoder->base.crtc;
1820

1821 1822
	if (encoder->type == INTEL_OUTPUT_DSI) {
		struct intel_encoder *other_encoder;
1823

1824 1825 1826 1827 1828 1829 1830 1831 1832
		port_mask = intel_dsi_encoder_ports(encoder);
		/*
		 * Sanity check that we haven't incorrectly registered another
		 * encoder using any of the ports of this DSI encoder.
		 */
		for_each_intel_encoder(&dev_priv->drm, other_encoder) {
			if (other_encoder == encoder)
				continue;

1833 1834
			if (drm_WARN_ON(&dev_priv->drm,
					port_mask & BIT(other_encoder->port)))
1835 1836 1837
				return;
		}
		/*
1838 1839
		 * For DSI we keep the ddi clocks gated
		 * except during enable/disable sequence.
1840
		 */
1841
		ddi_clk_needed = false;
1842 1843
	}

1844 1845 1846 1847
	if (IS_DG1(dev_priv))
		dg1_sanitize_port_clk_off(dev_priv, port_mask, ddi_clk_needed);
	else
		icl_sanitize_port_clk_off(dev_priv, port_mask, ddi_clk_needed);
1848 1849
}

1850 1851
void intel_ddi_clk_select(struct intel_encoder *encoder,
			  const struct intel_crtc_state *crtc_state)
1852
{
1853
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1854
	enum port port = encoder->port;
1855
	enum phy phy = intel_port_to_phy(dev_priv, port);
1856
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
1857

1858
	if (drm_WARN_ON(&dev_priv->drm, !pll))
1859 1860
		return;

1861
	mutex_lock(&dev_priv->dpll.lock);
1862

1863
	if (INTEL_GEN(dev_priv) >= 11) {
1864
		if (!intel_phy_is_combo(dev_priv, phy))
1865 1866
			intel_de_write(dev_priv, DDI_CLK_SEL(port),
				       icl_pll_to_ddi_clk_sel(encoder, crtc_state));
1867
		else if (IS_JSL_EHL(dev_priv) && port >= PORT_C)
1868 1869 1870 1871
			/*
			 * MG does not exist but the programming is required
			 * to ungate DDIC and DDID
			 */
1872 1873
			intel_de_write(dev_priv, DDI_CLK_SEL(port),
				       DDI_CLK_SEL_MG);
1874
	}
1875

1876
	mutex_unlock(&dev_priv->dpll.lock);
1877 1878
}

1879 1880 1881
static void intel_ddi_clk_disable(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1882
	enum port port = encoder->port;
1883
	enum phy phy = intel_port_to_phy(dev_priv, port);
1884

1885
	if (INTEL_GEN(dev_priv) >= 11) {
1886
		if (!intel_phy_is_combo(dev_priv, phy) ||
1887
		    (IS_JSL_EHL(dev_priv) && port >= PORT_C))
1888 1889
			intel_de_write(dev_priv, DDI_CLK_SEL(port),
				       DDI_CLK_SEL_NONE);
1890
	}
1891 1892
}

1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912 1913 1914 1915 1916 1917 1918 1919 1920 1921 1922 1923 1924 1925 1926 1927 1928 1929 1930
static void cnl_ddi_enable_clock(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
	enum port port = encoder->port;
	u32 val;

	if (drm_WARN_ON(&i915->drm, !pll))
		return;

	mutex_lock(&i915->dpll.lock);

	val = intel_de_read(i915, DPCLKA_CFGCR0);
	val &= ~DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(port);
	val |= DPCLKA_CFGCR0_DDI_CLK_SEL(pll->info->id, port);
	intel_de_write(i915, DPCLKA_CFGCR0, val);

	/*
	 * "This step and the step before must be
	 *  done with separate register writes."
	 */
	val = intel_de_read(i915, DPCLKA_CFGCR0);
	val &= ~DPCLKA_CFGCR0_DDI_CLK_OFF(port);
	intel_de_write(i915, DPCLKA_CFGCR0, val);

	mutex_unlock(&i915->dpll.lock);
}

static void cnl_ddi_disable_clock(struct intel_encoder *encoder)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	enum port port = encoder->port;

	intel_de_write(i915, DPCLKA_CFGCR0,
		       intel_de_read(i915, DPCLKA_CFGCR0) | DPCLKA_CFGCR0_DDI_CLK_OFF(port));
}

1931 1932 1933 1934 1935 1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947 1948 1949 1950 1951 1952 1953 1954 1955 1956 1957 1958 1959 1960 1961 1962 1963 1964
static void skl_ddi_enable_clock(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
	enum port port = encoder->port;
	u32 val;

	if (drm_WARN_ON(&i915->drm, !pll))
		return;

	mutex_lock(&i915->dpll.lock);

	val = intel_de_read(i915, DPLL_CTRL2);

	val &= ~(DPLL_CTRL2_DDI_CLK_OFF(port) |
		 DPLL_CTRL2_DDI_CLK_SEL_MASK(port));
	val |= (DPLL_CTRL2_DDI_CLK_SEL(pll->info->id, port) |
		DPLL_CTRL2_DDI_SEL_OVERRIDE(port));

	intel_de_write(i915, DPLL_CTRL2, val);

	mutex_unlock(&i915->dpll.lock);
}

static void skl_ddi_disable_clock(struct intel_encoder *encoder)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	enum port port = encoder->port;

	intel_de_write(i915, DPLL_CTRL2,
		       intel_de_read(i915, DPLL_CTRL2) | DPLL_CTRL2_DDI_CLK_OFF(port));
}

1965 1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984 1985
void hsw_ddi_enable_clock(struct intel_encoder *encoder,
			  const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
	enum port port = encoder->port;

	if (drm_WARN_ON(&i915->drm, !pll))
		return;

	intel_de_write(i915, PORT_CLK_SEL(port), hsw_pll_to_ddi_pll_sel(pll));
}

void hsw_ddi_disable_clock(struct intel_encoder *encoder)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	enum port port = encoder->port;

	intel_de_write(i915, PORT_CLK_SEL(port), PORT_CLK_SEL_NONE);
}

1986 1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999 2000 2001 2002
void intel_ddi_enable_clock(struct intel_encoder *encoder,
			    const struct intel_crtc_state *crtc_state)
{
	if (encoder->enable_clock)
		encoder->enable_clock(encoder, crtc_state);
	else
		intel_ddi_clk_select(encoder, crtc_state);
}

static void intel_ddi_disable_clock(struct intel_encoder *encoder)
{
	if (encoder->disable_clock)
		encoder->disable_clock(encoder);
	else
		intel_ddi_clk_disable(encoder);
}

2003
static void
2004
icl_program_mg_dp_mode(struct intel_digital_port *dig_port,
2005
		       const struct intel_crtc_state *crtc_state)
2006
{
2007 2008
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
	enum tc_port tc_port = intel_port_to_tc(dev_priv, dig_port->base.port);
2009
	enum phy phy = intel_port_to_phy(dev_priv, dig_port->base.port);
2010 2011
	u32 ln0, ln1, pin_assignment;
	u8 width;
2012

2013 2014
	if (!intel_phy_is_tc(dev_priv, phy) ||
	    dig_port->tc_mode == TC_PORT_TBT_ALT)
2015 2016
		return;

2017
	if (INTEL_GEN(dev_priv) >= 12) {
2018 2019 2020 2021 2022 2023
		intel_de_write(dev_priv, HIP_INDEX_REG(tc_port),
			       HIP_INDEX_VAL(tc_port, 0x0));
		ln0 = intel_de_read(dev_priv, DKL_DP_MODE(tc_port));
		intel_de_write(dev_priv, HIP_INDEX_REG(tc_port),
			       HIP_INDEX_VAL(tc_port, 0x1));
		ln1 = intel_de_read(dev_priv, DKL_DP_MODE(tc_port));
2024
	} else {
2025 2026
		ln0 = intel_de_read(dev_priv, MG_DP_MODE(0, tc_port));
		ln1 = intel_de_read(dev_priv, MG_DP_MODE(1, tc_port));
2027
	}
2028

2029
	ln0 &= ~(MG_DP_MODE_CFG_DP_X1_MODE | MG_DP_MODE_CFG_DP_X2_MODE);
2030
	ln1 &= ~(MG_DP_MODE_CFG_DP_X1_MODE | MG_DP_MODE_CFG_DP_X2_MODE);
2031

2032
	/* DPPATC */
2033
	pin_assignment = intel_tc_port_get_pin_assignment_mask(dig_port);
2034
	width = crtc_state->lane_count;
2035

2036 2037
	switch (pin_assignment) {
	case 0x0:
2038
		drm_WARN_ON(&dev_priv->drm,
2039
			    dig_port->tc_mode != TC_PORT_LEGACY);
2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058 2059 2060 2061
		if (width == 1) {
			ln1 |= MG_DP_MODE_CFG_DP_X1_MODE;
		} else {
			ln0 |= MG_DP_MODE_CFG_DP_X2_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X2_MODE;
		}
		break;
	case 0x1:
		if (width == 4) {
			ln0 |= MG_DP_MODE_CFG_DP_X2_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X2_MODE;
		}
		break;
	case 0x2:
		if (width == 2) {
			ln0 |= MG_DP_MODE_CFG_DP_X2_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X2_MODE;
		}
		break;
	case 0x3:
	case 0x5:
		if (width == 1) {
2062 2063
			ln0 |= MG_DP_MODE_CFG_DP_X1_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X1_MODE;
2064 2065 2066
		} else {
			ln0 |= MG_DP_MODE_CFG_DP_X2_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X2_MODE;
2067 2068
		}
		break;
2069 2070 2071 2072 2073 2074 2075 2076 2077
	case 0x4:
	case 0x6:
		if (width == 1) {
			ln0 |= MG_DP_MODE_CFG_DP_X1_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X1_MODE;
		} else {
			ln0 |= MG_DP_MODE_CFG_DP_X2_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X2_MODE;
		}
2078 2079
		break;
	default:
2080
		MISSING_CASE(pin_assignment);
2081 2082
	}

2083
	if (INTEL_GEN(dev_priv) >= 12) {
2084 2085 2086 2087 2088 2089
		intel_de_write(dev_priv, HIP_INDEX_REG(tc_port),
			       HIP_INDEX_VAL(tc_port, 0x0));
		intel_de_write(dev_priv, DKL_DP_MODE(tc_port), ln0);
		intel_de_write(dev_priv, HIP_INDEX_REG(tc_port),
			       HIP_INDEX_VAL(tc_port, 0x1));
		intel_de_write(dev_priv, DKL_DP_MODE(tc_port), ln1);
2090
	} else {
2091 2092
		intel_de_write(dev_priv, MG_DP_MODE(0, tc_port), ln0);
		intel_de_write(dev_priv, MG_DP_MODE(1, tc_port), ln1);
2093
	}
2094 2095
}

2096 2097 2098 2099 2100 2101 2102 2103 2104 2105 2106 2107 2108 2109 2110 2111 2112 2113 2114 2115 2116 2117 2118 2119 2120 2121 2122 2123 2124 2125 2126
static enum transcoder
tgl_dp_tp_transcoder(const struct intel_crtc_state *crtc_state)
{
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST))
		return crtc_state->mst_master_transcoder;
	else
		return crtc_state->cpu_transcoder;
}

i915_reg_t dp_tp_ctl_reg(struct intel_encoder *encoder,
			 const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);

	if (INTEL_GEN(dev_priv) >= 12)
		return TGL_DP_TP_CTL(tgl_dp_tp_transcoder(crtc_state));
	else
		return DP_TP_CTL(encoder->port);
}

i915_reg_t dp_tp_status_reg(struct intel_encoder *encoder,
			    const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);

	if (INTEL_GEN(dev_priv) >= 12)
		return TGL_DP_TP_STATUS(tgl_dp_tp_transcoder(crtc_state));
	else
		return DP_TP_STATUS(encoder->port);
}

2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139 2140 2141 2142
static void intel_dp_sink_set_msa_timing_par_ignore_state(struct intel_dp *intel_dp,
							  const struct intel_crtc_state *crtc_state,
							  bool enable)
{
	struct drm_i915_private *i915 = dp_to_i915(intel_dp);

	if (!crtc_state->vrr.enable)
		return;

	if (drm_dp_dpcd_writeb(&intel_dp->aux, DP_DOWNSPREAD_CTRL,
			       enable ? DP_MSA_TIMING_PAR_IGNORE_EN : 0) <= 0)
		drm_dbg_kms(&i915->drm,
			    "Failed to set MSA_TIMING_PAR_IGNORE %s in the sink\n",
			    enable ? "enable" : "disable");
}

2143 2144 2145
static void intel_dp_sink_set_fec_ready(struct intel_dp *intel_dp,
					const struct intel_crtc_state *crtc_state)
{
2146 2147
	struct drm_i915_private *i915 = dp_to_i915(intel_dp);

2148 2149 2150 2151
	if (!crtc_state->fec_enable)
		return;

	if (drm_dp_dpcd_writeb(&intel_dp->aux, DP_FEC_CONFIGURATION, DP_FEC_READY) <= 0)
2152 2153
		drm_dbg_kms(&i915->drm,
			    "Failed to set FEC_READY in the sink\n");
2154 2155
}

2156 2157 2158 2159
static void intel_ddi_enable_fec(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2160
	struct intel_dp *intel_dp;
2161 2162 2163 2164 2165
	u32 val;

	if (!crtc_state->fec_enable)
		return;

2166
	intel_dp = enc_to_intel_dp(encoder);
2167
	val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
2168
	val |= DP_TP_CTL_FEC_ENABLE;
2169
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
2170 2171
}

A
Anusha Srivatsa 已提交
2172 2173 2174 2175
static void intel_ddi_disable_fec_state(struct intel_encoder *encoder,
					const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2176
	struct intel_dp *intel_dp;
A
Anusha Srivatsa 已提交
2177 2178 2179 2180 2181
	u32 val;

	if (!crtc_state->fec_enable)
		return;

2182
	intel_dp = enc_to_intel_dp(encoder);
2183
	val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
A
Anusha Srivatsa 已提交
2184
	val &= ~DP_TP_CTL_FEC_ENABLE;
2185 2186
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
	intel_de_posting_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
A
Anusha Srivatsa 已提交
2187 2188
}

2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202 2203 2204 2205
static void intel_ddi_power_up_lanes(struct intel_encoder *encoder,
				     const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
	enum phy phy = intel_port_to_phy(i915, encoder->port);

	if (intel_phy_is_combo(i915, phy)) {
		bool lane_reversal =
			dig_port->saved_port_bits & DDI_BUF_PORT_REVERSAL;

		intel_combo_phy_power_up_lanes(i915, phy, false,
					       crtc_state->lane_count,
					       lane_reversal);
	}
}

2206 2207
static void tgl_ddi_pre_enable_dp(struct intel_atomic_state *state,
				  struct intel_encoder *encoder,
2208 2209 2210
				  const struct intel_crtc_state *crtc_state,
				  const struct drm_connector_state *conn_state)
{
2211
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2212 2213
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
2214
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2215 2216 2217
	bool is_mst = intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST);
	int level = intel_ddi_dp_level(intel_dp);

2218 2219 2220
	intel_dp_set_link_params(intel_dp,
				 crtc_state->port_clock,
				 crtc_state->lane_count);
2221

2222 2223 2224 2225 2226 2227
	/*
	 * 1. Enable Power Wells
	 *
	 * This was handled at the beginning of intel_atomic_commit_tail(),
	 * before we called down into this function.
	 */
2228

2229
	/* 2. Enable Panel Power if PPS is required */
2230
	intel_pps_on(intel_dp);
2231 2232

	/*
2233 2234 2235 2236
	 * 3. For non-TBT Type-C ports, set FIA lane count
	 * (DFLEXDPSP.DPX4TXLATC)
	 *
	 * This was done before tgl_ddi_pre_enable_dp by
2237
	 * hsw_crtc_enable()->intel_encoders_pre_pll_enable().
2238 2239
	 */

2240 2241 2242 2243
	/*
	 * 4. Enable the port PLL.
	 *
	 * The PLL enabling itself was already done before this function by
2244
	 * hsw_crtc_enable()->intel_enable_shared_dpll().  We need only
2245 2246
	 * configure the PLL to port mapping here.
	 */
2247
	intel_ddi_enable_clock(encoder, crtc_state);
2248

2249
	/* 5. If IO power is controlled through PWR_WELL_CTL, Enable IO Power */
2250
	if (!intel_phy_is_tc(dev_priv, phy) ||
2251 2252 2253 2254 2255
	    dig_port->tc_mode != TC_PORT_TBT_ALT) {
		drm_WARN_ON(&dev_priv->drm, dig_port->ddi_io_wakeref);
		dig_port->ddi_io_wakeref = intel_display_power_get(dev_priv,
								   dig_port->ddi_io_power_domain);
	}
2256

2257
	/* 6. Program DP_MODE */
2258
	icl_program_mg_dp_mode(dig_port, crtc_state);
2259 2260

	/*
2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272
	 * 7. The rest of the below are substeps under the bspec's "Enable and
	 * Train Display Port" step.  Note that steps that are specific to
	 * MST will be handled by intel_mst_pre_enable_dp() before/after it
	 * calls into this function.  Also intel_mst_pre_enable_dp() only calls
	 * us when active_mst_links==0, so any steps designated for "single
	 * stream or multi-stream master transcoder" can just be performed
	 * unconditionally here.
	 */

	/*
	 * 7.a Configure Transcoder Clock Select to direct the Port clock to the
	 * Transcoder.
2273
	 */
2274
	intel_ddi_enable_pipe_clock(encoder, crtc_state);
2275

2276 2277 2278 2279
	/*
	 * 7.b Configure TRANS_DDI_FUNC_CTL DDI Select, DDI Mode Select & MST
	 * Transport Select
	 */
2280
	intel_ddi_config_transcoder_func(encoder, crtc_state);
2281

2282 2283 2284 2285 2286 2287 2288 2289 2290
	/*
	 * 7.c Configure & enable DP_TP_CTL with link training pattern 1
	 * selected
	 *
	 * This will be handled by the intel_dp_start_link_train() farther
	 * down this function.
	 */

	/* 7.e Configure voltage swing and related IO settings */
2291
	tgl_ddi_vswing_sequence(encoder, crtc_state, level);
2292

2293 2294 2295 2296
	/*
	 * 7.f Combo PHY: Configure PORT_CL_DW10 Static Power Down to power up
	 * the used lanes of the DDI.
	 */
2297
	intel_ddi_power_up_lanes(encoder, crtc_state);
2298

2299 2300 2301 2302 2303 2304 2305 2306
	/*
	 * 7.g Configure and enable DDI_BUF_CTL
	 * 7.h Wait for DDI_BUF_CTL DDI Idle Status = 0b (Not Idle), timeout
	 *     after 500 us.
	 *
	 * We only configure what the register value will be here.  Actual
	 * enabling happens during link training farther down.
	 */
2307
	intel_ddi_init_dp_buf_reg(encoder, crtc_state);
2308 2309

	if (!is_mst)
2310
		intel_dp_set_power(intel_dp, DP_SET_POWER_D0);
2311

2312
	intel_dp_configure_protocol_converter(intel_dp, crtc_state);
2313 2314 2315 2316 2317 2318 2319
	intel_dp_sink_set_decompression_state(intel_dp, crtc_state, true);
	/*
	 * DDI FEC: "anticipates enabling FEC encoding sets the FEC_READY bit
	 * in the FEC_CONFIGURATION register to 1 before initiating link
	 * training
	 */
	intel_dp_sink_set_fec_ready(intel_dp, crtc_state);
2320

2321
	intel_dp_check_frl_training(intel_dp);
2322
	intel_dp_pcon_dsc_configure(intel_dp, crtc_state);
2323

2324 2325 2326 2327 2328 2329 2330
	/*
	 * 7.i Follow DisplayPort specification training sequence (see notes for
	 *     failure handling)
	 * 7.j If DisplayPort multi-stream - Set DP_TP_CTL link training to Idle
	 *     Pattern, wait for 5 idle patterns (DP_TP_STATUS Min_Idles_Sent)
	 *     (timeout after 800 us)
	 */
2331
	intel_dp_start_link_train(intel_dp, crtc_state);
2332

2333
	/* 7.k Set DP_TP_CTL link training to Normal */
2334
	if (!is_trans_port_sync_mode(crtc_state))
2335
		intel_dp_stop_link_train(intel_dp, crtc_state);
2336

2337
	/* 7.l Configure and enable FEC if needed */
2338
	intel_ddi_enable_fec(encoder, crtc_state);
2339 2340
	if (!crtc_state->bigjoiner)
		intel_dsc_enable(encoder, crtc_state);
2341 2342
}

2343 2344
static void hsw_ddi_pre_enable_dp(struct intel_atomic_state *state,
				  struct intel_encoder *encoder,
2345 2346
				  const struct intel_crtc_state *crtc_state,
				  const struct drm_connector_state *conn_state)
2347
{
2348
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2349
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2350
	enum port port = encoder->port;
2351
	enum phy phy = intel_port_to_phy(dev_priv, port);
2352
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2353
	bool is_mst = intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST);
2354
	int level = intel_ddi_dp_level(intel_dp);
2355

2356
	if (INTEL_GEN(dev_priv) < 11)
2357 2358
		drm_WARN_ON(&dev_priv->drm,
			    is_mst && (port == PORT_A || port == PORT_E));
2359
	else
2360
		drm_WARN_ON(&dev_priv->drm, is_mst && port == PORT_A);
2361

2362 2363 2364
	intel_dp_set_link_params(intel_dp,
				 crtc_state->port_clock,
				 crtc_state->lane_count);
2365

2366
	intel_pps_on(intel_dp);
2367

2368
	intel_ddi_enable_clock(encoder, crtc_state);
2369

2370
	if (!intel_phy_is_tc(dev_priv, phy) ||
2371 2372 2373 2374 2375
	    dig_port->tc_mode != TC_PORT_TBT_ALT) {
		drm_WARN_ON(&dev_priv->drm, dig_port->ddi_io_wakeref);
		dig_port->ddi_io_wakeref = intel_display_power_get(dev_priv,
								   dig_port->ddi_io_power_domain);
	}
2376

2377
	icl_program_mg_dp_mode(dig_port, crtc_state);
P
Paulo Zanoni 已提交
2378

2379
	if (INTEL_GEN(dev_priv) >= 11)
2380
		icl_ddi_vswing_sequence(encoder, crtc_state, level);
2381
	else if (IS_CANNONLAKE(dev_priv))
2382
		cnl_ddi_vswing_sequence(encoder, crtc_state, level);
2383
	else if (IS_GEN9_LP(dev_priv))
2384
		bxt_ddi_vswing_sequence(encoder, crtc_state, level);
2385
	else
2386
		intel_prepare_dp_ddi_buffers(encoder, crtc_state);
2387

2388
	intel_ddi_power_up_lanes(encoder, crtc_state);
2389

2390
	intel_ddi_init_dp_buf_reg(encoder, crtc_state);
2391
	if (!is_mst)
2392
		intel_dp_set_power(intel_dp, DP_SET_POWER_D0);
2393
	intel_dp_configure_protocol_converter(intel_dp, crtc_state);
2394 2395
	intel_dp_sink_set_decompression_state(intel_dp, crtc_state,
					      true);
2396
	intel_dp_sink_set_fec_ready(intel_dp, crtc_state);
2397
	intel_dp_start_link_train(intel_dp, crtc_state);
2398 2399
	if ((port != PORT_A || INTEL_GEN(dev_priv) >= 9) &&
	    !is_trans_port_sync_mode(crtc_state))
2400
		intel_dp_stop_link_train(intel_dp, crtc_state);
2401

2402 2403
	intel_ddi_enable_fec(encoder, crtc_state);

2404
	if (!is_mst)
2405
		intel_ddi_enable_pipe_clock(encoder, crtc_state);
2406

2407 2408
	if (!crtc_state->bigjoiner)
		intel_dsc_enable(encoder, crtc_state);
2409
}
2410

2411 2412
static void intel_ddi_pre_enable_dp(struct intel_atomic_state *state,
				    struct intel_encoder *encoder,
2413 2414 2415 2416 2417 2418
				    const struct intel_crtc_state *crtc_state,
				    const struct drm_connector_state *conn_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);

	if (INTEL_GEN(dev_priv) >= 12)
2419
		tgl_ddi_pre_enable_dp(state, encoder, crtc_state, conn_state);
2420
	else
2421
		hsw_ddi_pre_enable_dp(state, encoder, crtc_state, conn_state);
2422

2423 2424 2425
	/* MST will call a setting of MSA after an allocating of Virtual Channel
	 * from MST encoder pre_enable callback.
	 */
2426
	if (!intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST)) {
2427
		intel_ddi_set_dp_msa(crtc_state, conn_state);
2428

2429 2430
		intel_dp_set_m_n(crtc_state, M1_N1);
	}
2431 2432
}

2433 2434
static void intel_ddi_pre_enable_hdmi(struct intel_atomic_state *state,
				      struct intel_encoder *encoder,
2435
				      const struct intel_crtc_state *crtc_state,
2436
				      const struct drm_connector_state *conn_state)
2437
{
2438 2439
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
	struct intel_hdmi *intel_hdmi = &dig_port->hdmi;
2440
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2441

2442
	intel_dp_dual_mode_set_tmds_output(intel_hdmi, true);
2443
	intel_ddi_enable_clock(encoder, crtc_state);
2444

2445 2446 2447
	drm_WARN_ON(&dev_priv->drm, dig_port->ddi_io_wakeref);
	dig_port->ddi_io_wakeref = intel_display_power_get(dev_priv,
							   dig_port->ddi_io_power_domain);
2448

2449
	icl_program_mg_dp_mode(dig_port, crtc_state);
2450

2451
	intel_ddi_enable_pipe_clock(encoder, crtc_state);
2452

2453 2454 2455
	dig_port->set_infoframes(encoder,
				 crtc_state->has_infoframe,
				 crtc_state, conn_state);
2456
}
2457

2458 2459
static void intel_ddi_pre_enable(struct intel_atomic_state *state,
				 struct intel_encoder *encoder,
2460
				 const struct intel_crtc_state *crtc_state,
2461
				 const struct drm_connector_state *conn_state)
2462
{
2463
	struct intel_crtc *crtc = to_intel_crtc(crtc_state->uapi.crtc);
2464 2465
	struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
	enum pipe pipe = crtc->pipe;
2466

2467 2468 2469 2470 2471 2472 2473 2474 2475 2476 2477 2478 2479
	/*
	 * When called from DP MST code:
	 * - conn_state will be NULL
	 * - encoder will be the main encoder (ie. mst->primary)
	 * - the main connector associated with this port
	 *   won't be active or linked to a crtc
	 * - crtc_state will be the state of the first stream to
	 *   be activated on this port, and it may not be the same
	 *   stream that will be deactivated last, but each stream
	 *   should have a state that is identical when it comes to
	 *   the DP link parameteres
	 */

2480
	drm_WARN_ON(&dev_priv->drm, crtc_state->has_pch_encoder);
2481

2482 2483 2484
	if (IS_DG1(dev_priv))
		dg1_map_plls_to_ports(encoder, crtc_state);
	else if (INTEL_GEN(dev_priv) >= 11)
2485 2486
		icl_map_plls_to_ports(encoder, crtc_state);

2487 2488
	intel_set_cpu_fifo_underrun_reporting(dev_priv, pipe, true);

2489
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
2490 2491
		intel_ddi_pre_enable_hdmi(state, encoder, crtc_state,
					  conn_state);
2492
	} else {
2493
		struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2494

2495 2496
		intel_ddi_pre_enable_dp(state, encoder, crtc_state,
					conn_state);
2497

2498 2499 2500
		/* FIXME precompute everything properly */
		/* FIXME how do we turn infoframes off again? */
		if (dig_port->lspcon.active && dig_port->dp.has_hdmi_sink)
2501 2502 2503 2504
			dig_port->set_infoframes(encoder,
						 crtc_state->has_infoframe,
						 crtc_state, conn_state);
	}
2505 2506
}

A
Anusha Srivatsa 已提交
2507 2508
static void intel_disable_ddi_buf(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state)
2509 2510
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2511
	enum port port = encoder->port;
2512 2513 2514
	bool wait = false;
	u32 val;

2515
	val = intel_de_read(dev_priv, DDI_BUF_CTL(port));
2516 2517
	if (val & DDI_BUF_CTL_ENABLE) {
		val &= ~DDI_BUF_CTL_ENABLE;
2518
		intel_de_write(dev_priv, DDI_BUF_CTL(port), val);
2519 2520 2521
		wait = true;
	}

2522
	if (intel_crtc_has_dp_encoder(crtc_state)) {
2523
		val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
2524 2525
		val &= ~(DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_MASK);
		val |= DP_TP_CTL_LINK_TRAIN_PAT1;
2526
		intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
2527
	}
2528

A
Anusha Srivatsa 已提交
2529 2530 2531
	/* Disable FEC in DP Sink */
	intel_ddi_disable_fec_state(encoder, crtc_state);

2532 2533 2534 2535
	if (wait)
		intel_wait_ddi_buf_idle(dev_priv, port);
}

2536 2537
static void intel_ddi_post_disable_dp(struct intel_atomic_state *state,
				      struct intel_encoder *encoder,
2538 2539
				      const struct intel_crtc_state *old_crtc_state,
				      const struct drm_connector_state *old_conn_state)
2540
{
2541
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2542
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2543
	struct intel_dp *intel_dp = &dig_port->dp;
2544 2545
	bool is_mst = intel_crtc_has_type(old_crtc_state,
					  INTEL_OUTPUT_DP_MST);
2546
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
2547

2548 2549 2550
	if (!is_mst)
		intel_dp_set_infoframes(encoder, false,
					old_crtc_state, old_conn_state);
2551

2552 2553 2554 2555
	/*
	 * Power down sink before disabling the port, otherwise we end
	 * up getting interrupts from the sink on detecting link loss.
	 */
2556
	intel_dp_set_power(intel_dp, DP_SET_POWER_D3);
2557

2558 2559 2560 2561 2562
	if (INTEL_GEN(dev_priv) >= 12) {
		if (is_mst) {
			enum transcoder cpu_transcoder = old_crtc_state->cpu_transcoder;
			u32 val;

2563 2564
			val = intel_de_read(dev_priv,
					    TRANS_DDI_FUNC_CTL(cpu_transcoder));
2565 2566
			val &= ~(TGL_TRANS_DDI_PORT_MASK |
				 TRANS_DDI_MODE_SELECT_MASK);
2567 2568 2569
			intel_de_write(dev_priv,
				       TRANS_DDI_FUNC_CTL(cpu_transcoder),
				       val);
2570 2571 2572 2573 2574
		}
	} else {
		if (!is_mst)
			intel_ddi_disable_pipe_clock(old_crtc_state);
	}
2575

A
Anusha Srivatsa 已提交
2576
	intel_disable_ddi_buf(encoder, old_crtc_state);
2577

2578 2579 2580 2581 2582 2583 2584 2585
	/*
	 * From TGL spec: "If single stream or multi-stream master transcoder:
	 * Configure Transcoder Clock select to direct no clock to the
	 * transcoder"
	 */
	if (INTEL_GEN(dev_priv) >= 12)
		intel_ddi_disable_pipe_clock(old_crtc_state);

2586 2587
	intel_pps_vdd_on(intel_dp);
	intel_pps_off(intel_dp);
2588

2589
	if (!intel_phy_is_tc(dev_priv, phy) ||
2590
	    dig_port->tc_mode != TC_PORT_TBT_ALT)
2591 2592 2593
		intel_display_power_put(dev_priv,
					dig_port->ddi_io_power_domain,
					fetch_and_zero(&dig_port->ddi_io_wakeref));
2594

2595
	intel_ddi_disable_clock(encoder);
2596
}
2597

2598 2599
static void intel_ddi_post_disable_hdmi(struct intel_atomic_state *state,
					struct intel_encoder *encoder,
2600 2601 2602 2603
					const struct intel_crtc_state *old_crtc_state,
					const struct drm_connector_state *old_conn_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2604
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2605
	struct intel_hdmi *intel_hdmi = &dig_port->hdmi;
2606

2607
	dig_port->set_infoframes(encoder, false,
2608 2609
				 old_crtc_state, old_conn_state);

2610 2611
	intel_ddi_disable_pipe_clock(old_crtc_state);

A
Anusha Srivatsa 已提交
2612
	intel_disable_ddi_buf(encoder, old_crtc_state);
2613

2614 2615 2616
	intel_display_power_put(dev_priv,
				dig_port->ddi_io_power_domain,
				fetch_and_zero(&dig_port->ddi_io_wakeref));
2617

2618
	intel_ddi_disable_clock(encoder);
2619 2620 2621 2622

	intel_dp_dual_mode_set_tmds_output(intel_hdmi, false);
}

2623 2624
static void intel_ddi_post_disable(struct intel_atomic_state *state,
				   struct intel_encoder *encoder,
2625 2626 2627
				   const struct intel_crtc_state *old_crtc_state,
				   const struct drm_connector_state *old_conn_state)
{
2628
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2629
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2630 2631
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
	bool is_tc_port = intel_phy_is_tc(dev_priv, phy);
2632

2633 2634
	if (!intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_DP_MST)) {
		intel_crtc_vblank_off(old_crtc_state);
2635

2636
		intel_disable_pipe(old_crtc_state);
2637

2638 2639
		intel_vrr_disable(old_crtc_state);

2640
		intel_ddi_disable_transcoder_func(old_crtc_state);
2641

2642
		intel_dsc_disable(old_crtc_state);
2643

2644 2645 2646 2647 2648
		if (INTEL_GEN(dev_priv) >= 9)
			skl_scaler_disable(old_crtc_state);
		else
			ilk_pfit_disable(old_crtc_state);
	}
2649

2650 2651 2652 2653 2654 2655 2656 2657 2658 2659 2660 2661 2662 2663 2664
	if (old_crtc_state->bigjoiner_linked_crtc) {
		struct intel_atomic_state *state =
			to_intel_atomic_state(old_crtc_state->uapi.state);
		struct intel_crtc *slave =
			old_crtc_state->bigjoiner_linked_crtc;
		const struct intel_crtc_state *old_slave_crtc_state =
			intel_atomic_get_old_crtc_state(state, slave);

		intel_crtc_vblank_off(old_slave_crtc_state);
		trace_intel_pipe_disable(slave);

		intel_dsc_disable(old_slave_crtc_state);
		skl_scaler_disable(old_slave_crtc_state);
	}

2665
	/*
2666 2667 2668 2669 2670 2671 2672 2673 2674 2675
	 * When called from DP MST code:
	 * - old_conn_state will be NULL
	 * - encoder will be the main encoder (ie. mst->primary)
	 * - the main connector associated with this port
	 *   won't be active or linked to a crtc
	 * - old_crtc_state will be the state of the last stream to
	 *   be deactivated on this port, and it may not be the same
	 *   stream that was activated last, but each stream
	 *   should have a state that is identical when it comes to
	 *   the DP link parameteres
2676
	 */
2677 2678

	if (intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_HDMI))
2679 2680
		intel_ddi_post_disable_hdmi(state, encoder, old_crtc_state,
					    old_conn_state);
2681
	else
2682 2683
		intel_ddi_post_disable_dp(state, encoder, old_crtc_state,
					  old_conn_state);
2684

2685 2686 2687
	if (IS_DG1(dev_priv))
		dg1_unmap_plls_to_ports(encoder);
	else if (INTEL_GEN(dev_priv) >= 11)
2688
		icl_unmap_plls_to_ports(encoder);
2689 2690

	if (intel_crtc_has_dp_encoder(old_crtc_state) || is_tc_port)
2691 2692 2693
		intel_display_power_put(dev_priv,
					intel_ddi_main_link_aux_domain(dig_port),
					fetch_and_zero(&dig_port->aux_wakeref));
2694 2695 2696

	if (is_tc_port)
		intel_tc_port_put_link(dig_port);
2697 2698
}

2699 2700
void intel_ddi_fdi_post_disable(struct intel_atomic_state *state,
				struct intel_encoder *encoder,
2701 2702
				const struct intel_crtc_state *old_crtc_state,
				const struct drm_connector_state *old_conn_state)
2703
{
2704
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2705
	u32 val;
2706 2707 2708 2709 2710 2711 2712

	/*
	 * Bspec lists this as both step 13 (before DDI_BUF_CTL disable)
	 * and step 18 (after clearing PORT_CLK_SEL). Based on a BUN,
	 * step 13 is the correct place for it. Step 18 is where it was
	 * originally before the BUN.
	 */
2713
	val = intel_de_read(dev_priv, FDI_RX_CTL(PIPE_A));
2714
	val &= ~FDI_RX_ENABLE;
2715
	intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), val);
2716

A
Anusha Srivatsa 已提交
2717
	intel_disable_ddi_buf(encoder, old_crtc_state);
2718
	intel_ddi_disable_clock(encoder);
2719

2720
	val = intel_de_read(dev_priv, FDI_RX_MISC(PIPE_A));
2721 2722
	val &= ~(FDI_RX_PWRDN_LANE1_MASK | FDI_RX_PWRDN_LANE0_MASK);
	val |= FDI_RX_PWRDN_LANE1_VAL(2) | FDI_RX_PWRDN_LANE0_VAL(2);
2723
	intel_de_write(dev_priv, FDI_RX_MISC(PIPE_A), val);
2724

2725
	val = intel_de_read(dev_priv, FDI_RX_CTL(PIPE_A));
2726
	val &= ~FDI_PCDCLK;
2727
	intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), val);
2728

2729
	val = intel_de_read(dev_priv, FDI_RX_CTL(PIPE_A));
2730
	val &= ~FDI_RX_PLL_ENABLE;
2731
	intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), val);
2732 2733
}

2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747 2748 2749 2750 2751 2752 2753 2754 2755 2756 2757 2758 2759 2760
static void trans_port_sync_stop_link_train(struct intel_atomic_state *state,
					    struct intel_encoder *encoder,
					    const struct intel_crtc_state *crtc_state)
{
	const struct drm_connector_state *conn_state;
	struct drm_connector *conn;
	int i;

	if (!crtc_state->sync_mode_slaves_mask)
		return;

	for_each_new_connector_in_state(&state->base, conn, conn_state, i) {
		struct intel_encoder *slave_encoder =
			to_intel_encoder(conn_state->best_encoder);
		struct intel_crtc *slave_crtc = to_intel_crtc(conn_state->crtc);
		const struct intel_crtc_state *slave_crtc_state;

		if (!slave_crtc)
			continue;

		slave_crtc_state =
			intel_atomic_get_new_crtc_state(state, slave_crtc);

		if (slave_crtc_state->master_transcoder !=
		    crtc_state->cpu_transcoder)
			continue;

2761 2762
		intel_dp_stop_link_train(enc_to_intel_dp(slave_encoder),
					 slave_crtc_state);
2763 2764 2765 2766
	}

	usleep_range(200, 400);

2767 2768
	intel_dp_stop_link_train(enc_to_intel_dp(encoder),
				 crtc_state);
2769 2770
}

2771 2772
static void intel_enable_ddi_dp(struct intel_atomic_state *state,
				struct intel_encoder *encoder,
2773 2774
				const struct intel_crtc_state *crtc_state,
				const struct drm_connector_state *conn_state)
2775
{
2776
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2777
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2778
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2779
	enum port port = encoder->port;
2780

2781
	if (port == PORT_A && INTEL_GEN(dev_priv) < 9)
2782
		intel_dp_stop_link_train(intel_dp, crtc_state);
2783

2784
	intel_edp_backlight_on(crtc_state, conn_state);
2785
	intel_psr_enable(intel_dp, crtc_state, conn_state);
2786 2787 2788 2789

	if (!dig_port->lspcon.active || dig_port->dp.has_hdmi_sink)
		intel_dp_set_infoframes(encoder, true, crtc_state, conn_state);

2790
	intel_edp_drrs_enable(intel_dp, crtc_state);
2791

2792 2793
	if (crtc_state->has_audio)
		intel_audio_codec_enable(encoder, crtc_state, conn_state);
2794 2795

	trans_port_sync_stop_link_train(state, encoder, crtc_state);
2796 2797
}

2798 2799 2800 2801
static i915_reg_t
gen9_chicken_trans_reg_by_port(struct drm_i915_private *dev_priv,
			       enum port port)
{
2802 2803 2804 2805 2806 2807
	static const enum transcoder trans[] = {
		[PORT_A] = TRANSCODER_EDP,
		[PORT_B] = TRANSCODER_A,
		[PORT_C] = TRANSCODER_B,
		[PORT_D] = TRANSCODER_C,
		[PORT_E] = TRANSCODER_A,
2808 2809
	};

2810
	drm_WARN_ON(&dev_priv->drm, INTEL_GEN(dev_priv) < 9);
2811

2812
	if (drm_WARN_ON(&dev_priv->drm, port < PORT_A || port > PORT_E))
2813 2814
		port = PORT_A;

2815
	return CHICKEN_TRANS(trans[port]);
2816 2817
}

2818 2819
static void intel_enable_ddi_hdmi(struct intel_atomic_state *state,
				  struct intel_encoder *encoder,
2820 2821 2822 2823
				  const struct intel_crtc_state *crtc_state,
				  const struct drm_connector_state *conn_state)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2824
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2825
	struct drm_connector *connector = conn_state->connector;
2826
	int level = intel_ddi_hdmi_level(encoder, crtc_state);
2827
	enum port port = encoder->port;
2828

2829 2830 2831
	if (!intel_hdmi_handle_sink_scrambling(encoder, connector,
					       crtc_state->hdmi_high_tmds_clock_ratio,
					       crtc_state->hdmi_scrambling))
2832 2833 2834
		drm_dbg_kms(&dev_priv->drm,
			    "[CONNECTOR:%d:%s] Failed to configure sink scrambling/TMDS bit clock ratio\n",
			    connector->base.id, connector->name);
2835

2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 2846 2847 2848 2849
	if (INTEL_GEN(dev_priv) >= 12)
		tgl_ddi_vswing_sequence(encoder, crtc_state, level);
	else if (INTEL_GEN(dev_priv) == 11)
		icl_ddi_vswing_sequence(encoder, crtc_state, level);
	else if (IS_CANNONLAKE(dev_priv))
		cnl_ddi_vswing_sequence(encoder, crtc_state, level);
	else if (IS_GEN9_LP(dev_priv))
		bxt_ddi_vswing_sequence(encoder, crtc_state, level);
	else
		intel_prepare_hdmi_ddi_buffers(encoder, level);

	if (IS_GEN9_BC(dev_priv))
		skl_ddi_set_iboost(encoder, crtc_state, level);

2850 2851 2852 2853 2854 2855 2856 2857
	/* Display WA #1143: skl,kbl,cfl */
	if (IS_GEN9_BC(dev_priv)) {
		/*
		 * For some reason these chicken bits have been
		 * stuffed into a transcoder register, event though
		 * the bits affect a specific DDI port rather than
		 * a specific transcoder.
		 */
2858
		i915_reg_t reg = gen9_chicken_trans_reg_by_port(dev_priv, port);
2859 2860
		u32 val;

2861
		val = intel_de_read(dev_priv, reg);
2862 2863 2864 2865 2866 2867 2868 2869

		if (port == PORT_E)
			val |= DDIE_TRAINING_OVERRIDE_ENABLE |
				DDIE_TRAINING_OVERRIDE_VALUE;
		else
			val |= DDI_TRAINING_OVERRIDE_ENABLE |
				DDI_TRAINING_OVERRIDE_VALUE;

2870 2871
		intel_de_write(dev_priv, reg, val);
		intel_de_posting_read(dev_priv, reg);
2872 2873 2874 2875 2876 2877 2878 2879 2880 2881

		udelay(1);

		if (port == PORT_E)
			val &= ~(DDIE_TRAINING_OVERRIDE_ENABLE |
				 DDIE_TRAINING_OVERRIDE_VALUE);
		else
			val &= ~(DDI_TRAINING_OVERRIDE_ENABLE |
				 DDI_TRAINING_OVERRIDE_VALUE);

2882
		intel_de_write(dev_priv, reg, val);
2883 2884
	}

2885 2886
	intel_ddi_power_up_lanes(encoder, crtc_state);

2887 2888 2889 2890
	/* In HDMI/DVI mode, the port width, and swing/emphasis values
	 * are ignored so nothing special needs to be done besides
	 * enabling the port.
	 */
2891 2892
	intel_de_write(dev_priv, DDI_BUF_CTL(port),
		       dig_port->saved_port_bits | DDI_BUF_CTL_ENABLE);
2893

2894 2895 2896 2897
	if (crtc_state->has_audio)
		intel_audio_codec_enable(encoder, crtc_state, conn_state);
}

2898 2899
static void intel_enable_ddi(struct intel_atomic_state *state,
			     struct intel_encoder *encoder,
2900 2901 2902
			     const struct intel_crtc_state *crtc_state,
			     const struct drm_connector_state *conn_state)
{
2903
	drm_WARN_ON(state->base.dev, crtc_state->has_pch_encoder);
2904

2905 2906
	if (!crtc_state->bigjoiner_slave)
		intel_ddi_enable_transcoder_func(encoder, crtc_state);
2907

2908 2909
	intel_vrr_enable(encoder, crtc_state);

2910 2911 2912 2913
	intel_enable_pipe(crtc_state);

	intel_crtc_vblank_on(crtc_state);

2914
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
2915
		intel_enable_ddi_hdmi(state, encoder, crtc_state, conn_state);
2916
	else
2917
		intel_enable_ddi_dp(state, encoder, crtc_state, conn_state);
2918 2919 2920 2921

	/* Enable hdcp if it's desired */
	if (conn_state->content_protection ==
	    DRM_MODE_CONTENT_PROTECTION_DESIRED)
2922
		intel_hdcp_enable(to_intel_connector(conn_state->connector),
2923
				  crtc_state,
2924
				  (u8)conn_state->hdcp_content_type);
2925 2926
}

2927 2928
static void intel_disable_ddi_dp(struct intel_atomic_state *state,
				 struct intel_encoder *encoder,
2929 2930
				 const struct intel_crtc_state *old_crtc_state,
				 const struct drm_connector_state *old_conn_state)
2931
{
2932
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2933

2934 2935
	intel_dp->link_trained = false;

2936
	if (old_crtc_state->has_audio)
2937 2938
		intel_audio_codec_disable(encoder,
					  old_crtc_state, old_conn_state);
2939

2940 2941 2942
	intel_edp_drrs_disable(intel_dp, old_crtc_state);
	intel_psr_disable(intel_dp, old_crtc_state);
	intel_edp_backlight_off(old_conn_state);
2943 2944 2945
	/* Disable the decompression in DP Sink */
	intel_dp_sink_set_decompression_state(intel_dp, old_crtc_state,
					      false);
2946 2947 2948
	/* Disable Ignore_MSA bit in DP Sink */
	intel_dp_sink_set_msa_timing_par_ignore_state(intel_dp, old_crtc_state,
						      false);
2949
}
S
Shashank Sharma 已提交
2950

2951 2952
static void intel_disable_ddi_hdmi(struct intel_atomic_state *state,
				   struct intel_encoder *encoder,
2953 2954 2955
				   const struct intel_crtc_state *old_crtc_state,
				   const struct drm_connector_state *old_conn_state)
{
2956
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2957 2958
	struct drm_connector *connector = old_conn_state->connector;

2959
	if (old_crtc_state->has_audio)
2960 2961
		intel_audio_codec_disable(encoder,
					  old_crtc_state, old_conn_state);
2962

2963 2964
	if (!intel_hdmi_handle_sink_scrambling(encoder, connector,
					       false, false))
2965 2966 2967
		drm_dbg_kms(&i915->drm,
			    "[CONNECTOR:%d:%s] Failed to reset sink scrambling/TMDS bit clock ratio\n",
			    connector->base.id, connector->name);
2968 2969
}

2970 2971
static void intel_disable_ddi(struct intel_atomic_state *state,
			      struct intel_encoder *encoder,
2972 2973 2974
			      const struct intel_crtc_state *old_crtc_state,
			      const struct drm_connector_state *old_conn_state)
{
2975 2976
	intel_hdcp_disable(to_intel_connector(old_conn_state->connector));

2977
	if (intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_HDMI))
2978 2979
		intel_disable_ddi_hdmi(state, encoder, old_crtc_state,
				       old_conn_state);
2980
	else
2981 2982
		intel_disable_ddi_dp(state, encoder, old_crtc_state,
				     old_conn_state);
2983
}
P
Paulo Zanoni 已提交
2984

2985 2986
static void intel_ddi_update_pipe_dp(struct intel_atomic_state *state,
				     struct intel_encoder *encoder,
2987 2988 2989
				     const struct intel_crtc_state *crtc_state,
				     const struct drm_connector_state *conn_state)
{
2990
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2991

2992
	intel_ddi_set_dp_msa(crtc_state, conn_state);
2993

2994
	intel_psr_update(intel_dp, crtc_state, conn_state);
2995
	intel_dp_set_infoframes(encoder, true, crtc_state, conn_state);
2996
	intel_edp_drrs_update(intel_dp, crtc_state);
2997

2998
	intel_panel_update_backlight(state, encoder, crtc_state, conn_state);
2999 3000
}

3001 3002 3003 3004
void intel_ddi_update_pipe(struct intel_atomic_state *state,
			   struct intel_encoder *encoder,
			   const struct intel_crtc_state *crtc_state,
			   const struct drm_connector_state *conn_state)
3005
{
3006

3007 3008
	if (!intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI) &&
	    !intel_encoder_is_mst(encoder))
3009 3010
		intel_ddi_update_pipe_dp(state, encoder, crtc_state,
					 conn_state);
3011

3012
	intel_hdcp_update_pipe(state, encoder, crtc_state, conn_state);
3013 3014
}

3015 3016 3017 3018 3019 3020 3021 3022 3023
static void
intel_ddi_update_prepare(struct intel_atomic_state *state,
			 struct intel_encoder *encoder,
			 struct intel_crtc *crtc)
{
	struct intel_crtc_state *crtc_state =
		crtc ? intel_atomic_get_new_crtc_state(state, crtc) : NULL;
	int required_lanes = crtc_state ? crtc_state->lane_count : 1;

3024
	drm_WARN_ON(state->base.dev, crtc && crtc->active);
3025

3026 3027
	intel_tc_port_get_link(enc_to_dig_port(encoder),
		               required_lanes);
3028
	if (crtc_state && crtc_state->hw.active)
3029 3030 3031 3032 3033 3034 3035 3036
		intel_update_active_dpll(state, crtc, encoder);
}

static void
intel_ddi_update_complete(struct intel_atomic_state *state,
			  struct intel_encoder *encoder,
			  struct intel_crtc *crtc)
{
3037
	intel_tc_port_put_link(enc_to_dig_port(encoder));
3038 3039
}

I
Imre Deak 已提交
3040
static void
3041 3042
intel_ddi_pre_pll_enable(struct intel_atomic_state *state,
			 struct intel_encoder *encoder,
I
Imre Deak 已提交
3043 3044
			 const struct intel_crtc_state *crtc_state,
			 const struct drm_connector_state *conn_state)
3045
{
I
Imre Deak 已提交
3046
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3047
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
3048 3049
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
	bool is_tc_port = intel_phy_is_tc(dev_priv, phy);
I
Imre Deak 已提交
3050

3051 3052 3053
	if (is_tc_port)
		intel_tc_port_get_link(dig_port, crtc_state->lane_count);

3054 3055 3056 3057 3058 3059
	if (intel_crtc_has_dp_encoder(crtc_state) || is_tc_port) {
		drm_WARN_ON(&dev_priv->drm, dig_port->aux_wakeref);
		dig_port->aux_wakeref =
			intel_display_power_get(dev_priv,
						intel_ddi_main_link_aux_domain(dig_port));
	}
I
Imre Deak 已提交
3060

3061 3062 3063 3064 3065 3066 3067
	if (is_tc_port && dig_port->tc_mode != TC_PORT_TBT_ALT)
		/*
		 * Program the lane count for static/dynamic connections on
		 * Type-C ports.  Skip this step for TBT.
		 */
		intel_tc_port_set_fia_lane_count(dig_port, crtc_state->lane_count);
	else if (IS_GEN9_LP(dev_priv))
I
Imre Deak 已提交
3068 3069 3070 3071
		bxt_ddi_phy_set_lane_optim_mask(encoder,
						crtc_state->lane_lat_optim_mask);
}

3072 3073
static void intel_ddi_prepare_link_retrain(struct intel_dp *intel_dp,
					   const struct intel_crtc_state *crtc_state)
3074
{
3075 3076 3077
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum port port = encoder->port;
3078
	u32 dp_tp_ctl, ddi_buf_ctl;
3079
	bool wait = false;
3080

3081
	dp_tp_ctl = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3082 3083

	if (dp_tp_ctl & DP_TP_CTL_ENABLE) {
3084
		ddi_buf_ctl = intel_de_read(dev_priv, DDI_BUF_CTL(port));
3085
		if (ddi_buf_ctl & DDI_BUF_CTL_ENABLE) {
3086 3087
			intel_de_write(dev_priv, DDI_BUF_CTL(port),
				       ddi_buf_ctl & ~DDI_BUF_CTL_ENABLE);
3088 3089 3090
			wait = true;
		}

3091 3092
		dp_tp_ctl &= ~(DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_MASK);
		dp_tp_ctl |= DP_TP_CTL_LINK_TRAIN_PAT1;
3093 3094
		intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), dp_tp_ctl);
		intel_de_posting_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3095 3096 3097 3098 3099

		if (wait)
			intel_wait_ddi_buf_idle(dev_priv, port);
	}

3100
	dp_tp_ctl = DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_PAT1;
3101
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST)) {
3102
		dp_tp_ctl |= DP_TP_CTL_MODE_MST;
3103
	} else {
3104
		dp_tp_ctl |= DP_TP_CTL_MODE_SST;
3105
		if (drm_dp_enhanced_frame_cap(intel_dp->dpcd))
3106
			dp_tp_ctl |= DP_TP_CTL_ENHANCED_FRAME_ENABLE;
3107
	}
3108 3109
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), dp_tp_ctl);
	intel_de_posting_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3110 3111

	intel_dp->DP |= DDI_BUF_CTL_ENABLE;
3112 3113
	intel_de_write(dev_priv, DDI_BUF_CTL(port), intel_dp->DP);
	intel_de_posting_read(dev_priv, DDI_BUF_CTL(port));
3114

3115
	intel_wait_ddi_buf_active(dev_priv, port);
3116
}
P
Paulo Zanoni 已提交
3117

3118
static void intel_ddi_set_link_train(struct intel_dp *intel_dp,
3119
				     const struct intel_crtc_state *crtc_state,
3120 3121
				     u8 dp_train_pat)
{
3122 3123
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3124 3125
	u32 temp;

3126
	temp = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3127 3128

	temp &= ~DP_TP_CTL_LINK_TRAIN_MASK;
3129
	switch (intel_dp_training_pattern_symbol(dp_train_pat)) {
3130 3131 3132 3133 3134 3135 3136 3137 3138 3139 3140 3141 3142 3143 3144 3145 3146
	case DP_TRAINING_PATTERN_DISABLE:
		temp |= DP_TP_CTL_LINK_TRAIN_NORMAL;
		break;
	case DP_TRAINING_PATTERN_1:
		temp |= DP_TP_CTL_LINK_TRAIN_PAT1;
		break;
	case DP_TRAINING_PATTERN_2:
		temp |= DP_TP_CTL_LINK_TRAIN_PAT2;
		break;
	case DP_TRAINING_PATTERN_3:
		temp |= DP_TP_CTL_LINK_TRAIN_PAT3;
		break;
	case DP_TRAINING_PATTERN_4:
		temp |= DP_TP_CTL_LINK_TRAIN_PAT4;
		break;
	}

3147
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), temp);
3148 3149
}

3150 3151
static void intel_ddi_set_idle_link_train(struct intel_dp *intel_dp,
					  const struct intel_crtc_state *crtc_state)
3152 3153 3154 3155 3156 3157
{
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum port port = encoder->port;
	u32 val;

3158
	val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3159 3160
	val &= ~DP_TP_CTL_LINK_TRAIN_MASK;
	val |= DP_TP_CTL_LINK_TRAIN_IDLE;
3161
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
3162 3163 3164 3165 3166 3167 3168 3169 3170 3171 3172

	/*
	 * Until TGL on PORT_A we can have only eDP in SST mode. There the only
	 * reason we need to set idle transmission mode is to work around a HW
	 * issue where we enable the pipe while not in idle link-training mode.
	 * In this case there is requirement to wait for a minimum number of
	 * idle patterns to be sent.
	 */
	if (port == PORT_A && INTEL_GEN(dev_priv) < 12)
		return;

3173 3174
	if (intel_de_wait_for_set(dev_priv,
				  dp_tp_status_reg(encoder, crtc_state),
3175 3176 3177 3178 3179
				  DP_TP_STATUS_IDLE_DONE, 1))
		drm_err(&dev_priv->drm,
			"Timed out waiting for DP idle patterns\n");
}

3180 3181
static bool intel_ddi_is_audio_enabled(struct drm_i915_private *dev_priv,
				       enum transcoder cpu_transcoder)
3182
{
3183 3184
	if (cpu_transcoder == TRANSCODER_EDP)
		return false;
3185

3186 3187 3188
	if (!intel_display_power_is_enabled(dev_priv, POWER_DOMAIN_AUDIO))
		return false;

3189
	return intel_de_read(dev_priv, HSW_AUD_PIN_ELD_CP_VLD) &
3190
		AUDIO_OUTPUT_ENABLE(cpu_transcoder);
3191 3192
}

3193 3194 3195
void intel_ddi_compute_min_voltage_level(struct drm_i915_private *dev_priv,
					 struct intel_crtc_state *crtc_state)
{
3196 3197
	if (INTEL_GEN(dev_priv) >= 12 && crtc_state->port_clock > 594000)
		crtc_state->min_voltage_level = 2;
3198
	else if (IS_JSL_EHL(dev_priv) && crtc_state->port_clock > 594000)
3199 3200
		crtc_state->min_voltage_level = 3;
	else if (INTEL_GEN(dev_priv) >= 11 && crtc_state->port_clock > 594000)
3201
		crtc_state->min_voltage_level = 1;
3202 3203
	else if (IS_CANNONLAKE(dev_priv) && crtc_state->port_clock > 594000)
		crtc_state->min_voltage_level = 2;
3204 3205
}

3206 3207
static enum transcoder bdw_transcoder_master_readout(struct drm_i915_private *dev_priv,
						     enum transcoder cpu_transcoder)
3208
{
3209 3210 3211 3212
	u32 master_select;

	if (INTEL_GEN(dev_priv) >= 11) {
		u32 ctl2 = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL2(cpu_transcoder));
3213

3214 3215
		if ((ctl2 & PORT_SYNC_MODE_ENABLE) == 0)
			return INVALID_TRANSCODER;
3216

3217 3218 3219
		master_select = REG_FIELD_GET(PORT_SYNC_MODE_MASTER_SELECT_MASK, ctl2);
	} else {
		u32 ctl = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder));
3220

3221 3222 3223 3224 3225
		if ((ctl & TRANS_DDI_PORT_SYNC_ENABLE) == 0)
			return INVALID_TRANSCODER;

		master_select = REG_FIELD_GET(TRANS_DDI_PORT_SYNC_MASTER_SELECT_MASK, ctl);
	}
3226 3227 3228 3229 3230 3231 3232

	if (master_select == 0)
		return TRANSCODER_EDP;
	else
		return master_select - 1;
}

3233
static void bdw_get_trans_port_sync_config(struct intel_crtc_state *crtc_state)
3234 3235 3236 3237 3238 3239 3240
{
	struct drm_i915_private *dev_priv = to_i915(crtc_state->uapi.crtc->dev);
	u32 transcoders = BIT(TRANSCODER_A) | BIT(TRANSCODER_B) |
		BIT(TRANSCODER_C) | BIT(TRANSCODER_D);
	enum transcoder cpu_transcoder;

	crtc_state->master_transcoder =
3241
		bdw_transcoder_master_readout(dev_priv, crtc_state->cpu_transcoder);
3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252 3253

	for_each_cpu_transcoder_masked(dev_priv, cpu_transcoder, transcoders) {
		enum intel_display_power_domain power_domain;
		intel_wakeref_t trans_wakeref;

		power_domain = POWER_DOMAIN_TRANSCODER(cpu_transcoder);
		trans_wakeref = intel_display_power_get_if_enabled(dev_priv,
								   power_domain);

		if (!trans_wakeref)
			continue;

3254
		if (bdw_transcoder_master_readout(dev_priv, cpu_transcoder) ==
3255 3256 3257 3258 3259 3260 3261 3262 3263 3264 3265
		    crtc_state->cpu_transcoder)
			crtc_state->sync_mode_slaves_mask |= BIT(cpu_transcoder);

		intel_display_power_put(dev_priv, power_domain, trans_wakeref);
	}

	drm_WARN_ON(&dev_priv->drm,
		    crtc_state->master_transcoder != INVALID_TRANSCODER &&
		    crtc_state->sync_mode_slaves_mask);
}

3266 3267
static void intel_ddi_read_func_ctl(struct intel_encoder *encoder,
				    struct intel_crtc_state *pipe_config)
3268
{
3269
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3270
	struct intel_crtc *intel_crtc = to_intel_crtc(pipe_config->uapi.crtc);
3271
	enum transcoder cpu_transcoder = pipe_config->cpu_transcoder;
3272
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
3273 3274
	u32 temp, flags = 0;

3275
	temp = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder));
3276 3277 3278 3279 3280 3281 3282 3283 3284
	if (temp & TRANS_DDI_PHSYNC)
		flags |= DRM_MODE_FLAG_PHSYNC;
	else
		flags |= DRM_MODE_FLAG_NHSYNC;
	if (temp & TRANS_DDI_PVSYNC)
		flags |= DRM_MODE_FLAG_PVSYNC;
	else
		flags |= DRM_MODE_FLAG_NVSYNC;

3285
	pipe_config->hw.adjusted_mode.flags |= flags;
3286 3287 3288 3289 3290 3291 3292 3293 3294 3295 3296 3297 3298 3299 3300 3301 3302

	switch (temp & TRANS_DDI_BPC_MASK) {
	case TRANS_DDI_BPC_6:
		pipe_config->pipe_bpp = 18;
		break;
	case TRANS_DDI_BPC_8:
		pipe_config->pipe_bpp = 24;
		break;
	case TRANS_DDI_BPC_10:
		pipe_config->pipe_bpp = 30;
		break;
	case TRANS_DDI_BPC_12:
		pipe_config->pipe_bpp = 36;
		break;
	default:
		break;
	}
3303 3304 3305

	switch (temp & TRANS_DDI_MODE_SELECT_MASK) {
	case TRANS_DDI_MODE_SELECT_HDMI:
3306
		pipe_config->has_hdmi_sink = true;
3307

3308 3309 3310 3311
		pipe_config->infoframes.enable |=
			intel_hdmi_infoframes_enabled(encoder, pipe_config);

		if (pipe_config->infoframes.enable)
3312
			pipe_config->has_infoframe = true;
S
Shashank Sharma 已提交
3313

3314
		if (temp & TRANS_DDI_HDMI_SCRAMBLING)
S
Shashank Sharma 已提交
3315 3316 3317
			pipe_config->hdmi_scrambling = true;
		if (temp & TRANS_DDI_HIGH_TMDS_CHAR_RATE)
			pipe_config->hdmi_high_tmds_clock_ratio = true;
3318
		fallthrough;
3319
	case TRANS_DDI_MODE_SELECT_DVI:
3320
		pipe_config->output_types |= BIT(INTEL_OUTPUT_HDMI);
3321 3322
		pipe_config->lane_count = 4;
		break;
3323
	case TRANS_DDI_MODE_SELECT_FDI:
3324
		pipe_config->output_types |= BIT(INTEL_OUTPUT_ANALOG);
3325 3326
		break;
	case TRANS_DDI_MODE_SELECT_DP_SST:
3327 3328 3329 3330 3331 3332 3333
		if (encoder->type == INTEL_OUTPUT_EDP)
			pipe_config->output_types |= BIT(INTEL_OUTPUT_EDP);
		else
			pipe_config->output_types |= BIT(INTEL_OUTPUT_DP);
		pipe_config->lane_count =
			((temp & DDI_PORT_WIDTH_MASK) >> DDI_PORT_WIDTH_SHIFT) + 1;
		intel_dp_get_m_n(intel_crtc, pipe_config);
3334 3335

		if (INTEL_GEN(dev_priv) >= 11) {
3336
			i915_reg_t dp_tp_ctl = dp_tp_ctl_reg(encoder, pipe_config);
3337 3338

			pipe_config->fec_enable =
3339
				intel_de_read(dev_priv, dp_tp_ctl) & DP_TP_CTL_FEC_ENABLE;
3340

3341 3342 3343 3344
			drm_dbg_kms(&dev_priv->drm,
				    "[ENCODER:%d:%s] Fec status: %u\n",
				    encoder->base.base.id, encoder->base.name,
				    pipe_config->fec_enable);
3345 3346
		}

3347 3348 3349 3350 3351 3352
		if (dig_port->lspcon.active && dig_port->dp.has_hdmi_sink)
			pipe_config->infoframes.enable |=
				intel_lspcon_infoframes_enabled(encoder, pipe_config);
		else
			pipe_config->infoframes.enable |=
				intel_hdmi_infoframes_enabled(encoder, pipe_config);
3353
		break;
3354
	case TRANS_DDI_MODE_SELECT_DP_MST:
3355
		pipe_config->output_types |= BIT(INTEL_OUTPUT_DP_MST);
3356 3357
		pipe_config->lane_count =
			((temp & DDI_PORT_WIDTH_MASK) >> DDI_PORT_WIDTH_SHIFT) + 1;
3358 3359 3360 3361 3362

		if (INTEL_GEN(dev_priv) >= 12)
			pipe_config->mst_master_transcoder =
					REG_FIELD_GET(TRANS_DDI_MST_TRANSPORT_SELECT_MASK, temp);

3363
		intel_dp_get_m_n(intel_crtc, pipe_config);
3364 3365 3366

		pipe_config->infoframes.enable |=
			intel_hdmi_infoframes_enabled(encoder, pipe_config);
3367 3368 3369 3370
		break;
	default:
		break;
	}
3371 3372 3373 3374 3375 3376 3377 3378 3379 3380 3381 3382 3383 3384 3385 3386 3387 3388 3389 3390 3391 3392 3393 3394
}

void intel_ddi_get_config(struct intel_encoder *encoder,
			  struct intel_crtc_state *pipe_config)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
	enum transcoder cpu_transcoder = pipe_config->cpu_transcoder;

	/* XXX: DSI transcoder paranoia */
	if (drm_WARN_ON(&dev_priv->drm, transcoder_is_dsi(cpu_transcoder)))
		return;

	if (pipe_config->bigjoiner_slave) {
		/* read out pipe settings from master */
		enum transcoder save = pipe_config->cpu_transcoder;

		/* Our own transcoder needs to be disabled when reading it in intel_ddi_read_func_ctl() */
		WARN_ON(pipe_config->output_types);
		pipe_config->cpu_transcoder = (enum transcoder)pipe_config->bigjoiner_linked_crtc->pipe;
		intel_ddi_read_func_ctl(encoder, pipe_config);
		pipe_config->cpu_transcoder = save;
	} else {
		intel_ddi_read_func_ctl(encoder, pipe_config);
	}
3395

3396
	pipe_config->has_audio =
3397
		intel_ddi_is_audio_enabled(dev_priv, cpu_transcoder);
3398

3399 3400
	if (encoder->type == INTEL_OUTPUT_EDP && dev_priv->vbt.edp.bpp &&
	    pipe_config->pipe_bpp > dev_priv->vbt.edp.bpp) {
3401 3402 3403 3404 3405 3406 3407 3408 3409 3410 3411 3412 3413
		/*
		 * This is a big fat ugly hack.
		 *
		 * Some machines in UEFI boot mode provide us a VBT that has 18
		 * bpp and 1.62 GHz link bandwidth for eDP, which for reasons
		 * unknown we fail to light up. Yet the same BIOS boots up with
		 * 24 bpp and 2.7 GHz link. Use the same bpp as the BIOS uses as
		 * max, not what it tells us to use.
		 *
		 * Note: This will still be broken if the eDP panel is not lit
		 * up by the BIOS, and thus we can't get the mode at module
		 * load.
		 */
3414 3415 3416
		drm_dbg_kms(&dev_priv->drm,
			    "pipe has %d bpp for eDP panel, overriding BIOS-provided max %d bpp\n",
			    pipe_config->pipe_bpp, dev_priv->vbt.edp.bpp);
3417
		dev_priv->vbt.edp.bpp = pipe_config->pipe_bpp;
3418
	}
3419

3420 3421
	if (!pipe_config->bigjoiner_slave)
		intel_ddi_clock_get(encoder, pipe_config);
3422

3423
	if (IS_GEN9_LP(dev_priv))
3424 3425
		pipe_config->lane_lat_optim_mask =
			bxt_ddi_phy_get_lane_lat_optim_mask(encoder);
3426 3427

	intel_ddi_compute_min_voltage_level(dev_priv, pipe_config);
3428 3429 3430 3431 3432 3433 3434 3435 3436 3437 3438 3439

	intel_hdmi_read_gcp_infoframe(encoder, pipe_config);

	intel_read_infoframe(encoder, pipe_config,
			     HDMI_INFOFRAME_TYPE_AVI,
			     &pipe_config->infoframes.avi);
	intel_read_infoframe(encoder, pipe_config,
			     HDMI_INFOFRAME_TYPE_SPD,
			     &pipe_config->infoframes.spd);
	intel_read_infoframe(encoder, pipe_config,
			     HDMI_INFOFRAME_TYPE_VENDOR,
			     &pipe_config->infoframes.hdmi);
3440 3441 3442
	intel_read_infoframe(encoder, pipe_config,
			     HDMI_INFOFRAME_TYPE_DRM,
			     &pipe_config->infoframes.drm);
3443

3444 3445
	if (INTEL_GEN(dev_priv) >= 8)
		bdw_get_trans_port_sync_config(pipe_config);
3446 3447

	intel_read_dp_sdp(encoder, pipe_config, HDMI_PACKET_TYPE_GAMUT_METADATA);
3448
	intel_read_dp_sdp(encoder, pipe_config, DP_SDP_VSC);
3449 3450
}

3451 3452 3453 3454 3455 3456 3457
static void intel_ddi_sync_state(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
{
	if (intel_crtc_has_dp_encoder(crtc_state))
		intel_dp_sync_state(encoder, crtc_state);
}

3458 3459 3460 3461 3462 3463 3464 3465 3466
static bool intel_ddi_initial_fastset_check(struct intel_encoder *encoder,
					    struct intel_crtc_state *crtc_state)
{
	if (intel_crtc_has_dp_encoder(crtc_state))
		return intel_dp_initial_fastset_check(encoder, crtc_state);

	return true;
}

3467 3468 3469 3470 3471 3472 3473 3474 3475 3476 3477 3478 3479 3480 3481 3482 3483 3484
static enum intel_output_type
intel_ddi_compute_output_type(struct intel_encoder *encoder,
			      struct intel_crtc_state *crtc_state,
			      struct drm_connector_state *conn_state)
{
	switch (conn_state->connector->connector_type) {
	case DRM_MODE_CONNECTOR_HDMIA:
		return INTEL_OUTPUT_HDMI;
	case DRM_MODE_CONNECTOR_eDP:
		return INTEL_OUTPUT_EDP;
	case DRM_MODE_CONNECTOR_DisplayPort:
		return INTEL_OUTPUT_DP;
	default:
		MISSING_CASE(conn_state->connector->connector_type);
		return INTEL_OUTPUT_UNUSED;
	}
}

3485 3486 3487
static int intel_ddi_compute_config(struct intel_encoder *encoder,
				    struct intel_crtc_state *pipe_config,
				    struct drm_connector_state *conn_state)
P
Paulo Zanoni 已提交
3488
{
3489
	struct intel_crtc *crtc = to_intel_crtc(pipe_config->uapi.crtc);
3490
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3491
	enum port port = encoder->port;
3492
	int ret;
P
Paulo Zanoni 已提交
3493

3494
	if (HAS_TRANSCODER(dev_priv, TRANSCODER_EDP) && port == PORT_A)
3495 3496
		pipe_config->cpu_transcoder = TRANSCODER_EDP;

3497
	if (intel_crtc_has_type(pipe_config, INTEL_OUTPUT_HDMI)) {
3498
		ret = intel_hdmi_compute_config(encoder, pipe_config, conn_state);
3499
	} else {
3500
		ret = intel_dp_compute_config(encoder, pipe_config, conn_state);
3501 3502
	}

3503 3504
	if (ret)
		return ret;
3505

3506 3507 3508 3509 3510 3511
	if (IS_HASWELL(dev_priv) && crtc->pipe == PIPE_A &&
	    pipe_config->cpu_transcoder == TRANSCODER_EDP)
		pipe_config->pch_pfit.force_thru =
			pipe_config->pch_pfit.enabled ||
			pipe_config->crc_enabled;

3512
	if (IS_GEN9_LP(dev_priv))
3513
		pipe_config->lane_lat_optim_mask =
3514
			bxt_ddi_phy_calc_lane_lat_optim_mask(pipe_config->lane_count);
3515

3516 3517
	intel_ddi_compute_min_voltage_level(dev_priv, pipe_config);

3518
	return 0;
P
Paulo Zanoni 已提交
3519 3520
}

3521 3522 3523 3524 3525 3526 3527 3528 3529 3530 3531 3532 3533 3534 3535 3536 3537 3538 3539 3540 3541 3542 3543 3544 3545 3546 3547 3548 3549 3550 3551 3552 3553 3554 3555 3556 3557 3558 3559 3560 3561 3562 3563 3564 3565
static bool mode_equal(const struct drm_display_mode *mode1,
		       const struct drm_display_mode *mode2)
{
	return drm_mode_match(mode1, mode2,
			      DRM_MODE_MATCH_TIMINGS |
			      DRM_MODE_MATCH_FLAGS |
			      DRM_MODE_MATCH_3D_FLAGS) &&
		mode1->clock == mode2->clock; /* we want an exact match */
}

static bool m_n_equal(const struct intel_link_m_n *m_n_1,
		      const struct intel_link_m_n *m_n_2)
{
	return m_n_1->tu == m_n_2->tu &&
		m_n_1->gmch_m == m_n_2->gmch_m &&
		m_n_1->gmch_n == m_n_2->gmch_n &&
		m_n_1->link_m == m_n_2->link_m &&
		m_n_1->link_n == m_n_2->link_n;
}

static bool crtcs_port_sync_compatible(const struct intel_crtc_state *crtc_state1,
				       const struct intel_crtc_state *crtc_state2)
{
	return crtc_state1->hw.active && crtc_state2->hw.active &&
		crtc_state1->output_types == crtc_state2->output_types &&
		crtc_state1->output_format == crtc_state2->output_format &&
		crtc_state1->lane_count == crtc_state2->lane_count &&
		crtc_state1->port_clock == crtc_state2->port_clock &&
		mode_equal(&crtc_state1->hw.adjusted_mode,
			   &crtc_state2->hw.adjusted_mode) &&
		m_n_equal(&crtc_state1->dp_m_n, &crtc_state2->dp_m_n);
}

static u8
intel_ddi_port_sync_transcoders(const struct intel_crtc_state *ref_crtc_state,
				int tile_group_id)
{
	struct drm_connector *connector;
	const struct drm_connector_state *conn_state;
	struct drm_i915_private *dev_priv = to_i915(ref_crtc_state->uapi.crtc->dev);
	struct intel_atomic_state *state =
		to_intel_atomic_state(ref_crtc_state->uapi.state);
	u8 transcoders = 0;
	int i;

3566 3567 3568 3569 3570
	/*
	 * We don't enable port sync on BDW due to missing w/as and
	 * due to not having adjusted the modeset sequence appropriately.
	 */
	if (INTEL_GEN(dev_priv) < 9)
3571 3572 3573 3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588 3589 3590 3591 3592 3593 3594 3595 3596 3597 3598 3599 3600 3601
		return 0;

	if (!intel_crtc_has_type(ref_crtc_state, INTEL_OUTPUT_DP))
		return 0;

	for_each_new_connector_in_state(&state->base, connector, conn_state, i) {
		struct intel_crtc *crtc = to_intel_crtc(conn_state->crtc);
		const struct intel_crtc_state *crtc_state;

		if (!crtc)
			continue;

		if (!connector->has_tile ||
		    connector->tile_group->id !=
		    tile_group_id)
			continue;
		crtc_state = intel_atomic_get_new_crtc_state(state,
							     crtc);
		if (!crtcs_port_sync_compatible(ref_crtc_state,
						crtc_state))
			continue;
		transcoders |= BIT(crtc_state->cpu_transcoder);
	}

	return transcoders;
}

static int intel_ddi_compute_config_late(struct intel_encoder *encoder,
					 struct intel_crtc_state *crtc_state,
					 struct drm_connector_state *conn_state)
{
3602
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
3603 3604 3605
	struct drm_connector *connector = conn_state->connector;
	u8 port_sync_transcoders = 0;

3606 3607 3608
	drm_dbg_kms(&i915->drm, "[ENCODER:%d:%s] [CRTC:%d:%s]",
		    encoder->base.base.id, encoder->base.name,
		    crtc_state->uapi.crtc->base.id, crtc_state->uapi.crtc->name);
3609 3610 3611 3612 3613 3614 3615 3616 3617 3618 3619 3620 3621 3622 3623 3624 3625 3626 3627 3628 3629 3630 3631

	if (connector->has_tile)
		port_sync_transcoders = intel_ddi_port_sync_transcoders(crtc_state,
									connector->tile_group->id);

	/*
	 * EDP Transcoders cannot be ensalved
	 * make them a master always when present
	 */
	if (port_sync_transcoders & BIT(TRANSCODER_EDP))
		crtc_state->master_transcoder = TRANSCODER_EDP;
	else
		crtc_state->master_transcoder = ffs(port_sync_transcoders) - 1;

	if (crtc_state->master_transcoder == crtc_state->cpu_transcoder) {
		crtc_state->master_transcoder = INVALID_TRANSCODER;
		crtc_state->sync_mode_slaves_mask =
			port_sync_transcoders & ~BIT(crtc_state->cpu_transcoder);
	}

	return 0;
}

3632 3633
static void intel_ddi_encoder_destroy(struct drm_encoder *encoder)
{
3634
	struct intel_digital_port *dig_port = enc_to_dig_port(to_intel_encoder(encoder));
3635 3636 3637 3638

	intel_dp_encoder_flush_work(encoder);

	drm_encoder_cleanup(encoder);
3639 3640
	if (dig_port)
		kfree(dig_port->hdcp_port_data.streams);
3641 3642 3643
	kfree(dig_port);
}

P
Paulo Zanoni 已提交
3644
static const struct drm_encoder_funcs intel_ddi_funcs = {
3645
	.reset = intel_dp_encoder_reset,
3646
	.destroy = intel_ddi_encoder_destroy,
P
Paulo Zanoni 已提交
3647 3648
};

3649
static struct intel_connector *
3650
intel_ddi_init_dp_connector(struct intel_digital_port *dig_port)
3651
{
3652
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
3653
	struct intel_connector *connector;
3654
	enum port port = dig_port->base.port;
3655

3656
	connector = intel_connector_alloc();
3657 3658 3659
	if (!connector)
		return NULL;

3660 3661 3662 3663
	dig_port->dp.output_reg = DDI_BUF_CTL(port);
	dig_port->dp.prepare_link_retrain = intel_ddi_prepare_link_retrain;
	dig_port->dp.set_link_train = intel_ddi_set_link_train;
	dig_port->dp.set_idle_link_train = intel_ddi_set_idle_link_train;
3664

3665
	if (INTEL_GEN(dev_priv) >= 12)
3666
		dig_port->dp.set_signal_levels = tgl_set_signal_levels;
3667
	else if (INTEL_GEN(dev_priv) >= 11)
3668
		dig_port->dp.set_signal_levels = icl_set_signal_levels;
3669
	else if (IS_CANNONLAKE(dev_priv))
3670
		dig_port->dp.set_signal_levels = cnl_set_signal_levels;
3671
	else if (IS_GEN9_LP(dev_priv))
3672
		dig_port->dp.set_signal_levels = bxt_set_signal_levels;
3673
	else
3674
		dig_port->dp.set_signal_levels = hsw_set_signal_levels;
3675

3676 3677
	dig_port->dp.voltage_max = intel_ddi_dp_voltage_max;
	dig_port->dp.preemph_max = intel_ddi_dp_preemph_max;
3678

3679
	if (!intel_dp_init_connector(dig_port, connector)) {
3680 3681 3682 3683 3684 3685 3686
		kfree(connector);
		return NULL;
	}

	return connector;
}

3687 3688 3689 3690 3691 3692 3693 3694 3695 3696 3697 3698 3699 3700 3701 3702 3703 3704 3705
static int modeset_pipe(struct drm_crtc *crtc,
			struct drm_modeset_acquire_ctx *ctx)
{
	struct drm_atomic_state *state;
	struct drm_crtc_state *crtc_state;
	int ret;

	state = drm_atomic_state_alloc(crtc->dev);
	if (!state)
		return -ENOMEM;

	state->acquire_ctx = ctx;

	crtc_state = drm_atomic_get_crtc_state(state, crtc);
	if (IS_ERR(crtc_state)) {
		ret = PTR_ERR(crtc_state);
		goto out;
	}

3706
	crtc_state->connectors_changed = true;
3707 3708

	ret = drm_atomic_commit(state);
3709
out:
3710 3711 3712 3713 3714 3715 3716 3717 3718
	drm_atomic_state_put(state);

	return ret;
}

static int intel_hdmi_reset_link(struct intel_encoder *encoder,
				 struct drm_modeset_acquire_ctx *ctx)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3719
	struct intel_hdmi *hdmi = enc_to_intel_hdmi(encoder);
3720 3721 3722 3723 3724 3725 3726 3727 3728 3729 3730 3731 3732 3733 3734 3735 3736 3737 3738 3739 3740 3741 3742 3743 3744 3745 3746 3747 3748
	struct intel_connector *connector = hdmi->attached_connector;
	struct i2c_adapter *adapter =
		intel_gmbus_get_adapter(dev_priv, hdmi->ddc_bus);
	struct drm_connector_state *conn_state;
	struct intel_crtc_state *crtc_state;
	struct intel_crtc *crtc;
	u8 config;
	int ret;

	if (!connector || connector->base.status != connector_status_connected)
		return 0;

	ret = drm_modeset_lock(&dev_priv->drm.mode_config.connection_mutex,
			       ctx);
	if (ret)
		return ret;

	conn_state = connector->base.state;

	crtc = to_intel_crtc(conn_state->crtc);
	if (!crtc)
		return 0;

	ret = drm_modeset_lock(&crtc->base.mutex, ctx);
	if (ret)
		return ret;

	crtc_state = to_intel_crtc_state(crtc->base.state);

3749 3750
	drm_WARN_ON(&dev_priv->drm,
		    !intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI));
3751

3752
	if (!crtc_state->hw.active)
3753 3754 3755 3756 3757 3758 3759 3760 3761 3762 3763 3764
		return 0;

	if (!crtc_state->hdmi_high_tmds_clock_ratio &&
	    !crtc_state->hdmi_scrambling)
		return 0;

	if (conn_state->commit &&
	    !try_wait_for_completion(&conn_state->commit->hw_done))
		return 0;

	ret = drm_scdc_readb(adapter, SCDC_TMDS_CONFIG, &config);
	if (ret < 0) {
3765 3766
		drm_err(&dev_priv->drm, "Failed to read TMDS config: %d\n",
			ret);
3767 3768 3769 3770 3771 3772 3773 3774 3775 3776 3777 3778 3779 3780 3781 3782 3783 3784 3785 3786 3787
		return 0;
	}

	if (!!(config & SCDC_TMDS_BIT_CLOCK_RATIO_BY_40) ==
	    crtc_state->hdmi_high_tmds_clock_ratio &&
	    !!(config & SCDC_SCRAMBLING_ENABLE) ==
	    crtc_state->hdmi_scrambling)
		return 0;

	/*
	 * HDMI 2.0 says that one should not send scrambled data
	 * prior to configuring the sink scrambling, and that
	 * TMDS clock/data transmission should be suspended when
	 * changing the TMDS clock rate in the sink. So let's
	 * just do a full modeset here, even though some sinks
	 * would be perfectly happy if were to just reconfigure
	 * the SCDC settings on the fly.
	 */
	return modeset_pipe(&crtc->base, ctx);
}

3788 3789
static enum intel_hotplug_state
intel_ddi_hotplug(struct intel_encoder *encoder,
3790
		  struct intel_connector *connector)
3791
{
3792
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
3793
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
3794
	struct intel_dp *intel_dp = &dig_port->dp;
3795 3796
	enum phy phy = intel_port_to_phy(i915, encoder->port);
	bool is_tc = intel_phy_is_tc(i915, phy);
3797
	struct drm_modeset_acquire_ctx ctx;
3798
	enum intel_hotplug_state state;
3799 3800
	int ret;

3801 3802 3803 3804 3805 3806 3807
	if (intel_dp->compliance.test_active &&
	    intel_dp->compliance.test_type == DP_TEST_LINK_PHY_TEST_PATTERN) {
		intel_dp_phy_test(encoder);
		/* just do the PHY test and nothing else */
		return INTEL_HOTPLUG_UNCHANGED;
	}

3808
	state = intel_encoder_hotplug(encoder, connector);
3809 3810 3811 3812

	drm_modeset_acquire_init(&ctx, 0);

	for (;;) {
3813 3814 3815 3816
		if (connector->base.connector_type == DRM_MODE_CONNECTOR_HDMIA)
			ret = intel_hdmi_reset_link(encoder, &ctx);
		else
			ret = intel_dp_retrain_link(encoder, &ctx);
3817 3818 3819 3820 3821 3822 3823 3824 3825 3826 3827

		if (ret == -EDEADLK) {
			drm_modeset_backoff(&ctx);
			continue;
		}

		break;
	}

	drm_modeset_drop_locks(&ctx);
	drm_modeset_acquire_fini(&ctx);
3828 3829
	drm_WARN(encoder->base.dev, ret,
		 "Acquiring modeset locks failed with %i\n", ret);
3830

3831 3832 3833 3834 3835 3836 3837 3838 3839 3840 3841 3842 3843 3844 3845
	/*
	 * Unpowered type-c dongles can take some time to boot and be
	 * responsible, so here giving some time to those dongles to power up
	 * and then retrying the probe.
	 *
	 * On many platforms the HDMI live state signal is known to be
	 * unreliable, so we can't use it to detect if a sink is connected or
	 * not. Instead we detect if it's connected based on whether we can
	 * read the EDID or not. That in turn has a problem during disconnect,
	 * since the HPD interrupt may be raised before the DDC lines get
	 * disconnected (due to how the required length of DDC vs. HPD
	 * connector pins are specified) and so we'll still be able to get a
	 * valid EDID. To solve this schedule another detection cycle if this
	 * time around we didn't detect any change in the sink's connection
	 * status.
3846 3847 3848 3849 3850 3851
	 *
	 * Type-c connectors which get their HPD signal deasserted then
	 * reasserted, without unplugging/replugging the sink from the
	 * connector, introduce a delay until the AUX channel communication
	 * becomes functional. Retry the detection for 5 seconds on type-c
	 * connectors to account for this delay.
3852
	 */
3853 3854
	if (state == INTEL_HOTPLUG_UNCHANGED &&
	    connector->hotplug_retries < (is_tc ? 5 : 1) &&
3855 3856 3857
	    !dig_port->dp.is_mst)
		state = INTEL_HOTPLUG_RETRY;

3858
	return state;
3859 3860
}

3861 3862 3863
static bool lpt_digital_port_connected(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3864
	u32 bit = dev_priv->hotplug.pch_hpd[encoder->hpd_pin];
3865 3866 3867 3868 3869 3870 3871

	return intel_de_read(dev_priv, SDEISR) & bit;
}

static bool hsw_digital_port_connected(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3872
	u32 bit = dev_priv->hotplug.hpd[encoder->hpd_pin];
3873

3874
	return intel_de_read(dev_priv, DEISR) & bit;
3875 3876 3877 3878 3879
}

static bool bdw_digital_port_connected(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3880
	u32 bit = dev_priv->hotplug.hpd[encoder->hpd_pin];
3881 3882 3883 3884

	return intel_de_read(dev_priv, GEN8_DE_PORT_ISR) & bit;
}

3885
static struct intel_connector *
3886
intel_ddi_init_hdmi_connector(struct intel_digital_port *dig_port)
3887 3888
{
	struct intel_connector *connector;
3889
	enum port port = dig_port->base.port;
3890

3891
	connector = intel_connector_alloc();
3892 3893 3894
	if (!connector)
		return NULL;

3895 3896
	dig_port->hdmi.hdmi_reg = DDI_BUF_CTL(port);
	intel_hdmi_init_connector(dig_port, connector);
3897 3898 3899 3900

	return connector;
}

3901
static bool intel_ddi_a_force_4_lanes(struct intel_digital_port *dig_port)
3902
{
3903
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
3904

3905
	if (dig_port->base.port != PORT_A)
3906 3907
		return false;

3908
	if (dig_port->saved_port_bits & DDI_A_4_LANES)
3909 3910 3911 3912 3913 3914 3915 3916 3917 3918 3919 3920 3921 3922 3923 3924 3925 3926 3927 3928
		return false;

	/* Broxton/Geminilake: Bspec says that DDI_A_4_LANES is the only
	 *                     supported configuration
	 */
	if (IS_GEN9_LP(dev_priv))
		return true;

	/* Cannonlake: Most of SKUs don't support DDI_E, and the only
	 *             one who does also have a full A/E split called
	 *             DDI_F what makes DDI_E useless. However for this
	 *             case let's trust VBT info.
	 */
	if (IS_CANNONLAKE(dev_priv) &&
	    !intel_bios_is_port_present(dev_priv, PORT_E))
		return true;

	return false;
}

3929
static int
3930
intel_ddi_max_lanes(struct intel_digital_port *dig_port)
3931
{
3932 3933
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
	enum port port = dig_port->base.port;
3934 3935 3936 3937 3938 3939
	int max_lanes = 4;

	if (INTEL_GEN(dev_priv) >= 11)
		return max_lanes;

	if (port == PORT_A || port == PORT_E) {
3940
		if (intel_de_read(dev_priv, DDI_BUF_CTL(PORT_A)) & DDI_A_4_LANES)
3941 3942 3943 3944 3945 3946 3947 3948 3949 3950 3951
			max_lanes = port == PORT_A ? 4 : 0;
		else
			/* Both A and E share 2 lanes */
			max_lanes = 2;
	}

	/*
	 * Some BIOS might fail to set this bit on port A if eDP
	 * wasn't lit up at boot.  Force this bit set when needed
	 * so we use the proper lane count for our calculations.
	 */
3952
	if (intel_ddi_a_force_4_lanes(dig_port)) {
3953 3954
		drm_dbg_kms(&dev_priv->drm,
			    "Forcing DDI_A_4_LANES for port A\n");
3955
		dig_port->saved_port_bits |= DDI_A_4_LANES;
3956 3957 3958 3959 3960 3961
		max_lanes = 4;
	}

	return max_lanes;
}

M
Matt Roper 已提交
3962 3963 3964
static bool hti_uses_phy(struct drm_i915_private *i915, enum phy phy)
{
	return i915->hti_state & HDPORT_ENABLED &&
3965
	       i915->hti_state & HDPORT_DDI_USED(phy);
M
Matt Roper 已提交
3966 3967
}

3968 3969 3970
static enum hpd_pin dg1_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
3971 3972
	if (port >= PORT_TC1)
		return HPD_PORT_C + port - PORT_TC1;
3973 3974 3975 3976
	else
		return HPD_PORT_A + port - PORT_A;
}

3977 3978 3979
static enum hpd_pin tgl_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
3980 3981
	if (port >= PORT_TC1)
		return HPD_PORT_TC1 + port - PORT_TC1;
3982 3983 3984 3985 3986 3987 3988 3989 3990 3991
	else
		return HPD_PORT_A + port - PORT_A;
}

static enum hpd_pin rkl_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
	if (HAS_PCH_TGP(dev_priv))
		return tgl_hpd_pin(dev_priv, port);

3992 3993
	if (port >= PORT_TC1)
		return HPD_PORT_C + port - PORT_TC1;
3994 3995 3996 3997 3998 3999 4000 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010 4011 4012 4013 4014 4015 4016 4017 4018 4019 4020 4021 4022 4023 4024 4025 4026 4027
	else
		return HPD_PORT_A + port - PORT_A;
}

static enum hpd_pin icl_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
	if (port >= PORT_C)
		return HPD_PORT_TC1 + port - PORT_C;
	else
		return HPD_PORT_A + port - PORT_A;
}

static enum hpd_pin ehl_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
	if (port == PORT_D)
		return HPD_PORT_A;

	if (HAS_PCH_MCC(dev_priv))
		return icl_hpd_pin(dev_priv, port);

	return HPD_PORT_A + port - PORT_A;
}

static enum hpd_pin cnl_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
	if (port == PORT_F)
		return HPD_PORT_E;

	return HPD_PORT_A + port - PORT_A;
}

4028 4029 4030 4031 4032 4033 4034 4035
static enum hpd_pin skl_hpd_pin(struct drm_i915_private *dev_priv, enum port port)
{
	if (HAS_PCH_TGP(dev_priv))
		return icl_hpd_pin(dev_priv, port);

	return HPD_PORT_A + port - PORT_A;
}

4036 4037 4038
#define port_tc_name(port) ((port) - PORT_TC1 + '1')
#define tc_port_name(tc_port) ((tc_port) - TC_PORT_1 + '1')

4039
void intel_ddi_init(struct drm_i915_private *dev_priv, enum port port)
P
Paulo Zanoni 已提交
4040
{
4041
	struct intel_digital_port *dig_port;
4042
	struct intel_encoder *encoder;
4043
	bool init_hdmi, init_dp;
4044
	enum phy phy = intel_port_to_phy(dev_priv, port);
4045

M
Matt Roper 已提交
4046 4047 4048 4049 4050 4051 4052 4053 4054 4055 4056 4057
	/*
	 * On platforms with HTI (aka HDPORT), if it's enabled at boot it may
	 * have taken over some of the PHYs and made them unavailable to the
	 * driver.  In that case we should skip initializing the corresponding
	 * outputs.
	 */
	if (hti_uses_phy(dev_priv, phy)) {
		drm_dbg_kms(&dev_priv->drm, "PORT %c / PHY %c reserved by HTI\n",
			    port_name(port), phy_name(phy));
		return;
	}

4058 4059 4060
	init_hdmi = intel_bios_port_supports_dvi(dev_priv, port) ||
		intel_bios_port_supports_hdmi(dev_priv, port);
	init_dp = intel_bios_port_supports_dp(dev_priv, port);
4061 4062 4063 4064 4065 4066 4067 4068 4069

	if (intel_bios_is_lspcon_present(dev_priv, port)) {
		/*
		 * Lspcon device needs to be driven with DP connector
		 * with special detection sequence. So make sure DP
		 * is initialized before lspcon.
		 */
		init_dp = true;
		init_hdmi = false;
4070 4071
		drm_dbg_kms(&dev_priv->drm, "VBT says port %c has lspcon\n",
			    port_name(port));
4072 4073
	}

4074
	if (!init_dp && !init_hdmi) {
4075 4076 4077
		drm_dbg_kms(&dev_priv->drm,
			    "VBT says port %c is not DVI/HDMI/DP compatible, respect it\n",
			    port_name(port));
4078
		return;
4079
	}
P
Paulo Zanoni 已提交
4080

4081 4082
	dig_port = kzalloc(sizeof(*dig_port), GFP_KERNEL);
	if (!dig_port)
P
Paulo Zanoni 已提交
4083 4084
		return;

4085
	encoder = &dig_port->base;
P
Paulo Zanoni 已提交
4086

4087 4088 4089 4090 4091 4092 4093
	if (INTEL_GEN(dev_priv) >= 12) {
		enum tc_port tc_port = intel_port_to_tc(dev_priv, port);

		drm_encoder_init(&dev_priv->drm, &encoder->base, &intel_ddi_funcs,
				 DRM_MODE_ENCODER_TMDS,
				 "DDI %s%c/PHY %s%c",
				 port >= PORT_TC1 ? "TC" : "",
4094
				 port >= PORT_TC1 ? port_tc_name(port) : port_name(port),
4095
				 tc_port != TC_PORT_NONE ? "TC" : "",
4096
				 tc_port != TC_PORT_NONE ? tc_port_name(tc_port) : phy_name(phy));
4097 4098 4099 4100 4101 4102 4103 4104 4105
	} else if (INTEL_GEN(dev_priv) >= 11) {
		enum tc_port tc_port = intel_port_to_tc(dev_priv, port);

		drm_encoder_init(&dev_priv->drm, &encoder->base, &intel_ddi_funcs,
				 DRM_MODE_ENCODER_TMDS,
				 "DDI %c%s/PHY %s%c",
				 port_name(port),
				 port >= PORT_C ? " (TC)" : "",
				 tc_port != TC_PORT_NONE ? "TC" : "",
4106
				 tc_port != TC_PORT_NONE ? tc_port_name(tc_port) : phy_name(phy));
4107 4108 4109 4110 4111
	} else {
		drm_encoder_init(&dev_priv->drm, &encoder->base, &intel_ddi_funcs,
				 DRM_MODE_ENCODER_TMDS,
				 "DDI %c/PHY %c", port_name(port),  phy_name(phy));
	}
P
Paulo Zanoni 已提交
4112

4113 4114 4115
	mutex_init(&dig_port->hdcp_mutex);
	dig_port->num_hdcp_streams = 0;

4116 4117 4118
	encoder->hotplug = intel_ddi_hotplug;
	encoder->compute_output_type = intel_ddi_compute_output_type;
	encoder->compute_config = intel_ddi_compute_config;
4119
	encoder->compute_config_late = intel_ddi_compute_config_late;
4120 4121 4122 4123 4124 4125 4126 4127
	encoder->enable = intel_enable_ddi;
	encoder->pre_pll_enable = intel_ddi_pre_pll_enable;
	encoder->pre_enable = intel_ddi_pre_enable;
	encoder->disable = intel_disable_ddi;
	encoder->post_disable = intel_ddi_post_disable;
	encoder->update_pipe = intel_ddi_update_pipe;
	encoder->get_hw_state = intel_ddi_get_hw_state;
	encoder->get_config = intel_ddi_get_config;
4128
	encoder->sync_state = intel_ddi_sync_state;
4129
	encoder->initial_fastset_check = intel_ddi_initial_fastset_check;
4130
	encoder->suspend = intel_dp_encoder_suspend;
4131
	encoder->shutdown = intel_dp_encoder_shutdown;
4132 4133 4134 4135 4136 4137 4138
	encoder->get_power_domains = intel_ddi_get_power_domains;

	encoder->type = INTEL_OUTPUT_DDI;
	encoder->power_domain = intel_port_to_power_domain(port);
	encoder->port = port;
	encoder->cloneable = 0;
	encoder->pipe_mask = ~0;
4139

4140 4141 4142 4143
	if (IS_CANNONLAKE(dev_priv)) {
		encoder->enable_clock = cnl_ddi_enable_clock;
		encoder->disable_clock = cnl_ddi_disable_clock;
	} else if (IS_GEN9_BC(dev_priv)) {
4144 4145 4146
		encoder->enable_clock = skl_ddi_enable_clock;
		encoder->disable_clock = skl_ddi_disable_clock;
	} else if (IS_BROADWELL(dev_priv) || IS_HASWELL(dev_priv)) {
4147 4148 4149 4150
		encoder->enable_clock = hsw_ddi_enable_clock;
		encoder->disable_clock = hsw_ddi_disable_clock;
	}

4151 4152 4153
	if (IS_DG1(dev_priv))
		encoder->hpd_pin = dg1_hpd_pin(dev_priv, port);
	else if (IS_ROCKETLAKE(dev_priv))
4154 4155 4156
		encoder->hpd_pin = rkl_hpd_pin(dev_priv, port);
	else if (INTEL_GEN(dev_priv) >= 12)
		encoder->hpd_pin = tgl_hpd_pin(dev_priv, port);
4157
	else if (IS_JSL_EHL(dev_priv))
4158 4159 4160 4161 4162
		encoder->hpd_pin = ehl_hpd_pin(dev_priv, port);
	else if (IS_GEN(dev_priv, 11))
		encoder->hpd_pin = icl_hpd_pin(dev_priv, port);
	else if (IS_GEN(dev_priv, 10))
		encoder->hpd_pin = cnl_hpd_pin(dev_priv, port);
4163 4164
	else if (IS_GEN(dev_priv, 9))
		encoder->hpd_pin = skl_hpd_pin(dev_priv, port);
4165 4166
	else
		encoder->hpd_pin = intel_hpd_pin_default(dev_priv, port);
P
Paulo Zanoni 已提交
4167

4168
	if (INTEL_GEN(dev_priv) >= 11)
4169 4170 4171
		dig_port->saved_port_bits =
			intel_de_read(dev_priv, DDI_BUF_CTL(port))
			& DDI_BUF_PORT_REVERSAL;
4172
	else
4173 4174 4175
		dig_port->saved_port_bits =
			intel_de_read(dev_priv, DDI_BUF_CTL(port))
			& (DDI_BUF_PORT_REVERSAL | DDI_A_4_LANES);
4176

4177 4178 4179
	if (intel_bios_is_lane_reversal_needed(dev_priv, port))
		dig_port->saved_port_bits |= DDI_BUF_PORT_REVERSAL;

4180 4181 4182
	dig_port->dp.output_reg = INVALID_MMIO_REG;
	dig_port->max_lanes = intel_ddi_max_lanes(dig_port);
	dig_port->aux_ch = intel_bios_port_aux_ch(dev_priv, port);
P
Paulo Zanoni 已提交
4183

4184
	if (intel_phy_is_tc(dev_priv, phy)) {
4185 4186 4187
		bool is_legacy =
			!intel_bios_port_supports_typec_usb(dev_priv, port) &&
			!intel_bios_port_supports_tbt(dev_priv, port);
4188

4189
		intel_tc_port_init(dig_port, is_legacy);
4190

4191 4192
		encoder->update_prepare = intel_ddi_update_prepare;
		encoder->update_complete = intel_ddi_update_complete;
4193
	}
4194

4195
	drm_WARN_ON(&dev_priv->drm, port > PORT_I);
4196
	dig_port->ddi_io_power_domain = POWER_DOMAIN_PORT_DDI_A_IO +
4197
					      port - PORT_A;
4198

4199
	if (init_dp) {
4200
		if (!intel_ddi_init_dp_connector(dig_port))
4201
			goto err;
4202

4203
		dig_port->hpd_pulse = intel_dp_hpd_pulse;
4204
	}
4205

4206 4207
	/* In theory we don't need the encoder->type check, but leave it just in
	 * case we have some really bad VBTs... */
4208
	if (encoder->type != INTEL_OUTPUT_EDP && init_hdmi) {
4209
		if (!intel_ddi_init_hdmi_connector(dig_port))
4210
			goto err;
4211
	}
4212

4213 4214
	if (INTEL_GEN(dev_priv) >= 11) {
		if (intel_phy_is_tc(dev_priv, phy))
4215
			dig_port->connected = intel_tc_port_connected;
4216
		else
4217
			dig_port->connected = lpt_digital_port_connected;
4218 4219
	} else if (INTEL_GEN(dev_priv) >= 8) {
		if (port == PORT_A || IS_GEN9_LP(dev_priv))
4220
			dig_port->connected = bdw_digital_port_connected;
4221
		else
4222
			dig_port->connected = lpt_digital_port_connected;
4223
	} else {
4224
		if (port == PORT_A)
4225
			dig_port->connected = hsw_digital_port_connected;
4226
		else
4227
			dig_port->connected = lpt_digital_port_connected;
4228 4229
	}

4230
	intel_infoframe_init(dig_port);
4231

4232 4233 4234
	return;

err:
4235
	drm_encoder_cleanup(&encoder->base);
4236
	kfree(dig_port);
P
Paulo Zanoni 已提交
4237
}