intel_ddi.c 128.7 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
static void dg1_ddi_enable_clock(struct intel_encoder *encoder,
				 const struct intel_crtc_state *crtc_state)
1604 1605 1606 1607 1608 1609 1610 1611 1612 1613 1614 1615 1616 1617 1618 1619
{
	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);

	/*
	 * 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);

1620 1621 1622
	intel_de_rmw(dev_priv, DG1_DPCLKA_CFGCR0(phy),
		     DG1_DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(phy),
		     DG1_DPCLKA_CFGCR0_DDI_CLK_SEL(pll->info->id, phy));
1623

1624 1625
	intel_de_rmw(dev_priv, DG1_DPCLKA_CFGCR0(phy),
		     DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy), 0);
1626 1627 1628 1629

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

1630 1631 1632 1633 1634 1635 1636
static void dg1_ddi_disable_clock(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);

1637 1638
	intel_de_rmw(dev_priv, DG1_DPCLKA_CFGCR0(phy),
		     0, DG1_DPCLKA_CFGCR0_DDI_CLK_OFF(phy));
1639 1640 1641 1642

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

1643 1644
static void icl_ddi_combo_enable_clock(struct intel_encoder *encoder,
				       const struct intel_crtc_state *crtc_state)
1645
{
1646
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1647
	struct intel_shared_dpll *pll = crtc_state->shared_dpll;
1648
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1649
	u32 mask, sel;
1650 1651 1652 1653 1654 1655 1656 1657 1658 1659 1660 1661 1662 1663 1664
	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);
	}
1665

1666
	mutex_lock(&dev_priv->dpll.lock);
1667

1668 1669 1670 1671 1672 1673 1674 1675 1676 1677
	/*
	 * 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."
	 */
1678
	intel_de_rmw(dev_priv, reg, mask, sel);
1679

1680 1681
	intel_de_rmw(dev_priv, reg,
		     icl_dpclka_cfgcr0_clk_off(dev_priv, phy), 0);
1682

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

1686
static void icl_ddi_combo_disable_clock(struct intel_encoder *encoder)
1687
{
1688
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1689
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
1690
	i915_reg_t reg;
1691

1692
	mutex_lock(&dev_priv->dpll.lock);
1693

1694 1695 1696 1697 1698
	if (IS_ALDERLAKE_S(dev_priv))
		reg = ADLS_DPCLKA_CFGCR(phy);
	else
		reg = ICL_DPCLKA_CFGCR0;

1699
	mutex_lock(&dev_priv->dpll.lock);
1700

1701 1702
	intel_de_rmw(dev_priv, reg,
		     0, icl_dpclka_cfgcr0_clk_off(dev_priv, phy));
1703

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

1707 1708 1709 1710 1711 1712 1713 1714 1715 1716 1717 1718 1719 1720 1721 1722 1723 1724 1725 1726 1727 1728 1729 1730 1731 1732 1733 1734 1735 1736 1737
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);
	}
}

1738 1739 1740 1741
static void icl_sanitize_port_clk_off(struct drm_i915_private *dev_priv,
				      u32 port_mask, bool ddi_clk_needed)
{
	enum port port;
1742
	bool ddi_clk_off;
1743
	u32 val;
1744
	i915_reg_t reg;
1745 1746 1747

	for_each_port_masked(port, port_mask) {
		enum phy phy = intel_port_to_phy(dev_priv, port);
1748 1749 1750 1751 1752 1753 1754 1755 1756

		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);
1757

1758
		if (ddi_clk_needed == !ddi_clk_off)
1759 1760 1761 1762 1763 1764
			continue;

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

1768 1769 1770
		drm_notice(&dev_priv->drm,
			   "PHY %c is disabled/in DSI mode with an ungated DDI clock, gate it\n",
			   phy_name(phy));
1771
		val |= icl_dpclka_cfgcr0_clk_off(dev_priv, phy);
1772
		intel_de_write(dev_priv, reg, val);
1773 1774 1775
	}
}

1776 1777 1778
void icl_sanitize_encoder_pll_mapping(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
1779 1780
	u32 port_mask;
	bool ddi_clk_needed;
1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797

	/*
	 * 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.
		 */
1798
		if (drm_WARN_ON(&dev_priv->drm, is_mst))
1799 1800
			return;
	}
1801

1802 1803
	port_mask = BIT(encoder->port);
	ddi_clk_needed = encoder->base.crtc;
1804

1805 1806
	if (encoder->type == INTEL_OUTPUT_DSI) {
		struct intel_encoder *other_encoder;
1807

1808 1809 1810 1811 1812 1813 1814 1815 1816
		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;

1817 1818
			if (drm_WARN_ON(&dev_priv->drm,
					port_mask & BIT(other_encoder->port)))
1819 1820 1821
				return;
		}
		/*
1822 1823
		 * For DSI we keep the ddi clocks gated
		 * except during enable/disable sequence.
1824
		 */
1825
		ddi_clk_needed = false;
1826 1827
	}

1828 1829 1830 1831
	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);
1832 1833
}

1834 1835
static void jsl_ddi_tc_enable_clock(struct intel_encoder *encoder,
				    const struct intel_crtc_state *crtc_state)
1836
{
1837 1838
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
1839
	enum port port = encoder->port;
1840 1841 1842 1843 1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866

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

	/*
	 * "For DDIC and DDID, program DDI_CLK_SEL to map the MG clock to the port.
	 *  MG does not exist, but the programming is required to ungate DDIC and DDID."
	 */
	intel_de_write(i915, DDI_CLK_SEL(port), DDI_CLK_SEL_MG);

	icl_ddi_combo_enable_clock(encoder, crtc_state);
}

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

	icl_ddi_combo_disable_clock(encoder);

	intel_de_write(i915, DDI_CLK_SEL(port), DDI_CLK_SEL_NONE);
}

static void icl_ddi_tc_enable_clock(struct intel_encoder *encoder,
				    const struct intel_crtc_state *crtc_state)
{
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
1867
	const struct intel_shared_dpll *pll = crtc_state->shared_dpll;
1868 1869
	enum tc_port tc_port = intel_port_to_tc(i915, encoder->port);
	enum port port = encoder->port;
1870

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

1874 1875
	intel_de_write(i915, DDI_CLK_SEL(port),
		       icl_pll_to_ddi_clk_sel(encoder, crtc_state));
1876

1877
	mutex_lock(&i915->dpll.lock);
1878

1879 1880 1881 1882
	intel_de_rmw(i915, ICL_DPCLKA_CFGCR0,
		     ICL_DPCLKA_CFGCR0_TC_CLK_OFF(tc_port), 0);

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

1885
static void icl_ddi_tc_disable_clock(struct intel_encoder *encoder)
1886
{
1887 1888
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
	enum tc_port tc_port = intel_port_to_tc(i915, encoder->port);
1889
	enum port port = encoder->port;
1890

1891 1892 1893 1894 1895 1896 1897 1898
	mutex_lock(&i915->dpll.lock);

	intel_de_rmw(i915, ICL_DPCLKA_CFGCR0,
		     0, ICL_DPCLKA_CFGCR0_TC_CLK_OFF(tc_port));

	mutex_unlock(&i915->dpll.lock);

	intel_de_write(i915, DDI_CLK_SEL(port), DDI_CLK_SEL_NONE);
1899 1900
}

1901 1902 1903 1904 1905 1906 1907 1908 1909 1910 1911 1912
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;

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

	mutex_lock(&i915->dpll.lock);

1913 1914 1915
	intel_de_rmw(i915, DPCLKA_CFGCR0,
		     DPCLKA_CFGCR0_DDI_CLK_SEL_MASK(port),
		     DPCLKA_CFGCR0_DDI_CLK_SEL(pll->info->id, port));
1916 1917 1918 1919 1920

	/*
	 * "This step and the step before must be
	 *  done with separate register writes."
	 */
1921 1922
	intel_de_rmw(i915, DPCLKA_CFGCR0,
		     DPCLKA_CFGCR0_DDI_CLK_OFF(port), 0);
1923 1924 1925 1926 1927 1928 1929 1930 1931

	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;

1932 1933
	intel_de_rmw(i915, DPCLKA_CFGCR0,
		     0, DPCLKA_CFGCR0_DDI_CLK_OFF(port));
1934 1935
}

1936 1937 1938 1939 1940 1941 1942 1943 1944 1945 1946 1947
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;

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

	mutex_lock(&i915->dpll.lock);

1948 1949 1950 1951 1952
	intel_de_rmw(i915, DPLL_CTRL2,
		     DPLL_CTRL2_DDI_CLK_OFF(port) |
		     DPLL_CTRL2_DDI_CLK_SEL_MASK(port),
		     DPLL_CTRL2_DDI_CLK_SEL(pll->info->id, port) |
		     DPLL_CTRL2_DDI_SEL_OVERRIDE(port));
1953 1954 1955 1956 1957 1958 1959 1960 1961

	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;

1962 1963
	intel_de_rmw(i915, DPLL_CTRL2,
		     0, DPLL_CTRL2_DDI_CLK_OFF(port));
1964 1965
}

1966 1967 1968 1969 1970 1971 1972 1973 1974 1975 1976 1977 1978 1979 1980 1981 1982 1983 1984 1985 1986
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);
}

1987 1988 1989 1990 1991 1992 1993 1994 1995 1996 1997 1998 1999
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);
}

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

2000
static void
2001
icl_program_mg_dp_mode(struct intel_digital_port *dig_port,
2002
		       const struct intel_crtc_state *crtc_state)
2003
{
2004 2005
	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);
2006
	enum phy phy = intel_port_to_phy(dev_priv, dig_port->base.port);
2007 2008
	u32 ln0, ln1, pin_assignment;
	u8 width;
2009

2010 2011
	if (!intel_phy_is_tc(dev_priv, phy) ||
	    dig_port->tc_mode == TC_PORT_TBT_ALT)
2012 2013
		return;

2014
	if (INTEL_GEN(dev_priv) >= 12) {
2015 2016 2017 2018 2019 2020
		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));
2021
	} else {
2022 2023
		ln0 = intel_de_read(dev_priv, MG_DP_MODE(0, tc_port));
		ln1 = intel_de_read(dev_priv, MG_DP_MODE(1, tc_port));
2024
	}
2025

2026
	ln0 &= ~(MG_DP_MODE_CFG_DP_X1_MODE | MG_DP_MODE_CFG_DP_X2_MODE);
2027
	ln1 &= ~(MG_DP_MODE_CFG_DP_X1_MODE | MG_DP_MODE_CFG_DP_X2_MODE);
2028

2029
	/* DPPATC */
2030
	pin_assignment = intel_tc_port_get_pin_assignment_mask(dig_port);
2031
	width = crtc_state->lane_count;
2032

2033 2034
	switch (pin_assignment) {
	case 0x0:
2035
		drm_WARN_ON(&dev_priv->drm,
2036
			    dig_port->tc_mode != TC_PORT_LEGACY);
2037 2038 2039 2040 2041 2042 2043 2044 2045 2046 2047 2048 2049 2050 2051 2052 2053 2054 2055 2056 2057 2058
		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) {
2059 2060
			ln0 |= MG_DP_MODE_CFG_DP_X1_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X1_MODE;
2061 2062 2063
		} else {
			ln0 |= MG_DP_MODE_CFG_DP_X2_MODE;
			ln1 |= MG_DP_MODE_CFG_DP_X2_MODE;
2064 2065
		}
		break;
2066 2067 2068 2069 2070 2071 2072 2073 2074
	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;
		}
2075 2076
		break;
	default:
2077
		MISSING_CASE(pin_assignment);
2078 2079
	}

2080
	if (INTEL_GEN(dev_priv) >= 12) {
2081 2082 2083 2084 2085 2086
		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);
2087
	} else {
2088 2089
		intel_de_write(dev_priv, MG_DP_MODE(0, tc_port), ln0);
		intel_de_write(dev_priv, MG_DP_MODE(1, tc_port), ln1);
2090
	}
2091 2092
}

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
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);
}

2124 2125 2126 2127 2128 2129 2130 2131 2132 2133 2134 2135 2136 2137 2138 2139
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");
}

2140 2141 2142
static void intel_dp_sink_set_fec_ready(struct intel_dp *intel_dp,
					const struct intel_crtc_state *crtc_state)
{
2143 2144
	struct drm_i915_private *i915 = dp_to_i915(intel_dp);

2145 2146 2147 2148
	if (!crtc_state->fec_enable)
		return;

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

2153 2154 2155 2156
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);
2157
	struct intel_dp *intel_dp;
2158 2159 2160 2161 2162
	u32 val;

	if (!crtc_state->fec_enable)
		return;

2163
	intel_dp = enc_to_intel_dp(encoder);
2164
	val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
2165
	val |= DP_TP_CTL_FEC_ENABLE;
2166
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
2167 2168
}

A
Anusha Srivatsa 已提交
2169 2170 2171 2172
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);
2173
	struct intel_dp *intel_dp;
A
Anusha Srivatsa 已提交
2174 2175 2176 2177 2178
	u32 val;

	if (!crtc_state->fec_enable)
		return;

2179
	intel_dp = enc_to_intel_dp(encoder);
2180
	val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
A
Anusha Srivatsa 已提交
2181
	val &= ~DP_TP_CTL_FEC_ENABLE;
2182 2183
	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 已提交
2184 2185
}

2186 2187 2188 2189 2190 2191 2192 2193 2194 2195 2196 2197 2198 2199 2200 2201 2202
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);
	}
}

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

2215 2216 2217
	intel_dp_set_link_params(intel_dp,
				 crtc_state->port_clock,
				 crtc_state->lane_count);
2218

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

2226
	/* 2. Enable Panel Power if PPS is required */
2227
	intel_pps_on(intel_dp);
2228 2229

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

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

2246
	/* 5. If IO power is controlled through PWR_WELL_CTL, Enable IO Power */
2247
	if (!intel_phy_is_tc(dev_priv, phy) ||
2248 2249 2250 2251 2252
	    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);
	}
2253

2254
	/* 6. Program DP_MODE */
2255
	icl_program_mg_dp_mode(dig_port, crtc_state);
2256 2257

	/*
2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269
	 * 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.
2270
	 */
2271
	intel_ddi_enable_pipe_clock(encoder, crtc_state);
2272

2273 2274 2275 2276
	/*
	 * 7.b Configure TRANS_DDI_FUNC_CTL DDI Select, DDI Mode Select & MST
	 * Transport Select
	 */
2277
	intel_ddi_config_transcoder_func(encoder, crtc_state);
2278

2279 2280 2281 2282 2283 2284 2285 2286 2287
	/*
	 * 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 */
2288
	tgl_ddi_vswing_sequence(encoder, crtc_state, level);
2289

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

2296 2297 2298 2299 2300 2301 2302 2303
	/*
	 * 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.
	 */
2304
	intel_ddi_init_dp_buf_reg(encoder, crtc_state);
2305 2306

	if (!is_mst)
2307
		intel_dp_set_power(intel_dp, DP_SET_POWER_D0);
2308

2309
	intel_dp_configure_protocol_converter(intel_dp, crtc_state);
2310 2311 2312 2313 2314 2315 2316
	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);
2317

2318
	intel_dp_check_frl_training(intel_dp);
2319
	intel_dp_pcon_dsc_configure(intel_dp, crtc_state);
2320

2321 2322 2323 2324 2325 2326 2327
	/*
	 * 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)
	 */
2328
	intel_dp_start_link_train(intel_dp, crtc_state);
2329

2330
	/* 7.k Set DP_TP_CTL link training to Normal */
2331
	if (!is_trans_port_sync_mode(crtc_state))
2332
		intel_dp_stop_link_train(intel_dp, crtc_state);
2333

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

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

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

2359 2360 2361
	intel_dp_set_link_params(intel_dp,
				 crtc_state->port_clock,
				 crtc_state->lane_count);
2362

2363
	intel_pps_on(intel_dp);
2364

2365
	intel_ddi_enable_clock(encoder, crtc_state);
2366

2367
	if (!intel_phy_is_tc(dev_priv, phy) ||
2368 2369 2370 2371 2372
	    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);
	}
2373

2374
	icl_program_mg_dp_mode(dig_port, crtc_state);
P
Paulo Zanoni 已提交
2375

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

2385
	intel_ddi_power_up_lanes(encoder, crtc_state);
2386

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

2399 2400
	intel_ddi_enable_fec(encoder, crtc_state);

2401
	if (!is_mst)
2402
		intel_ddi_enable_pipe_clock(encoder, crtc_state);
2403

2404 2405
	if (!crtc_state->bigjoiner)
		intel_dsc_enable(encoder, crtc_state);
2406
}
2407

2408 2409
static void intel_ddi_pre_enable_dp(struct intel_atomic_state *state,
				    struct intel_encoder *encoder,
2410 2411 2412 2413 2414 2415
				    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)
2416
		tgl_ddi_pre_enable_dp(state, encoder, crtc_state, conn_state);
2417
	else
2418
		hsw_ddi_pre_enable_dp(state, encoder, crtc_state, conn_state);
2419

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

2426 2427
		intel_dp_set_m_n(crtc_state, M1_N1);
	}
2428 2429
}

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

2439
	intel_dp_dual_mode_set_tmds_output(intel_hdmi, true);
2440
	intel_ddi_enable_clock(encoder, crtc_state);
2441

2442 2443 2444
	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);
2445

2446
	icl_program_mg_dp_mode(dig_port, crtc_state);
2447

2448
	intel_ddi_enable_pipe_clock(encoder, crtc_state);
2449

2450 2451 2452
	dig_port->set_infoframes(encoder,
				 crtc_state->has_infoframe,
				 crtc_state, conn_state);
2453
}
2454

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

2464 2465 2466 2467 2468 2469 2470 2471 2472 2473 2474 2475 2476
	/*
	 * 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
	 */

2477
	drm_WARN_ON(&dev_priv->drm, crtc_state->has_pch_encoder);
2478 2479 2480

	intel_set_cpu_fifo_underrun_reporting(dev_priv, pipe, true);

2481
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI)) {
2482 2483
		intel_ddi_pre_enable_hdmi(state, encoder, crtc_state,
					  conn_state);
2484
	} else {
2485
		struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2486

2487 2488
		intel_ddi_pre_enable_dp(state, encoder, crtc_state,
					conn_state);
2489

2490 2491 2492
		/* FIXME precompute everything properly */
		/* FIXME how do we turn infoframes off again? */
		if (dig_port->lspcon.active && dig_port->dp.has_hdmi_sink)
2493 2494 2495 2496
			dig_port->set_infoframes(encoder,
						 crtc_state->has_infoframe,
						 crtc_state, conn_state);
	}
2497 2498
}

A
Anusha Srivatsa 已提交
2499 2500
static void intel_disable_ddi_buf(struct intel_encoder *encoder,
				  const struct intel_crtc_state *crtc_state)
2501 2502
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2503
	enum port port = encoder->port;
2504 2505 2506
	bool wait = false;
	u32 val;

2507
	val = intel_de_read(dev_priv, DDI_BUF_CTL(port));
2508 2509
	if (val & DDI_BUF_CTL_ENABLE) {
		val &= ~DDI_BUF_CTL_ENABLE;
2510
		intel_de_write(dev_priv, DDI_BUF_CTL(port), val);
2511 2512 2513
		wait = true;
	}

2514
	if (intel_crtc_has_dp_encoder(crtc_state)) {
2515
		val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
2516 2517
		val &= ~(DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_MASK);
		val |= DP_TP_CTL_LINK_TRAIN_PAT1;
2518
		intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
2519
	}
2520

A
Anusha Srivatsa 已提交
2521 2522 2523
	/* Disable FEC in DP Sink */
	intel_ddi_disable_fec_state(encoder, crtc_state);

2524 2525 2526 2527
	if (wait)
		intel_wait_ddi_buf_idle(dev_priv, port);
}

2528 2529
static void intel_ddi_post_disable_dp(struct intel_atomic_state *state,
				      struct intel_encoder *encoder,
2530 2531
				      const struct intel_crtc_state *old_crtc_state,
				      const struct drm_connector_state *old_conn_state)
2532
{
2533
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2534
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2535
	struct intel_dp *intel_dp = &dig_port->dp;
2536 2537
	bool is_mst = intel_crtc_has_type(old_crtc_state,
					  INTEL_OUTPUT_DP_MST);
2538
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
2539

2540 2541 2542
	if (!is_mst)
		intel_dp_set_infoframes(encoder, false,
					old_crtc_state, old_conn_state);
2543

2544 2545 2546 2547
	/*
	 * Power down sink before disabling the port, otherwise we end
	 * up getting interrupts from the sink on detecting link loss.
	 */
2548
	intel_dp_set_power(intel_dp, DP_SET_POWER_D3);
2549

2550 2551 2552 2553 2554
	if (INTEL_GEN(dev_priv) >= 12) {
		if (is_mst) {
			enum transcoder cpu_transcoder = old_crtc_state->cpu_transcoder;
			u32 val;

2555 2556
			val = intel_de_read(dev_priv,
					    TRANS_DDI_FUNC_CTL(cpu_transcoder));
2557 2558
			val &= ~(TGL_TRANS_DDI_PORT_MASK |
				 TRANS_DDI_MODE_SELECT_MASK);
2559 2560 2561
			intel_de_write(dev_priv,
				       TRANS_DDI_FUNC_CTL(cpu_transcoder),
				       val);
2562 2563 2564 2565 2566
		}
	} else {
		if (!is_mst)
			intel_ddi_disable_pipe_clock(old_crtc_state);
	}
2567

A
Anusha Srivatsa 已提交
2568
	intel_disable_ddi_buf(encoder, old_crtc_state);
2569

2570 2571 2572 2573 2574 2575 2576 2577
	/*
	 * 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);

2578 2579
	intel_pps_vdd_on(intel_dp);
	intel_pps_off(intel_dp);
2580

2581
	if (!intel_phy_is_tc(dev_priv, phy) ||
2582
	    dig_port->tc_mode != TC_PORT_TBT_ALT)
2583 2584 2585
		intel_display_power_put(dev_priv,
					dig_port->ddi_io_power_domain,
					fetch_and_zero(&dig_port->ddi_io_wakeref));
2586

2587
	intel_ddi_disable_clock(encoder);
2588
}
2589

2590 2591
static void intel_ddi_post_disable_hdmi(struct intel_atomic_state *state,
					struct intel_encoder *encoder,
2592 2593 2594 2595
					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);
2596
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2597
	struct intel_hdmi *intel_hdmi = &dig_port->hdmi;
2598

2599
	dig_port->set_infoframes(encoder, false,
2600 2601
				 old_crtc_state, old_conn_state);

2602 2603
	intel_ddi_disable_pipe_clock(old_crtc_state);

A
Anusha Srivatsa 已提交
2604
	intel_disable_ddi_buf(encoder, old_crtc_state);
2605

2606 2607 2608
	intel_display_power_put(dev_priv,
				dig_port->ddi_io_power_domain,
				fetch_and_zero(&dig_port->ddi_io_wakeref));
2609

2610
	intel_ddi_disable_clock(encoder);
2611 2612 2613 2614

	intel_dp_dual_mode_set_tmds_output(intel_hdmi, false);
}

2615 2616
static void intel_ddi_post_disable(struct intel_atomic_state *state,
				   struct intel_encoder *encoder,
2617 2618 2619
				   const struct intel_crtc_state *old_crtc_state,
				   const struct drm_connector_state *old_conn_state)
{
2620
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2621
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2622 2623
	enum phy phy = intel_port_to_phy(dev_priv, encoder->port);
	bool is_tc_port = intel_phy_is_tc(dev_priv, phy);
2624

2625 2626
	if (!intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_DP_MST)) {
		intel_crtc_vblank_off(old_crtc_state);
2627

2628
		intel_disable_pipe(old_crtc_state);
2629

2630 2631
		intel_vrr_disable(old_crtc_state);

2632
		intel_ddi_disable_transcoder_func(old_crtc_state);
2633

2634
		intel_dsc_disable(old_crtc_state);
2635

2636 2637 2638 2639 2640
		if (INTEL_GEN(dev_priv) >= 9)
			skl_scaler_disable(old_crtc_state);
		else
			ilk_pfit_disable(old_crtc_state);
	}
2641

2642 2643 2644 2645 2646 2647 2648 2649 2650 2651 2652 2653 2654 2655 2656
	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);
	}

2657
	/*
2658 2659 2660 2661 2662 2663 2664 2665 2666 2667
	 * 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
2668
	 */
2669 2670

	if (intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_HDMI))
2671 2672
		intel_ddi_post_disable_hdmi(state, encoder, old_crtc_state,
					    old_conn_state);
2673
	else
2674 2675
		intel_ddi_post_disable_dp(state, encoder, old_crtc_state,
					  old_conn_state);
2676

2677
	if (intel_crtc_has_dp_encoder(old_crtc_state) || is_tc_port)
2678 2679 2680
		intel_display_power_put(dev_priv,
					intel_ddi_main_link_aux_domain(dig_port),
					fetch_and_zero(&dig_port->aux_wakeref));
2681 2682 2683

	if (is_tc_port)
		intel_tc_port_put_link(dig_port);
2684 2685
}

2686 2687
void intel_ddi_fdi_post_disable(struct intel_atomic_state *state,
				struct intel_encoder *encoder,
2688 2689
				const struct intel_crtc_state *old_crtc_state,
				const struct drm_connector_state *old_conn_state)
2690
{
2691
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2692
	u32 val;
2693 2694 2695 2696 2697 2698 2699

	/*
	 * 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.
	 */
2700
	val = intel_de_read(dev_priv, FDI_RX_CTL(PIPE_A));
2701
	val &= ~FDI_RX_ENABLE;
2702
	intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), val);
2703

A
Anusha Srivatsa 已提交
2704
	intel_disable_ddi_buf(encoder, old_crtc_state);
2705
	intel_ddi_disable_clock(encoder);
2706

2707
	val = intel_de_read(dev_priv, FDI_RX_MISC(PIPE_A));
2708 2709
	val &= ~(FDI_RX_PWRDN_LANE1_MASK | FDI_RX_PWRDN_LANE0_MASK);
	val |= FDI_RX_PWRDN_LANE1_VAL(2) | FDI_RX_PWRDN_LANE0_VAL(2);
2710
	intel_de_write(dev_priv, FDI_RX_MISC(PIPE_A), val);
2711

2712
	val = intel_de_read(dev_priv, FDI_RX_CTL(PIPE_A));
2713
	val &= ~FDI_PCDCLK;
2714
	intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), val);
2715

2716
	val = intel_de_read(dev_priv, FDI_RX_CTL(PIPE_A));
2717
	val &= ~FDI_RX_PLL_ENABLE;
2718
	intel_de_write(dev_priv, FDI_RX_CTL(PIPE_A), val);
2719 2720
}

2721 2722 2723 2724 2725 2726 2727 2728 2729 2730 2731 2732 2733 2734 2735 2736 2737 2738 2739 2740 2741 2742 2743 2744 2745 2746 2747
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;

2748 2749
		intel_dp_stop_link_train(enc_to_intel_dp(slave_encoder),
					 slave_crtc_state);
2750 2751 2752 2753
	}

	usleep_range(200, 400);

2754 2755
	intel_dp_stop_link_train(enc_to_intel_dp(encoder),
				 crtc_state);
2756 2757
}

2758 2759
static void intel_enable_ddi_dp(struct intel_atomic_state *state,
				struct intel_encoder *encoder,
2760 2761
				const struct intel_crtc_state *crtc_state,
				const struct drm_connector_state *conn_state)
2762
{
2763
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
2764
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2765
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2766
	enum port port = encoder->port;
2767

2768
	if (port == PORT_A && INTEL_GEN(dev_priv) < 9)
2769
		intel_dp_stop_link_train(intel_dp, crtc_state);
2770

2771
	intel_edp_backlight_on(crtc_state, conn_state);
2772
	intel_psr_enable(intel_dp, crtc_state, conn_state);
2773 2774 2775 2776

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

2777
	intel_edp_drrs_enable(intel_dp, crtc_state);
2778

2779 2780
	if (crtc_state->has_audio)
		intel_audio_codec_enable(encoder, crtc_state, conn_state);
2781 2782

	trans_port_sync_stop_link_train(state, encoder, crtc_state);
2783 2784
}

2785 2786 2787 2788
static i915_reg_t
gen9_chicken_trans_reg_by_port(struct drm_i915_private *dev_priv,
			       enum port port)
{
2789 2790 2791 2792 2793 2794
	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,
2795 2796
	};

2797
	drm_WARN_ON(&dev_priv->drm, INTEL_GEN(dev_priv) < 9);
2798

2799
	if (drm_WARN_ON(&dev_priv->drm, port < PORT_A || port > PORT_E))
2800 2801
		port = PORT_A;

2802
	return CHICKEN_TRANS(trans[port]);
2803 2804
}

2805 2806
static void intel_enable_ddi_hdmi(struct intel_atomic_state *state,
				  struct intel_encoder *encoder,
2807 2808 2809 2810
				  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);
2811
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
2812
	struct drm_connector *connector = conn_state->connector;
2813
	int level = intel_ddi_hdmi_level(encoder, crtc_state);
2814
	enum port port = encoder->port;
2815

2816 2817 2818
	if (!intel_hdmi_handle_sink_scrambling(encoder, connector,
					       crtc_state->hdmi_high_tmds_clock_ratio,
					       crtc_state->hdmi_scrambling))
2819 2820 2821
		drm_dbg_kms(&dev_priv->drm,
			    "[CONNECTOR:%d:%s] Failed to configure sink scrambling/TMDS bit clock ratio\n",
			    connector->base.id, connector->name);
2822

2823 2824 2825 2826 2827 2828 2829 2830 2831 2832 2833 2834 2835 2836
	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);

2837 2838 2839 2840 2841 2842 2843 2844
	/* 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.
		 */
2845
		i915_reg_t reg = gen9_chicken_trans_reg_by_port(dev_priv, port);
2846 2847
		u32 val;

2848
		val = intel_de_read(dev_priv, reg);
2849 2850 2851 2852 2853 2854 2855 2856

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

2857 2858
		intel_de_write(dev_priv, reg, val);
		intel_de_posting_read(dev_priv, reg);
2859 2860 2861 2862 2863 2864 2865 2866 2867 2868

		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);

2869
		intel_de_write(dev_priv, reg, val);
2870 2871
	}

2872 2873
	intel_ddi_power_up_lanes(encoder, crtc_state);

2874 2875 2876 2877
	/* In HDMI/DVI mode, the port width, and swing/emphasis values
	 * are ignored so nothing special needs to be done besides
	 * enabling the port.
	 */
2878 2879
	intel_de_write(dev_priv, DDI_BUF_CTL(port),
		       dig_port->saved_port_bits | DDI_BUF_CTL_ENABLE);
2880

2881 2882 2883 2884
	if (crtc_state->has_audio)
		intel_audio_codec_enable(encoder, crtc_state, conn_state);
}

2885 2886
static void intel_enable_ddi(struct intel_atomic_state *state,
			     struct intel_encoder *encoder,
2887 2888 2889
			     const struct intel_crtc_state *crtc_state,
			     const struct drm_connector_state *conn_state)
{
2890
	drm_WARN_ON(state->base.dev, crtc_state->has_pch_encoder);
2891

2892 2893
	if (!crtc_state->bigjoiner_slave)
		intel_ddi_enable_transcoder_func(encoder, crtc_state);
2894

2895 2896
	intel_vrr_enable(encoder, crtc_state);

2897 2898 2899 2900
	intel_enable_pipe(crtc_state);

	intel_crtc_vblank_on(crtc_state);

2901
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI))
2902
		intel_enable_ddi_hdmi(state, encoder, crtc_state, conn_state);
2903
	else
2904
		intel_enable_ddi_dp(state, encoder, crtc_state, conn_state);
2905 2906 2907 2908

	/* Enable hdcp if it's desired */
	if (conn_state->content_protection ==
	    DRM_MODE_CONTENT_PROTECTION_DESIRED)
2909
		intel_hdcp_enable(to_intel_connector(conn_state->connector),
2910
				  crtc_state,
2911
				  (u8)conn_state->hdcp_content_type);
2912 2913
}

2914 2915
static void intel_disable_ddi_dp(struct intel_atomic_state *state,
				 struct intel_encoder *encoder,
2916 2917
				 const struct intel_crtc_state *old_crtc_state,
				 const struct drm_connector_state *old_conn_state)
2918
{
2919
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2920

2921 2922
	intel_dp->link_trained = false;

2923
	if (old_crtc_state->has_audio)
2924 2925
		intel_audio_codec_disable(encoder,
					  old_crtc_state, old_conn_state);
2926

2927 2928 2929
	intel_edp_drrs_disable(intel_dp, old_crtc_state);
	intel_psr_disable(intel_dp, old_crtc_state);
	intel_edp_backlight_off(old_conn_state);
2930 2931 2932
	/* Disable the decompression in DP Sink */
	intel_dp_sink_set_decompression_state(intel_dp, old_crtc_state,
					      false);
2933 2934 2935
	/* Disable Ignore_MSA bit in DP Sink */
	intel_dp_sink_set_msa_timing_par_ignore_state(intel_dp, old_crtc_state,
						      false);
2936
}
S
Shashank Sharma 已提交
2937

2938 2939
static void intel_disable_ddi_hdmi(struct intel_atomic_state *state,
				   struct intel_encoder *encoder,
2940 2941 2942
				   const struct intel_crtc_state *old_crtc_state,
				   const struct drm_connector_state *old_conn_state)
{
2943
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
2944 2945
	struct drm_connector *connector = old_conn_state->connector;

2946
	if (old_crtc_state->has_audio)
2947 2948
		intel_audio_codec_disable(encoder,
					  old_crtc_state, old_conn_state);
2949

2950 2951
	if (!intel_hdmi_handle_sink_scrambling(encoder, connector,
					       false, false))
2952 2953 2954
		drm_dbg_kms(&i915->drm,
			    "[CONNECTOR:%d:%s] Failed to reset sink scrambling/TMDS bit clock ratio\n",
			    connector->base.id, connector->name);
2955 2956
}

2957 2958
static void intel_disable_ddi(struct intel_atomic_state *state,
			      struct intel_encoder *encoder,
2959 2960 2961
			      const struct intel_crtc_state *old_crtc_state,
			      const struct drm_connector_state *old_conn_state)
{
2962 2963
	intel_hdcp_disable(to_intel_connector(old_conn_state->connector));

2964
	if (intel_crtc_has_type(old_crtc_state, INTEL_OUTPUT_HDMI))
2965 2966
		intel_disable_ddi_hdmi(state, encoder, old_crtc_state,
				       old_conn_state);
2967
	else
2968 2969
		intel_disable_ddi_dp(state, encoder, old_crtc_state,
				     old_conn_state);
2970
}
P
Paulo Zanoni 已提交
2971

2972 2973
static void intel_ddi_update_pipe_dp(struct intel_atomic_state *state,
				     struct intel_encoder *encoder,
2974 2975 2976
				     const struct intel_crtc_state *crtc_state,
				     const struct drm_connector_state *conn_state)
{
2977
	struct intel_dp *intel_dp = enc_to_intel_dp(encoder);
2978

2979
	intel_ddi_set_dp_msa(crtc_state, conn_state);
2980

2981
	intel_psr_update(intel_dp, crtc_state, conn_state);
2982
	intel_dp_set_infoframes(encoder, true, crtc_state, conn_state);
2983
	intel_edp_drrs_update(intel_dp, crtc_state);
2984

2985
	intel_panel_update_backlight(state, encoder, crtc_state, conn_state);
2986 2987
}

2988 2989 2990 2991
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)
2992
{
2993

2994 2995
	if (!intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI) &&
	    !intel_encoder_is_mst(encoder))
2996 2997
		intel_ddi_update_pipe_dp(state, encoder, crtc_state,
					 conn_state);
2998

2999
	intel_hdcp_update_pipe(state, encoder, crtc_state, conn_state);
3000 3001
}

3002 3003 3004 3005 3006 3007 3008 3009 3010
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;

3011
	drm_WARN_ON(state->base.dev, crtc && crtc->active);
3012

3013 3014
	intel_tc_port_get_link(enc_to_dig_port(encoder),
		               required_lanes);
3015
	if (crtc_state && crtc_state->hw.active)
3016 3017 3018 3019 3020 3021 3022 3023
		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)
{
3024
	intel_tc_port_put_link(enc_to_dig_port(encoder));
3025 3026
}

I
Imre Deak 已提交
3027
static void
3028 3029
intel_ddi_pre_pll_enable(struct intel_atomic_state *state,
			 struct intel_encoder *encoder,
I
Imre Deak 已提交
3030 3031
			 const struct intel_crtc_state *crtc_state,
			 const struct drm_connector_state *conn_state)
3032
{
I
Imre Deak 已提交
3033
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3034
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
3035 3036
	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 已提交
3037

3038 3039 3040
	if (is_tc_port)
		intel_tc_port_get_link(dig_port, crtc_state->lane_count);

3041 3042 3043 3044 3045 3046
	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 已提交
3047

3048 3049 3050 3051 3052 3053 3054
	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 已提交
3055 3056 3057 3058
		bxt_ddi_phy_set_lane_optim_mask(encoder,
						crtc_state->lane_lat_optim_mask);
}

3059 3060
static void intel_ddi_prepare_link_retrain(struct intel_dp *intel_dp,
					   const struct intel_crtc_state *crtc_state)
3061
{
3062 3063 3064
	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;
3065
	u32 dp_tp_ctl, ddi_buf_ctl;
3066
	bool wait = false;
3067

3068
	dp_tp_ctl = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3069 3070

	if (dp_tp_ctl & DP_TP_CTL_ENABLE) {
3071
		ddi_buf_ctl = intel_de_read(dev_priv, DDI_BUF_CTL(port));
3072
		if (ddi_buf_ctl & DDI_BUF_CTL_ENABLE) {
3073 3074
			intel_de_write(dev_priv, DDI_BUF_CTL(port),
				       ddi_buf_ctl & ~DDI_BUF_CTL_ENABLE);
3075 3076 3077
			wait = true;
		}

3078 3079
		dp_tp_ctl &= ~(DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_MASK);
		dp_tp_ctl |= DP_TP_CTL_LINK_TRAIN_PAT1;
3080 3081
		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));
3082 3083 3084 3085 3086

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

3087
	dp_tp_ctl = DP_TP_CTL_ENABLE | DP_TP_CTL_LINK_TRAIN_PAT1;
3088
	if (intel_crtc_has_type(crtc_state, INTEL_OUTPUT_DP_MST)) {
3089
		dp_tp_ctl |= DP_TP_CTL_MODE_MST;
3090
	} else {
3091
		dp_tp_ctl |= DP_TP_CTL_MODE_SST;
3092
		if (drm_dp_enhanced_frame_cap(intel_dp->dpcd))
3093
			dp_tp_ctl |= DP_TP_CTL_ENHANCED_FRAME_ENABLE;
3094
	}
3095 3096
	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));
3097 3098

	intel_dp->DP |= DDI_BUF_CTL_ENABLE;
3099 3100
	intel_de_write(dev_priv, DDI_BUF_CTL(port), intel_dp->DP);
	intel_de_posting_read(dev_priv, DDI_BUF_CTL(port));
3101

3102
	intel_wait_ddi_buf_active(dev_priv, port);
3103
}
P
Paulo Zanoni 已提交
3104

3105
static void intel_ddi_set_link_train(struct intel_dp *intel_dp,
3106
				     const struct intel_crtc_state *crtc_state,
3107 3108
				     u8 dp_train_pat)
{
3109 3110
	struct intel_encoder *encoder = &dp_to_dig_port(intel_dp)->base;
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3111 3112
	u32 temp;

3113
	temp = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3114 3115

	temp &= ~DP_TP_CTL_LINK_TRAIN_MASK;
3116
	switch (intel_dp_training_pattern_symbol(dp_train_pat)) {
3117 3118 3119 3120 3121 3122 3123 3124 3125 3126 3127 3128 3129 3130 3131 3132 3133
	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;
	}

3134
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), temp);
3135 3136
}

3137 3138
static void intel_ddi_set_idle_link_train(struct intel_dp *intel_dp,
					  const struct intel_crtc_state *crtc_state)
3139 3140 3141 3142 3143 3144
{
	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;

3145
	val = intel_de_read(dev_priv, dp_tp_ctl_reg(encoder, crtc_state));
3146 3147
	val &= ~DP_TP_CTL_LINK_TRAIN_MASK;
	val |= DP_TP_CTL_LINK_TRAIN_IDLE;
3148
	intel_de_write(dev_priv, dp_tp_ctl_reg(encoder, crtc_state), val);
3149 3150 3151 3152 3153 3154 3155 3156 3157 3158 3159

	/*
	 * 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;

3160 3161
	if (intel_de_wait_for_set(dev_priv,
				  dp_tp_status_reg(encoder, crtc_state),
3162 3163 3164 3165 3166
				  DP_TP_STATUS_IDLE_DONE, 1))
		drm_err(&dev_priv->drm,
			"Timed out waiting for DP idle patterns\n");
}

3167 3168
static bool intel_ddi_is_audio_enabled(struct drm_i915_private *dev_priv,
				       enum transcoder cpu_transcoder)
3169
{
3170 3171
	if (cpu_transcoder == TRANSCODER_EDP)
		return false;
3172

3173 3174 3175
	if (!intel_display_power_is_enabled(dev_priv, POWER_DOMAIN_AUDIO))
		return false;

3176
	return intel_de_read(dev_priv, HSW_AUD_PIN_ELD_CP_VLD) &
3177
		AUDIO_OUTPUT_ENABLE(cpu_transcoder);
3178 3179
}

3180 3181 3182
void intel_ddi_compute_min_voltage_level(struct drm_i915_private *dev_priv,
					 struct intel_crtc_state *crtc_state)
{
3183 3184
	if (INTEL_GEN(dev_priv) >= 12 && crtc_state->port_clock > 594000)
		crtc_state->min_voltage_level = 2;
3185
	else if (IS_JSL_EHL(dev_priv) && crtc_state->port_clock > 594000)
3186 3187
		crtc_state->min_voltage_level = 3;
	else if (INTEL_GEN(dev_priv) >= 11 && crtc_state->port_clock > 594000)
3188
		crtc_state->min_voltage_level = 1;
3189 3190
	else if (IS_CANNONLAKE(dev_priv) && crtc_state->port_clock > 594000)
		crtc_state->min_voltage_level = 2;
3191 3192
}

3193 3194
static enum transcoder bdw_transcoder_master_readout(struct drm_i915_private *dev_priv,
						     enum transcoder cpu_transcoder)
3195
{
3196 3197 3198 3199
	u32 master_select;

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

3201 3202
		if ((ctl2 & PORT_SYNC_MODE_ENABLE) == 0)
			return INVALID_TRANSCODER;
3203

3204 3205 3206
		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));
3207

3208 3209 3210 3211 3212
		if ((ctl & TRANS_DDI_PORT_SYNC_ENABLE) == 0)
			return INVALID_TRANSCODER;

		master_select = REG_FIELD_GET(TRANS_DDI_PORT_SYNC_MASTER_SELECT_MASK, ctl);
	}
3213 3214 3215 3216 3217 3218 3219

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

3220
static void bdw_get_trans_port_sync_config(struct intel_crtc_state *crtc_state)
3221 3222 3223 3224 3225 3226 3227
{
	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 =
3228
		bdw_transcoder_master_readout(dev_priv, crtc_state->cpu_transcoder);
3229 3230 3231 3232 3233 3234 3235 3236 3237 3238 3239 3240

	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;

3241
		if (bdw_transcoder_master_readout(dev_priv, cpu_transcoder) ==
3242 3243 3244 3245 3246 3247 3248 3249 3250 3251 3252
		    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);
}

3253 3254
static void intel_ddi_read_func_ctl(struct intel_encoder *encoder,
				    struct intel_crtc_state *pipe_config)
3255
{
3256
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3257
	struct intel_crtc *intel_crtc = to_intel_crtc(pipe_config->uapi.crtc);
3258
	enum transcoder cpu_transcoder = pipe_config->cpu_transcoder;
3259
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
3260 3261
	u32 temp, flags = 0;

3262
	temp = intel_de_read(dev_priv, TRANS_DDI_FUNC_CTL(cpu_transcoder));
3263 3264 3265 3266 3267 3268 3269 3270 3271
	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;

3272
	pipe_config->hw.adjusted_mode.flags |= flags;
3273 3274 3275 3276 3277 3278 3279 3280 3281 3282 3283 3284 3285 3286 3287 3288 3289

	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;
	}
3290 3291 3292

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

3295 3296 3297 3298
		pipe_config->infoframes.enable |=
			intel_hdmi_infoframes_enabled(encoder, pipe_config);

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

3301
		if (temp & TRANS_DDI_HDMI_SCRAMBLING)
S
Shashank Sharma 已提交
3302 3303 3304
			pipe_config->hdmi_scrambling = true;
		if (temp & TRANS_DDI_HIGH_TMDS_CHAR_RATE)
			pipe_config->hdmi_high_tmds_clock_ratio = true;
3305
		fallthrough;
3306
	case TRANS_DDI_MODE_SELECT_DVI:
3307
		pipe_config->output_types |= BIT(INTEL_OUTPUT_HDMI);
3308 3309
		pipe_config->lane_count = 4;
		break;
3310
	case TRANS_DDI_MODE_SELECT_FDI:
3311
		pipe_config->output_types |= BIT(INTEL_OUTPUT_ANALOG);
3312 3313
		break;
	case TRANS_DDI_MODE_SELECT_DP_SST:
3314 3315 3316 3317 3318 3319 3320
		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);
3321 3322

		if (INTEL_GEN(dev_priv) >= 11) {
3323
			i915_reg_t dp_tp_ctl = dp_tp_ctl_reg(encoder, pipe_config);
3324 3325

			pipe_config->fec_enable =
3326
				intel_de_read(dev_priv, dp_tp_ctl) & DP_TP_CTL_FEC_ENABLE;
3327

3328 3329 3330 3331
			drm_dbg_kms(&dev_priv->drm,
				    "[ENCODER:%d:%s] Fec status: %u\n",
				    encoder->base.base.id, encoder->base.name,
				    pipe_config->fec_enable);
3332 3333
		}

3334 3335 3336 3337 3338 3339
		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);
3340
		break;
3341
	case TRANS_DDI_MODE_SELECT_DP_MST:
3342
		pipe_config->output_types |= BIT(INTEL_OUTPUT_DP_MST);
3343 3344
		pipe_config->lane_count =
			((temp & DDI_PORT_WIDTH_MASK) >> DDI_PORT_WIDTH_SHIFT) + 1;
3345 3346 3347 3348 3349

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

3350
		intel_dp_get_m_n(intel_crtc, pipe_config);
3351 3352 3353

		pipe_config->infoframes.enable |=
			intel_hdmi_infoframes_enabled(encoder, pipe_config);
3354 3355 3356 3357
		break;
	default:
		break;
	}
3358 3359 3360 3361 3362 3363 3364 3365 3366 3367 3368 3369 3370 3371 3372 3373 3374 3375 3376 3377 3378 3379 3380 3381
}

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);
	}
3382

3383
	pipe_config->has_audio =
3384
		intel_ddi_is_audio_enabled(dev_priv, cpu_transcoder);
3385

3386 3387
	if (encoder->type == INTEL_OUTPUT_EDP && dev_priv->vbt.edp.bpp &&
	    pipe_config->pipe_bpp > dev_priv->vbt.edp.bpp) {
3388 3389 3390 3391 3392 3393 3394 3395 3396 3397 3398 3399 3400
		/*
		 * 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.
		 */
3401 3402 3403
		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);
3404
		dev_priv->vbt.edp.bpp = pipe_config->pipe_bpp;
3405
	}
3406

3407 3408
	if (!pipe_config->bigjoiner_slave)
		intel_ddi_clock_get(encoder, pipe_config);
3409

3410
	if (IS_GEN9_LP(dev_priv))
3411 3412
		pipe_config->lane_lat_optim_mask =
			bxt_ddi_phy_get_lane_lat_optim_mask(encoder);
3413 3414

	intel_ddi_compute_min_voltage_level(dev_priv, pipe_config);
3415 3416 3417 3418 3419 3420 3421 3422 3423 3424 3425 3426

	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);
3427 3428 3429
	intel_read_infoframe(encoder, pipe_config,
			     HDMI_INFOFRAME_TYPE_DRM,
			     &pipe_config->infoframes.drm);
3430

3431 3432
	if (INTEL_GEN(dev_priv) >= 8)
		bdw_get_trans_port_sync_config(pipe_config);
3433 3434

	intel_read_dp_sdp(encoder, pipe_config, HDMI_PACKET_TYPE_GAMUT_METADATA);
3435
	intel_read_dp_sdp(encoder, pipe_config, DP_SDP_VSC);
3436 3437
}

3438 3439 3440 3441 3442 3443 3444
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);
}

3445 3446 3447 3448 3449 3450 3451 3452 3453
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;
}

3454 3455 3456 3457 3458 3459 3460 3461 3462 3463 3464 3465 3466 3467 3468 3469 3470 3471
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;
	}
}

3472 3473 3474
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 已提交
3475
{
3476
	struct intel_crtc *crtc = to_intel_crtc(pipe_config->uapi.crtc);
3477
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3478
	enum port port = encoder->port;
3479
	int ret;
P
Paulo Zanoni 已提交
3480

3481
	if (HAS_TRANSCODER(dev_priv, TRANSCODER_EDP) && port == PORT_A)
3482 3483
		pipe_config->cpu_transcoder = TRANSCODER_EDP;

3484
	if (intel_crtc_has_type(pipe_config, INTEL_OUTPUT_HDMI)) {
3485
		ret = intel_hdmi_compute_config(encoder, pipe_config, conn_state);
3486
	} else {
3487
		ret = intel_dp_compute_config(encoder, pipe_config, conn_state);
3488 3489
	}

3490 3491
	if (ret)
		return ret;
3492

3493 3494 3495 3496 3497 3498
	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;

3499
	if (IS_GEN9_LP(dev_priv))
3500
		pipe_config->lane_lat_optim_mask =
3501
			bxt_ddi_phy_calc_lane_lat_optim_mask(pipe_config->lane_count);
3502

3503 3504
	intel_ddi_compute_min_voltage_level(dev_priv, pipe_config);

3505
	return 0;
P
Paulo Zanoni 已提交
3506 3507
}

3508 3509 3510 3511 3512 3513 3514 3515 3516 3517 3518 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
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;

3553 3554 3555 3556 3557
	/*
	 * 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)
3558 3559 3560 3561 3562 3563 3564 3565 3566 3567 3568 3569 3570 3571 3572 3573 3574 3575 3576 3577 3578 3579 3580 3581 3582 3583 3584 3585 3586 3587 3588
		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)
{
3589
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
3590 3591 3592
	struct drm_connector *connector = conn_state->connector;
	u8 port_sync_transcoders = 0;

3593 3594 3595
	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);
3596 3597 3598 3599 3600 3601 3602 3603 3604 3605 3606 3607 3608 3609 3610 3611 3612 3613 3614 3615 3616 3617 3618

	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;
}

3619 3620
static void intel_ddi_encoder_destroy(struct drm_encoder *encoder)
{
3621
	struct intel_digital_port *dig_port = enc_to_dig_port(to_intel_encoder(encoder));
3622 3623 3624 3625

	intel_dp_encoder_flush_work(encoder);

	drm_encoder_cleanup(encoder);
3626 3627
	if (dig_port)
		kfree(dig_port->hdcp_port_data.streams);
3628 3629 3630
	kfree(dig_port);
}

P
Paulo Zanoni 已提交
3631
static const struct drm_encoder_funcs intel_ddi_funcs = {
3632
	.reset = intel_dp_encoder_reset,
3633
	.destroy = intel_ddi_encoder_destroy,
P
Paulo Zanoni 已提交
3634 3635
};

3636
static struct intel_connector *
3637
intel_ddi_init_dp_connector(struct intel_digital_port *dig_port)
3638
{
3639
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
3640
	struct intel_connector *connector;
3641
	enum port port = dig_port->base.port;
3642

3643
	connector = intel_connector_alloc();
3644 3645 3646
	if (!connector)
		return NULL;

3647 3648 3649 3650
	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;
3651

3652
	if (INTEL_GEN(dev_priv) >= 12)
3653
		dig_port->dp.set_signal_levels = tgl_set_signal_levels;
3654
	else if (INTEL_GEN(dev_priv) >= 11)
3655
		dig_port->dp.set_signal_levels = icl_set_signal_levels;
3656
	else if (IS_CANNONLAKE(dev_priv))
3657
		dig_port->dp.set_signal_levels = cnl_set_signal_levels;
3658
	else if (IS_GEN9_LP(dev_priv))
3659
		dig_port->dp.set_signal_levels = bxt_set_signal_levels;
3660
	else
3661
		dig_port->dp.set_signal_levels = hsw_set_signal_levels;
3662

3663 3664
	dig_port->dp.voltage_max = intel_ddi_dp_voltage_max;
	dig_port->dp.preemph_max = intel_ddi_dp_preemph_max;
3665

3666
	if (!intel_dp_init_connector(dig_port, connector)) {
3667 3668 3669 3670 3671 3672 3673
		kfree(connector);
		return NULL;
	}

	return connector;
}

3674 3675 3676 3677 3678 3679 3680 3681 3682 3683 3684 3685 3686 3687 3688 3689 3690 3691 3692
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;
	}

3693
	crtc_state->connectors_changed = true;
3694 3695

	ret = drm_atomic_commit(state);
3696
out:
3697 3698 3699 3700 3701 3702 3703 3704 3705
	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);
3706
	struct intel_hdmi *hdmi = enc_to_intel_hdmi(encoder);
3707 3708 3709 3710 3711 3712 3713 3714 3715 3716 3717 3718 3719 3720 3721 3722 3723 3724 3725 3726 3727 3728 3729 3730 3731 3732 3733 3734 3735
	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);

3736 3737
	drm_WARN_ON(&dev_priv->drm,
		    !intel_crtc_has_type(crtc_state, INTEL_OUTPUT_HDMI));
3738

3739
	if (!crtc_state->hw.active)
3740 3741 3742 3743 3744 3745 3746 3747 3748 3749 3750 3751
		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) {
3752 3753
		drm_err(&dev_priv->drm, "Failed to read TMDS config: %d\n",
			ret);
3754 3755 3756 3757 3758 3759 3760 3761 3762 3763 3764 3765 3766 3767 3768 3769 3770 3771 3772 3773 3774
		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);
}

3775 3776
static enum intel_hotplug_state
intel_ddi_hotplug(struct intel_encoder *encoder,
3777
		  struct intel_connector *connector)
3778
{
3779
	struct drm_i915_private *i915 = to_i915(encoder->base.dev);
3780
	struct intel_digital_port *dig_port = enc_to_dig_port(encoder);
3781
	struct intel_dp *intel_dp = &dig_port->dp;
3782 3783
	enum phy phy = intel_port_to_phy(i915, encoder->port);
	bool is_tc = intel_phy_is_tc(i915, phy);
3784
	struct drm_modeset_acquire_ctx ctx;
3785
	enum intel_hotplug_state state;
3786 3787
	int ret;

3788 3789 3790 3791 3792 3793 3794
	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;
	}

3795
	state = intel_encoder_hotplug(encoder, connector);
3796 3797 3798 3799

	drm_modeset_acquire_init(&ctx, 0);

	for (;;) {
3800 3801 3802 3803
		if (connector->base.connector_type == DRM_MODE_CONNECTOR_HDMIA)
			ret = intel_hdmi_reset_link(encoder, &ctx);
		else
			ret = intel_dp_retrain_link(encoder, &ctx);
3804 3805 3806 3807 3808 3809 3810 3811 3812 3813 3814

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

		break;
	}

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

3818 3819 3820 3821 3822 3823 3824 3825 3826 3827 3828 3829 3830 3831 3832
	/*
	 * 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.
3833 3834 3835 3836 3837 3838
	 *
	 * 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.
3839
	 */
3840 3841
	if (state == INTEL_HOTPLUG_UNCHANGED &&
	    connector->hotplug_retries < (is_tc ? 5 : 1) &&
3842 3843 3844
	    !dig_port->dp.is_mst)
		state = INTEL_HOTPLUG_RETRY;

3845
	return state;
3846 3847
}

3848 3849 3850
static bool lpt_digital_port_connected(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3851
	u32 bit = dev_priv->hotplug.pch_hpd[encoder->hpd_pin];
3852 3853 3854 3855 3856 3857 3858

	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);
3859
	u32 bit = dev_priv->hotplug.hpd[encoder->hpd_pin];
3860

3861
	return intel_de_read(dev_priv, DEISR) & bit;
3862 3863 3864 3865 3866
}

static bool bdw_digital_port_connected(struct intel_encoder *encoder)
{
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
3867
	u32 bit = dev_priv->hotplug.hpd[encoder->hpd_pin];
3868 3869 3870 3871

	return intel_de_read(dev_priv, GEN8_DE_PORT_ISR) & bit;
}

3872
static struct intel_connector *
3873
intel_ddi_init_hdmi_connector(struct intel_digital_port *dig_port)
3874 3875
{
	struct intel_connector *connector;
3876
	enum port port = dig_port->base.port;
3877

3878
	connector = intel_connector_alloc();
3879 3880 3881
	if (!connector)
		return NULL;

3882 3883
	dig_port->hdmi.hdmi_reg = DDI_BUF_CTL(port);
	intel_hdmi_init_connector(dig_port, connector);
3884 3885 3886 3887

	return connector;
}

3888
static bool intel_ddi_a_force_4_lanes(struct intel_digital_port *dig_port)
3889
{
3890
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
3891

3892
	if (dig_port->base.port != PORT_A)
3893 3894
		return false;

3895
	if (dig_port->saved_port_bits & DDI_A_4_LANES)
3896 3897 3898 3899 3900 3901 3902 3903 3904 3905 3906 3907 3908 3909 3910 3911 3912 3913 3914 3915
		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;
}

3916
static int
3917
intel_ddi_max_lanes(struct intel_digital_port *dig_port)
3918
{
3919 3920
	struct drm_i915_private *dev_priv = to_i915(dig_port->base.base.dev);
	enum port port = dig_port->base.port;
3921 3922 3923 3924 3925 3926
	int max_lanes = 4;

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

	if (port == PORT_A || port == PORT_E) {
3927
		if (intel_de_read(dev_priv, DDI_BUF_CTL(PORT_A)) & DDI_A_4_LANES)
3928 3929 3930 3931 3932 3933 3934 3935 3936 3937 3938
			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.
	 */
3939
	if (intel_ddi_a_force_4_lanes(dig_port)) {
3940 3941
		drm_dbg_kms(&dev_priv->drm,
			    "Forcing DDI_A_4_LANES for port A\n");
3942
		dig_port->saved_port_bits |= DDI_A_4_LANES;
3943 3944 3945 3946 3947 3948
		max_lanes = 4;
	}

	return max_lanes;
}

M
Matt Roper 已提交
3949 3950 3951
static bool hti_uses_phy(struct drm_i915_private *i915, enum phy phy)
{
	return i915->hti_state & HDPORT_ENABLED &&
3952
	       i915->hti_state & HDPORT_DDI_USED(phy);
M
Matt Roper 已提交
3953 3954
}

3955 3956 3957
static enum hpd_pin dg1_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
3958 3959
	if (port >= PORT_TC1)
		return HPD_PORT_C + port - PORT_TC1;
3960 3961 3962 3963
	else
		return HPD_PORT_A + port - PORT_A;
}

3964 3965 3966
static enum hpd_pin tgl_hpd_pin(struct drm_i915_private *dev_priv,
				enum port port)
{
3967 3968
	if (port >= PORT_TC1)
		return HPD_PORT_TC1 + port - PORT_TC1;
3969 3970 3971 3972 3973 3974 3975 3976 3977 3978
	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);

3979 3980
	if (port >= PORT_TC1)
		return HPD_PORT_C + port - PORT_TC1;
3981 3982 3983 3984 3985 3986 3987 3988 3989 3990 3991 3992 3993 3994 3995 3996 3997 3998 3999 4000 4001 4002 4003 4004 4005 4006 4007 4008 4009 4010 4011 4012 4013 4014
	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;
}

4015 4016 4017 4018 4019 4020 4021 4022
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;
}

4023 4024 4025 4026 4027 4028 4029 4030 4031 4032
static bool intel_ddi_is_tc(struct drm_i915_private *i915, enum port port)
{
	if (INTEL_GEN(i915) >= 12)
		return port >= PORT_TC1;
	else if (INTEL_GEN(i915) >= 11)
		return port >= PORT_C;
	else
		return false;
}

4033 4034 4035
#define port_tc_name(port) ((port) - PORT_TC1 + '1')
#define tc_port_name(tc_port) ((tc_port) - TC_PORT_1 + '1')

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

M
Matt Roper 已提交
4043 4044 4045 4046 4047 4048 4049 4050 4051 4052 4053 4054
	/*
	 * 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;
	}

4055 4056 4057
	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);
4058 4059 4060 4061 4062 4063 4064 4065 4066

	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;
4067 4068
		drm_dbg_kms(&dev_priv->drm, "VBT says port %c has lspcon\n",
			    port_name(port));
4069 4070
	}

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

4078 4079
	dig_port = kzalloc(sizeof(*dig_port), GFP_KERNEL);
	if (!dig_port)
P
Paulo Zanoni 已提交
4080 4081
		return;

4082
	encoder = &dig_port->base;
P
Paulo Zanoni 已提交
4083

4084 4085 4086 4087 4088 4089 4090
	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" : "",
4091
				 port >= PORT_TC1 ? port_tc_name(port) : port_name(port),
4092
				 tc_port != TC_PORT_NONE ? "TC" : "",
4093
				 tc_port != TC_PORT_NONE ? tc_port_name(tc_port) : phy_name(phy));
4094 4095 4096 4097 4098 4099 4100 4101 4102
	} 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" : "",
4103
				 tc_port != TC_PORT_NONE ? tc_port_name(tc_port) : phy_name(phy));
4104 4105 4106 4107 4108
	} 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 已提交
4109

4110 4111 4112
	mutex_init(&dig_port->hdcp_mutex);
	dig_port->num_hdcp_streams = 0;

4113 4114 4115
	encoder->hotplug = intel_ddi_hotplug;
	encoder->compute_output_type = intel_ddi_compute_output_type;
	encoder->compute_config = intel_ddi_compute_config;
4116
	encoder->compute_config_late = intel_ddi_compute_config_late;
4117 4118 4119 4120 4121 4122 4123 4124
	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;
4125
	encoder->sync_state = intel_ddi_sync_state;
4126
	encoder->initial_fastset_check = intel_ddi_initial_fastset_check;
4127
	encoder->suspend = intel_dp_encoder_suspend;
4128
	encoder->shutdown = intel_dp_encoder_shutdown;
4129 4130 4131 4132 4133 4134 4135
	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;
4136

4137 4138 4139 4140
	if (IS_ALDERLAKE_S(dev_priv) || IS_ROCKETLAKE(dev_priv)) {
		encoder->enable_clock = icl_ddi_combo_enable_clock;
		encoder->disable_clock = icl_ddi_combo_disable_clock;
	} else if (IS_DG1(dev_priv)) {
4141 4142
		encoder->enable_clock = dg1_ddi_enable_clock;
		encoder->disable_clock = dg1_ddi_disable_clock;
4143 4144 4145 4146 4147 4148 4149 4150 4151 4152 4153 4154 4155 4156 4157 4158
	} else if (IS_JSL_EHL(dev_priv)) {
		if (intel_ddi_is_tc(dev_priv, port)) {
			encoder->enable_clock = jsl_ddi_tc_enable_clock;
			encoder->disable_clock = jsl_ddi_tc_disable_clock;
		} else {
			encoder->enable_clock = icl_ddi_combo_enable_clock;
			encoder->disable_clock = icl_ddi_combo_disable_clock;
		}
	} else if (INTEL_GEN(dev_priv) >= 11) {
		if (intel_ddi_is_tc(dev_priv, port)) {
			encoder->enable_clock = icl_ddi_tc_enable_clock;
			encoder->disable_clock = icl_ddi_tc_disable_clock;
		} else {
			encoder->enable_clock = icl_ddi_combo_enable_clock;
			encoder->disable_clock = icl_ddi_combo_disable_clock;
		}
4159
	} else if (IS_CANNONLAKE(dev_priv)) {
4160 4161 4162
		encoder->enable_clock = cnl_ddi_enable_clock;
		encoder->disable_clock = cnl_ddi_disable_clock;
	} else if (IS_GEN9_BC(dev_priv)) {
4163 4164 4165
		encoder->enable_clock = skl_ddi_enable_clock;
		encoder->disable_clock = skl_ddi_disable_clock;
	} else if (IS_BROADWELL(dev_priv) || IS_HASWELL(dev_priv)) {
4166 4167 4168 4169
		encoder->enable_clock = hsw_ddi_enable_clock;
		encoder->disable_clock = hsw_ddi_disable_clock;
	}

4170 4171 4172
	if (IS_DG1(dev_priv))
		encoder->hpd_pin = dg1_hpd_pin(dev_priv, port);
	else if (IS_ROCKETLAKE(dev_priv))
4173 4174 4175
		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);
4176
	else if (IS_JSL_EHL(dev_priv))
4177 4178 4179 4180 4181
		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);
4182 4183
	else if (IS_GEN(dev_priv, 9))
		encoder->hpd_pin = skl_hpd_pin(dev_priv, port);
4184 4185
	else
		encoder->hpd_pin = intel_hpd_pin_default(dev_priv, port);
P
Paulo Zanoni 已提交
4186

4187
	if (INTEL_GEN(dev_priv) >= 11)
4188 4189 4190
		dig_port->saved_port_bits =
			intel_de_read(dev_priv, DDI_BUF_CTL(port))
			& DDI_BUF_PORT_REVERSAL;
4191
	else
4192 4193 4194
		dig_port->saved_port_bits =
			intel_de_read(dev_priv, DDI_BUF_CTL(port))
			& (DDI_BUF_PORT_REVERSAL | DDI_A_4_LANES);
4195

4196 4197 4198
	if (intel_bios_is_lane_reversal_needed(dev_priv, port))
		dig_port->saved_port_bits |= DDI_BUF_PORT_REVERSAL;

4199 4200 4201
	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 已提交
4202

4203
	if (intel_phy_is_tc(dev_priv, phy)) {
4204 4205 4206
		bool is_legacy =
			!intel_bios_port_supports_typec_usb(dev_priv, port) &&
			!intel_bios_port_supports_tbt(dev_priv, port);
4207

4208
		intel_tc_port_init(dig_port, is_legacy);
4209

4210 4211
		encoder->update_prepare = intel_ddi_update_prepare;
		encoder->update_complete = intel_ddi_update_complete;
4212
	}
4213

4214
	drm_WARN_ON(&dev_priv->drm, port > PORT_I);
4215
	dig_port->ddi_io_power_domain = POWER_DOMAIN_PORT_DDI_A_IO +
4216
					      port - PORT_A;
4217

4218
	if (init_dp) {
4219
		if (!intel_ddi_init_dp_connector(dig_port))
4220
			goto err;
4221

4222
		dig_port->hpd_pulse = intel_dp_hpd_pulse;
4223
	}
4224

4225 4226
	/* In theory we don't need the encoder->type check, but leave it just in
	 * case we have some really bad VBTs... */
4227
	if (encoder->type != INTEL_OUTPUT_EDP && init_hdmi) {
4228
		if (!intel_ddi_init_hdmi_connector(dig_port))
4229
			goto err;
4230
	}
4231

4232 4233
	if (INTEL_GEN(dev_priv) >= 11) {
		if (intel_phy_is_tc(dev_priv, phy))
4234
			dig_port->connected = intel_tc_port_connected;
4235
		else
4236
			dig_port->connected = lpt_digital_port_connected;
4237 4238
	} else if (INTEL_GEN(dev_priv) >= 8) {
		if (port == PORT_A || IS_GEN9_LP(dev_priv))
4239
			dig_port->connected = bdw_digital_port_connected;
4240
		else
4241
			dig_port->connected = lpt_digital_port_connected;
4242
	} else {
4243
		if (port == PORT_A)
4244
			dig_port->connected = hsw_digital_port_connected;
4245
		else
4246
			dig_port->connected = lpt_digital_port_connected;
4247 4248
	}

4249
	intel_infoframe_init(dig_port);
4250

4251 4252 4253
	return;

err:
4254
	drm_encoder_cleanup(&encoder->base);
4255
	kfree(dig_port);
P
Paulo Zanoni 已提交
4256
}