intel_audio.c 25.3 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
/*
 * Copyright © 2014 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.
 */

#include <linux/kernel.h>
I
Imre Deak 已提交
25 26 27
#include <linux/component.h>
#include <drm/i915_component.h>
#include "intel_drv.h"
28 29 30 31 32

#include <drm/drmP.h>
#include <drm/drm_edid.h>
#include "i915_drv.h"

33 34 35 36 37 38 39 40 41 42 43
/**
 * DOC: High Definition Audio over HDMI and Display Port
 *
 * The graphics and audio drivers together support High Definition Audio over
 * HDMI and Display Port. The audio programming sequences are divided into audio
 * codec and controller enable and disable sequences. The graphics driver
 * handles the audio codec sequences, while the audio driver handles the audio
 * controller sequences.
 *
 * The disable sequences must be performed before disabling the transcoder or
 * port. The enable sequences may only be performed after enabling the
44 45
 * transcoder and port, and after completed link training. Therefore the audio
 * enable/disable sequences are part of the modeset sequence.
46 47 48 49 50 51 52
 *
 * The codec and controller sequences could be done either parallel or serial,
 * but generally the ELDV/PD change in the codec sequence indicates to the audio
 * driver that the controller sequence should start. Indeed, most of the
 * co-operation between the graphics and audio drivers is handled via audio
 * related registers. (The notable exception is the power management, not
 * covered here.)
53 54 55 56 57
 *
 * The struct i915_audio_component is used to interact between the graphics
 * and audio drivers. The struct i915_audio_component_ops *ops in it is
 * defined in graphics driver and called in audio driver. The
 * struct i915_audio_component_audio_ops *audio_ops is called from i915 driver.
58 59
 */

60
static const struct {
61 62 63
	int clock;
	u32 config;
} hdmi_audio_clock[] = {
64
	{ 25175, AUD_CONFIG_PIXEL_CLOCK_HDMI_25175 },
65 66
	{ 25200, AUD_CONFIG_PIXEL_CLOCK_HDMI_25200 }, /* default per bspec */
	{ 27000, AUD_CONFIG_PIXEL_CLOCK_HDMI_27000 },
67
	{ 27027, AUD_CONFIG_PIXEL_CLOCK_HDMI_27027 },
68
	{ 54000, AUD_CONFIG_PIXEL_CLOCK_HDMI_54000 },
69 70
	{ 54054, AUD_CONFIG_PIXEL_CLOCK_HDMI_54054 },
	{ 74176, AUD_CONFIG_PIXEL_CLOCK_HDMI_74176 },
71
	{ 74250, AUD_CONFIG_PIXEL_CLOCK_HDMI_74250 },
72
	{ 148352, AUD_CONFIG_PIXEL_CLOCK_HDMI_148352 },
73 74 75
	{ 148500, AUD_CONFIG_PIXEL_CLOCK_HDMI_148500 },
};

76 77
/* HDMI N/CTS table */
#define TMDS_297M 297000
78
#define TMDS_296M 296703
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
static const struct {
	int sample_rate;
	int clock;
	int n;
	int cts;
} aud_ncts[] = {
	{ 44100, TMDS_296M, 4459, 234375 },
	{ 44100, TMDS_297M, 4704, 247500 },
	{ 48000, TMDS_296M, 5824, 281250 },
	{ 48000, TMDS_297M, 5120, 247500 },
	{ 32000, TMDS_296M, 5824, 421875 },
	{ 32000, TMDS_297M, 3072, 222750 },
	{ 88200, TMDS_296M, 8918, 234375 },
	{ 88200, TMDS_297M, 9408, 247500 },
	{ 96000, TMDS_296M, 11648, 281250 },
	{ 96000, TMDS_297M, 10240, 247500 },
	{ 176400, TMDS_296M, 17836, 234375 },
	{ 176400, TMDS_297M, 18816, 247500 },
	{ 192000, TMDS_296M, 23296, 281250 },
	{ 192000, TMDS_297M, 20480, 247500 },
};

101
/* get AUD_CONFIG_PIXEL_CLOCK_HDMI_* value for mode */
102
static u32 audio_config_hdmi_pixel_clock(const struct drm_display_mode *adjusted_mode)
103 104 105 106
{
	int i;

	for (i = 0; i < ARRAY_SIZE(hdmi_audio_clock); i++) {
107
		if (adjusted_mode->crtc_clock == hdmi_audio_clock[i].clock)
108 109 110 111
			break;
	}

	if (i == ARRAY_SIZE(hdmi_audio_clock)) {
112
		DRM_DEBUG_KMS("HDMI audio pixel clock setting for %d not found, falling back to defaults\n",
113
			      adjusted_mode->crtc_clock);
114 115 116 117 118 119 120 121 122 123
		i = 1;
	}

	DRM_DEBUG_KMS("Configuring HDMI audio for pixel clock %d (0x%08x)\n",
		      hdmi_audio_clock[i].clock,
		      hdmi_audio_clock[i].config);

	return hdmi_audio_clock[i].config;
}

124 125 126 127 128 129 130 131 132 133 134 135 136
static int audio_config_get_n(const struct drm_display_mode *mode, int rate)
{
	int i;

	for (i = 0; i < ARRAY_SIZE(aud_ncts); i++) {
		if ((rate == aud_ncts[i].sample_rate) &&
			(mode->clock == aud_ncts[i].clock)) {
			return aud_ncts[i].n;
		}
	}
	return 0;
}

137 138 139 140 141 142 143 144 145 146 147 148 149 150
static uint32_t audio_config_setup_n_reg(int n, uint32_t val)
{
	int n_low, n_up;
	uint32_t tmp = val;

	n_low = n & 0xfff;
	n_up = (n >> 12) & 0xff;
	tmp &= ~(AUD_CONFIG_UPPER_N_MASK | AUD_CONFIG_LOWER_N_MASK);
	tmp |= ((n_up << AUD_CONFIG_UPPER_N_SHIFT) |
			(n_low << AUD_CONFIG_LOWER_N_SHIFT) |
			AUD_CONFIG_N_PROG_ENABLE);
	return tmp;
}

151 152
/* check whether N/CTS/M need be set manually */
static bool audio_rate_need_prog(struct intel_crtc *crtc,
153
				 const struct drm_display_mode *mode)
154 155 156
{
	if (((mode->clock == TMDS_297M) ||
		 (mode->clock == TMDS_296M)) &&
157
		intel_crtc_has_type(crtc->config, INTEL_OUTPUT_HDMI))
158 159 160 161 162
		return true;
	else
		return false;
}

163
static bool intel_eld_uptodate(struct drm_connector *connector,
164 165 166
			       i915_reg_t reg_eldv, uint32_t bits_eldv,
			       i915_reg_t reg_elda, uint32_t bits_elda,
			       i915_reg_t reg_edid)
167
{
168
	struct drm_i915_private *dev_priv = to_i915(connector->dev);
169
	uint8_t *eld = connector->eld;
170 171
	uint32_t tmp;
	int i;
172

173 174
	tmp = I915_READ(reg_eldv);
	tmp &= bits_eldv;
175

176
	if (!tmp)
177 178
		return false;

179 180 181
	tmp = I915_READ(reg_elda);
	tmp &= ~bits_elda;
	I915_WRITE(reg_elda, tmp);
182

183
	for (i = 0; i < drm_eld_size(eld) / 4; i++)
184 185 186 187 188 189
		if (I915_READ(reg_edid) != *((uint32_t *)eld + i))
			return false;

	return true;
}

190 191
static void g4x_audio_codec_disable(struct intel_encoder *encoder)
{
192
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208
	uint32_t eldv, tmp;

	DRM_DEBUG_KMS("Disable audio codec\n");

	tmp = I915_READ(G4X_AUD_VID_DID);
	if (tmp == INTEL_AUDIO_DEVBLC || tmp == INTEL_AUDIO_DEVCL)
		eldv = G4X_ELDV_DEVCL_DEVBLC;
	else
		eldv = G4X_ELDV_DEVCTG;

	/* Invalidate ELD */
	tmp = I915_READ(G4X_AUD_CNTL_ST);
	tmp &= ~eldv;
	I915_WRITE(G4X_AUD_CNTL_ST, tmp);
}

209 210
static void g4x_audio_codec_enable(struct drm_connector *connector,
				   struct intel_encoder *encoder,
211
				   const struct drm_display_mode *adjusted_mode)
212
{
213
	struct drm_i915_private *dev_priv = to_i915(connector->dev);
214 215
	uint8_t *eld = connector->eld;
	uint32_t eldv;
216 217
	uint32_t tmp;
	int len, i;
218

219 220
	DRM_DEBUG_KMS("Enable audio codec, %u bytes ELD\n", eld[2]);

221 222
	tmp = I915_READ(G4X_AUD_VID_DID);
	if (tmp == INTEL_AUDIO_DEVBLC || tmp == INTEL_AUDIO_DEVCL)
223 224 225 226 227 228
		eldv = G4X_ELDV_DEVCL_DEVBLC;
	else
		eldv = G4X_ELDV_DEVCTG;

	if (intel_eld_uptodate(connector,
			       G4X_AUD_CNTL_ST, eldv,
229
			       G4X_AUD_CNTL_ST, G4X_ELD_ADDR_MASK,
230 231 232
			       G4X_HDMIW_HDMIEDID))
		return;

233
	tmp = I915_READ(G4X_AUD_CNTL_ST);
234
	tmp &= ~(eldv | G4X_ELD_ADDR_MASK);
235 236
	len = (tmp >> 9) & 0x1f;		/* ELD buffer size */
	I915_WRITE(G4X_AUD_CNTL_ST, tmp);
237

238
	len = min(drm_eld_size(eld) / 4, len);
239 240 241 242
	DRM_DEBUG_DRIVER("ELD size %d\n", len);
	for (i = 0; i < len; i++)
		I915_WRITE(G4X_HDMIW_HDMIEDID, *((uint32_t *)eld + i));

243 244 245
	tmp = I915_READ(G4X_AUD_CNTL_ST);
	tmp |= eldv;
	I915_WRITE(G4X_AUD_CNTL_ST, tmp);
246 247
}

248 249
static void hsw_audio_codec_disable(struct intel_encoder *encoder)
{
250
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
251 252
	struct intel_crtc *intel_crtc = to_intel_crtc(encoder->base.crtc);
	enum pipe pipe = intel_crtc->pipe;
253 254
	uint32_t tmp;

255 256
	DRM_DEBUG_KMS("Disable audio codec on pipe %c\n", pipe_name(pipe));

257 258
	mutex_lock(&dev_priv->av_mutex);

259 260 261 262 263 264
	/* Disable timestamps */
	tmp = I915_READ(HSW_AUD_CFG(pipe));
	tmp &= ~AUD_CONFIG_N_VALUE_INDEX;
	tmp |= AUD_CONFIG_N_PROG_ENABLE;
	tmp &= ~AUD_CONFIG_UPPER_N_MASK;
	tmp &= ~AUD_CONFIG_LOWER_N_MASK;
265
	if (intel_crtc_has_dp_encoder(intel_crtc->config))
266 267 268 269
		tmp |= AUD_CONFIG_N_VALUE_INDEX;
	I915_WRITE(HSW_AUD_CFG(pipe), tmp);

	/* Invalidate ELD */
270
	tmp = I915_READ(HSW_AUD_PIN_ELD_CP_VLD);
271
	tmp &= ~AUDIO_ELD_VALID(pipe);
272
	tmp &= ~AUDIO_OUTPUT_ENABLE(pipe);
273
	I915_WRITE(HSW_AUD_PIN_ELD_CP_VLD, tmp);
274 275

	mutex_unlock(&dev_priv->av_mutex);
276 277 278 279
}

static void hsw_audio_codec_enable(struct drm_connector *connector,
				   struct intel_encoder *encoder,
280
				   const struct drm_display_mode *adjusted_mode)
281
{
282
	struct drm_i915_private *dev_priv = to_i915(connector->dev);
283
	struct intel_crtc *intel_crtc = to_intel_crtc(encoder->base.crtc);
284
	enum pipe pipe = intel_crtc->pipe;
285
	struct i915_audio_component *acomp = dev_priv->audio_component;
286
	const uint8_t *eld = connector->eld;
287 288 289
	struct intel_digital_port *intel_dig_port =
		enc_to_dig_port(&encoder->base);
	enum port port = intel_dig_port->port;
290 291
	uint32_t tmp;
	int len, i;
292
	int n, rate;
293

294
	DRM_DEBUG_KMS("Enable audio codec on pipe %c, %u bytes ELD\n",
295
		      pipe_name(pipe), drm_eld_size(eld));
296

297 298
	mutex_lock(&dev_priv->av_mutex);

299 300
	/* Enable audio presence detect, invalidate ELD */
	tmp = I915_READ(HSW_AUD_PIN_ELD_CP_VLD);
301 302
	tmp |= AUDIO_OUTPUT_ENABLE(pipe);
	tmp &= ~AUDIO_ELD_VALID(pipe);
303
	I915_WRITE(HSW_AUD_PIN_ELD_CP_VLD, tmp);
304

305 306 307 308 309 310
	/*
	 * FIXME: We're supposed to wait for vblank here, but we have vblanks
	 * disabled during the mode set. The proper fix would be to push the
	 * rest of the setup into a vblank work item, queued here, but the
	 * infrastructure is not there yet.
	 */
311

312 313
	/* Reset ELD write address */
	tmp = I915_READ(HSW_AUD_DIP_ELD_CTRL(pipe));
314
	tmp &= ~IBX_ELD_ADDRESS_MASK;
315
	I915_WRITE(HSW_AUD_DIP_ELD_CTRL(pipe), tmp);
316

317
	/* Up to 84 bytes of hw ELD buffer */
318 319
	len = min(drm_eld_size(eld), 84);
	for (i = 0; i < len / 4; i++)
320
		I915_WRITE(HSW_AUD_EDID_DATA(pipe), *((uint32_t *)eld + i));
321

322
	/* ELD valid */
323
	tmp = I915_READ(HSW_AUD_PIN_ELD_CP_VLD);
324
	tmp |= AUDIO_ELD_VALID(pipe);
325
	I915_WRITE(HSW_AUD_PIN_ELD_CP_VLD, tmp);
326 327 328 329 330

	/* Enable timestamps */
	tmp = I915_READ(HSW_AUD_CFG(pipe));
	tmp &= ~AUD_CONFIG_N_VALUE_INDEX;
	tmp &= ~AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK;
331
	if (intel_crtc_has_dp_encoder(intel_crtc->config))
332 333
		tmp |= AUD_CONFIG_N_VALUE_INDEX;
	else
334
		tmp |= audio_config_hdmi_pixel_clock(adjusted_mode);
335 336

	tmp &= ~AUD_CONFIG_N_PROG_ENABLE;
337
	if (audio_rate_need_prog(intel_crtc, adjusted_mode)) {
338 339 340 341 342 343 344 345
		if (!acomp)
			rate = 0;
		else if (port >= PORT_A && port <= PORT_E)
			rate = acomp->aud_sample_rate[port];
		else {
			DRM_ERROR("invalid port: %d\n", port);
			rate = 0;
		}
346
		n = audio_config_get_n(adjusted_mode, rate);
347 348 349 350 351 352
		if (n != 0)
			tmp = audio_config_setup_n_reg(n, tmp);
		else
			DRM_DEBUG_KMS("no suitable N value is found\n");
	}

353
	I915_WRITE(HSW_AUD_CFG(pipe), tmp);
354 355

	mutex_unlock(&dev_priv->av_mutex);
356 357
}

358 359
static void ilk_audio_codec_disable(struct intel_encoder *encoder)
{
360
	struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
361 362 363 364 365 366
	struct intel_crtc *intel_crtc = to_intel_crtc(encoder->base.crtc);
	struct intel_digital_port *intel_dig_port =
		enc_to_dig_port(&encoder->base);
	enum port port = intel_dig_port->port;
	enum pipe pipe = intel_crtc->pipe;
	uint32_t tmp, eldv;
367
	i915_reg_t aud_config, aud_cntrl_st2;
368 369 370 371

	DRM_DEBUG_KMS("Disable audio codec on port %c, pipe %c\n",
		      port_name(port), pipe_name(pipe));

372 373 374
	if (WARN_ON(port == PORT_A))
		return;

375
	if (HAS_PCH_IBX(dev_priv)) {
376 377
		aud_config = IBX_AUD_CFG(pipe);
		aud_cntrl_st2 = IBX_AUD_CNTL_ST2;
378
	} else if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) {
379 380 381 382 383 384 385 386 387 388 389 390 391
		aud_config = VLV_AUD_CFG(pipe);
		aud_cntrl_st2 = VLV_AUD_CNTL_ST2;
	} else {
		aud_config = CPT_AUD_CFG(pipe);
		aud_cntrl_st2 = CPT_AUD_CNTRL_ST2;
	}

	/* Disable timestamps */
	tmp = I915_READ(aud_config);
	tmp &= ~AUD_CONFIG_N_VALUE_INDEX;
	tmp |= AUD_CONFIG_N_PROG_ENABLE;
	tmp &= ~AUD_CONFIG_UPPER_N_MASK;
	tmp &= ~AUD_CONFIG_LOWER_N_MASK;
392
	if (intel_crtc_has_dp_encoder(intel_crtc->config))
393 394 395
		tmp |= AUD_CONFIG_N_VALUE_INDEX;
	I915_WRITE(aud_config, tmp);

396
	eldv = IBX_ELD_VALID(port);
397 398 399 400 401 402 403

	/* Invalidate ELD */
	tmp = I915_READ(aud_cntrl_st2);
	tmp &= ~eldv;
	I915_WRITE(aud_cntrl_st2, tmp);
}

404 405
static void ilk_audio_codec_enable(struct drm_connector *connector,
				   struct intel_encoder *encoder,
406
				   const struct drm_display_mode *adjusted_mode)
407
{
408
	struct drm_i915_private *dev_priv = to_i915(connector->dev);
409
	struct intel_crtc *intel_crtc = to_intel_crtc(encoder->base.crtc);
410 411 412 413
	struct intel_digital_port *intel_dig_port =
		enc_to_dig_port(&encoder->base);
	enum port port = intel_dig_port->port;
	enum pipe pipe = intel_crtc->pipe;
414 415
	uint8_t *eld = connector->eld;
	uint32_t eldv;
416 417
	uint32_t tmp;
	int len, i;
418
	i915_reg_t hdmiw_hdmiedid, aud_config, aud_cntl_st, aud_cntrl_st2;
419 420

	DRM_DEBUG_KMS("Enable audio codec on port %c, pipe %c, %u bytes ELD\n",
421
		      port_name(port), pipe_name(pipe), drm_eld_size(eld));
422

423 424 425
	if (WARN_ON(port == PORT_A))
		return;

426 427 428 429 430 431
	/*
	 * FIXME: We're supposed to wait for vblank here, but we have vblanks
	 * disabled during the mode set. The proper fix would be to push the
	 * rest of the setup into a vblank work item, queued here, but the
	 * infrastructure is not there yet.
	 */
432 433 434 435 436 437

	if (HAS_PCH_IBX(connector->dev)) {
		hdmiw_hdmiedid = IBX_HDMIW_HDMIEDID(pipe);
		aud_config = IBX_AUD_CFG(pipe);
		aud_cntl_st = IBX_AUD_CNTL_ST(pipe);
		aud_cntrl_st2 = IBX_AUD_CNTL_ST2;
438 439
	} else if (IS_VALLEYVIEW(connector->dev) ||
		   IS_CHERRYVIEW(connector->dev)) {
440 441 442 443 444 445 446 447 448 449 450
		hdmiw_hdmiedid = VLV_HDMIW_HDMIEDID(pipe);
		aud_config = VLV_AUD_CFG(pipe);
		aud_cntl_st = VLV_AUD_CNTL_ST(pipe);
		aud_cntrl_st2 = VLV_AUD_CNTL_ST2;
	} else {
		hdmiw_hdmiedid = CPT_HDMIW_HDMIEDID(pipe);
		aud_config = CPT_AUD_CFG(pipe);
		aud_cntl_st = CPT_AUD_CNTL_ST(pipe);
		aud_cntrl_st2 = CPT_AUD_CNTRL_ST2;
	}

451
	eldv = IBX_ELD_VALID(port);
452

453
	/* Invalidate ELD */
454 455 456
	tmp = I915_READ(aud_cntrl_st2);
	tmp &= ~eldv;
	I915_WRITE(aud_cntrl_st2, tmp);
457

458
	/* Reset ELD write address */
459
	tmp = I915_READ(aud_cntl_st);
460
	tmp &= ~IBX_ELD_ADDRESS_MASK;
461
	I915_WRITE(aud_cntl_st, tmp);
462

463
	/* Up to 84 bytes of hw ELD buffer */
464 465
	len = min(drm_eld_size(eld), 84);
	for (i = 0; i < len / 4; i++)
466 467
		I915_WRITE(hdmiw_hdmiedid, *((uint32_t *)eld + i));

468
	/* ELD valid */
469 470 471
	tmp = I915_READ(aud_cntrl_st2);
	tmp |= eldv;
	I915_WRITE(aud_cntrl_st2, tmp);
472 473 474 475 476 477

	/* Enable timestamps */
	tmp = I915_READ(aud_config);
	tmp &= ~AUD_CONFIG_N_VALUE_INDEX;
	tmp &= ~AUD_CONFIG_N_PROG_ENABLE;
	tmp &= ~AUD_CONFIG_PIXEL_CLOCK_HDMI_MASK;
478
	if (intel_crtc_has_dp_encoder(intel_crtc->config))
479 480
		tmp |= AUD_CONFIG_N_VALUE_INDEX;
	else
481
		tmp |= audio_config_hdmi_pixel_clock(adjusted_mode);
482
	I915_WRITE(aud_config, tmp);
483 484
}

485 486 487 488 489 490 491 492
/**
 * intel_audio_codec_enable - Enable the audio codec for HD audio
 * @intel_encoder: encoder on which to enable audio
 *
 * The enable sequences may only be performed after enabling the transcoder and
 * port, and after completed link training.
 */
void intel_audio_codec_enable(struct intel_encoder *intel_encoder)
493
{
494 495
	struct drm_encoder *encoder = &intel_encoder->base;
	struct intel_crtc *crtc = to_intel_crtc(encoder->crtc);
496
	const struct drm_display_mode *adjusted_mode = &crtc->config->base.adjusted_mode;
497 498
	struct drm_connector *connector;
	struct drm_device *dev = encoder->dev;
499
	struct drm_i915_private *dev_priv = to_i915(dev);
500 501 502
	struct i915_audio_component *acomp = dev_priv->audio_component;
	struct intel_digital_port *intel_dig_port = enc_to_dig_port(encoder);
	enum port port = intel_dig_port->port;
503

504
	connector = drm_select_eld(encoder);
505 506 507 508 509 510 511 512 513
	if (!connector)
		return;

	DRM_DEBUG_DRIVER("ELD on [CONNECTOR:%d:%s], [ENCODER:%d:%s]\n",
			 connector->base.id,
			 connector->name,
			 connector->encoder->base.id,
			 connector->encoder->name);

514 515
	/* ELD Conn_Type */
	connector->eld[5] &= ~(3 << 2);
516
	if (intel_crtc_has_dp_encoder(crtc->config))
517 518
		connector->eld[5] |= (1 << 2);

519
	connector->eld[6] = drm_av_sync_delay(connector, adjusted_mode) / 2;
520

521
	if (dev_priv->display.audio_codec_enable)
522 523
		dev_priv->display.audio_codec_enable(connector, intel_encoder,
						     adjusted_mode);
524

525 526
	mutex_lock(&dev_priv->av_mutex);
	intel_dig_port->audio_connector = connector;
527 528
	/* referred in audio callbacks */
	dev_priv->dig_port_map[port] = intel_encoder;
529 530
	mutex_unlock(&dev_priv->av_mutex);

531
	if (acomp && acomp->audio_ops && acomp->audio_ops->pin_eld_notify)
532
		acomp->audio_ops->pin_eld_notify(acomp->audio_ops->audio_ptr, (int) port);
533 534 535 536
}

/**
 * intel_audio_codec_disable - Disable the audio codec for HD audio
537
 * @intel_encoder: encoder on which to disable audio
538 539 540 541
 *
 * The disable sequences must be performed before disabling the transcoder or
 * port.
 */
542
void intel_audio_codec_disable(struct intel_encoder *intel_encoder)
543
{
544 545
	struct drm_encoder *encoder = &intel_encoder->base;
	struct drm_device *dev = encoder->dev;
546
	struct drm_i915_private *dev_priv = to_i915(dev);
547 548 549
	struct i915_audio_component *acomp = dev_priv->audio_component;
	struct intel_digital_port *intel_dig_port = enc_to_dig_port(encoder);
	enum port port = intel_dig_port->port;
550 551

	if (dev_priv->display.audio_codec_disable)
552 553
		dev_priv->display.audio_codec_disable(intel_encoder);

554 555
	mutex_lock(&dev_priv->av_mutex);
	intel_dig_port->audio_connector = NULL;
556
	dev_priv->dig_port_map[port] = NULL;
557 558
	mutex_unlock(&dev_priv->av_mutex);

559
	if (acomp && acomp->audio_ops && acomp->audio_ops->pin_eld_notify)
560
		acomp->audio_ops->pin_eld_notify(acomp->audio_ops->audio_ptr, (int) port);
561 562 563
}

/**
564 565
 * intel_init_audio_hooks - Set up chip specific audio hooks
 * @dev_priv: device private
566
 */
567
void intel_init_audio_hooks(struct drm_i915_private *dev_priv)
568
{
569
	if (IS_G4X(dev_priv)) {
570
		dev_priv->display.audio_codec_enable = g4x_audio_codec_enable;
571
		dev_priv->display.audio_codec_disable = g4x_audio_codec_disable;
572
	} else if (IS_VALLEYVIEW(dev_priv) || IS_CHERRYVIEW(dev_priv)) {
573
		dev_priv->display.audio_codec_enable = ilk_audio_codec_enable;
574
		dev_priv->display.audio_codec_disable = ilk_audio_codec_disable;
575
	} else if (IS_HASWELL(dev_priv) || INTEL_INFO(dev_priv)->gen >= 8) {
576 577
		dev_priv->display.audio_codec_enable = hsw_audio_codec_enable;
		dev_priv->display.audio_codec_disable = hsw_audio_codec_disable;
578
	} else if (HAS_PCH_SPLIT(dev_priv)) {
579
		dev_priv->display.audio_codec_enable = ilk_audio_codec_enable;
580
		dev_priv->display.audio_codec_disable = ilk_audio_codec_disable;
581
	}
582
}
I
Imre Deak 已提交
583

584
static void i915_audio_component_get_power(struct device *kdev)
I
Imre Deak 已提交
585
{
586
	intel_display_power_get(kdev_to_i915(kdev), POWER_DOMAIN_AUDIO);
I
Imre Deak 已提交
587 588
}

589
static void i915_audio_component_put_power(struct device *kdev)
I
Imre Deak 已提交
590
{
591
	intel_display_power_put(kdev_to_i915(kdev), POWER_DOMAIN_AUDIO);
I
Imre Deak 已提交
592 593
}

594
static void i915_audio_component_codec_wake_override(struct device *kdev,
595 596
						     bool enable)
{
597
	struct drm_i915_private *dev_priv = kdev_to_i915(kdev);
598 599
	u32 tmp;

600
	if (!IS_SKYLAKE(dev_priv) && !IS_KABYLAKE(dev_priv))
601 602
		return;

603
	i915_audio_component_get_power(kdev);
604

605 606 607 608 609 610 611 612 613 614 615 616 617 618 619
	/*
	 * Enable/disable generating the codec wake signal, overriding the
	 * internal logic to generate the codec wake to controller.
	 */
	tmp = I915_READ(HSW_AUD_CHICKENBIT);
	tmp &= ~SKL_AUD_CODEC_WAKE_SIGNAL;
	I915_WRITE(HSW_AUD_CHICKENBIT, tmp);
	usleep_range(1000, 1500);

	if (enable) {
		tmp = I915_READ(HSW_AUD_CHICKENBIT);
		tmp |= SKL_AUD_CODEC_WAKE_SIGNAL;
		I915_WRITE(HSW_AUD_CHICKENBIT, tmp);
		usleep_range(1000, 1500);
	}
620

621
	i915_audio_component_put_power(kdev);
622 623
}

I
Imre Deak 已提交
624
/* Get CDCLK in kHz  */
625
static int i915_audio_component_get_cdclk_freq(struct device *kdev)
I
Imre Deak 已提交
626
{
627
	struct drm_i915_private *dev_priv = kdev_to_i915(kdev);
I
Imre Deak 已提交
628 629 630 631

	if (WARN_ON_ONCE(!HAS_DDI(dev_priv)))
		return -ENODEV;

632
	return dev_priv->cdclk_freq;
I
Imre Deak 已提交
633 634
}

635
static int i915_audio_component_sync_audio_rate(struct device *kdev,
636 637
						int port, int rate)
{
638
	struct drm_i915_private *dev_priv = kdev_to_i915(kdev);
639 640 641
	struct intel_encoder *intel_encoder;
	struct intel_crtc *crtc;
	struct drm_display_mode *mode;
642
	struct i915_audio_component *acomp = dev_priv->audio_component;
643
	enum pipe pipe = INVALID_PIPE;
644
	u32 tmp;
645
	int n;
646
	int err = 0;
647

648
	/* HSW, BDW, SKL, KBL need this fix */
649
	if (!IS_SKYLAKE(dev_priv) &&
650 651 652
	    !IS_KABYLAKE(dev_priv) &&
	    !IS_BROADWELL(dev_priv) &&
	    !IS_HASWELL(dev_priv))
653 654
		return 0;

655
	i915_audio_component_get_power(kdev);
656 657
	mutex_lock(&dev_priv->av_mutex);
	/* 1. get the pipe */
658 659 660 661 662 663 664
	intel_encoder = dev_priv->dig_port_map[port];
	/* intel_encoder might be NULL for DP MST */
	if (!intel_encoder || !intel_encoder->base.crtc ||
	    intel_encoder->type != INTEL_OUTPUT_HDMI) {
		DRM_DEBUG_KMS("no valid port %c\n", port_name(port));
		err = -ENODEV;
		goto unlock;
665
	}
666 667
	crtc = to_intel_crtc(intel_encoder->base.crtc);
	pipe = crtc->pipe;
668 669
	if (pipe == INVALID_PIPE) {
		DRM_DEBUG_KMS("no pipe for the port %c\n", port_name(port));
670 671
		err = -ENODEV;
		goto unlock;
672
	}
673

674 675 676 677
	DRM_DEBUG_KMS("pipe %c connects port %c\n",
				  pipe_name(pipe), port_name(port));
	mode = &crtc->config->base.adjusted_mode;

678 679 680
	/* port must be valid now, otherwise the pipe will be invalid */
	acomp->aud_sample_rate[port] = rate;

681 682 683 684 685
	/* 2. check whether to set the N/CTS/M manually or not */
	if (!audio_rate_need_prog(crtc, mode)) {
		tmp = I915_READ(HSW_AUD_CFG(pipe));
		tmp &= ~AUD_CONFIG_N_PROG_ENABLE;
		I915_WRITE(HSW_AUD_CFG(pipe), tmp);
686
		goto unlock;
687 688 689 690 691 692 693 694 695
	}

	n = audio_config_get_n(mode, rate);
	if (n == 0) {
		DRM_DEBUG_KMS("Using automatic mode for N value on port %c\n",
					  port_name(port));
		tmp = I915_READ(HSW_AUD_CFG(pipe));
		tmp &= ~AUD_CONFIG_N_PROG_ENABLE;
		I915_WRITE(HSW_AUD_CFG(pipe), tmp);
696
		goto unlock;
697 698
	}

699
	/* 3. set the N/CTS/M */
700
	tmp = I915_READ(HSW_AUD_CFG(pipe));
701
	tmp = audio_config_setup_n_reg(n, tmp);
702 703
	I915_WRITE(HSW_AUD_CFG(pipe), tmp);

704
 unlock:
705
	mutex_unlock(&dev_priv->av_mutex);
706
	i915_audio_component_put_power(kdev);
707
	return err;
708 709
}

710
static int i915_audio_component_get_eld(struct device *kdev, int port,
711 712 713
					bool *enabled,
					unsigned char *buf, int max_bytes)
{
714
	struct drm_i915_private *dev_priv = kdev_to_i915(kdev);
715 716 717 718 719 720
	struct intel_encoder *intel_encoder;
	struct intel_digital_port *intel_dig_port;
	const u8 *eld;
	int ret = -EINVAL;

	mutex_lock(&dev_priv->av_mutex);
721 722 723 724
	intel_encoder = dev_priv->dig_port_map[port];
	/* intel_encoder might be NULL for DP MST */
	if (intel_encoder) {
		ret = 0;
725
		intel_dig_port = enc_to_dig_port(&intel_encoder->base);
726 727
		*enabled = intel_dig_port->audio_connector != NULL;
		if (*enabled) {
728 729 730 731 732 733 734 735
			eld = intel_dig_port->audio_connector->eld;
			ret = drm_eld_size(eld);
			memcpy(buf, eld, min(max_bytes, ret));
		}
	}

	mutex_unlock(&dev_priv->av_mutex);
	return ret;
736 737
}

I
Imre Deak 已提交
738 739 740 741
static const struct i915_audio_component_ops i915_audio_component_ops = {
	.owner		= THIS_MODULE,
	.get_power	= i915_audio_component_get_power,
	.put_power	= i915_audio_component_put_power,
742
	.codec_wake_override = i915_audio_component_codec_wake_override,
I
Imre Deak 已提交
743
	.get_cdclk_freq	= i915_audio_component_get_cdclk_freq,
744
	.sync_audio_rate = i915_audio_component_sync_audio_rate,
745
	.get_eld	= i915_audio_component_get_eld,
I
Imre Deak 已提交
746 747
};

748 749
static int i915_audio_component_bind(struct device *i915_kdev,
				     struct device *hda_kdev, void *data)
I
Imre Deak 已提交
750 751
{
	struct i915_audio_component *acomp = data;
752
	struct drm_i915_private *dev_priv = kdev_to_i915(i915_kdev);
753
	int i;
I
Imre Deak 已提交
754 755 756 757

	if (WARN_ON(acomp->ops || acomp->dev))
		return -EEXIST;

758
	drm_modeset_lock_all(&dev_priv->drm);
I
Imre Deak 已提交
759
	acomp->ops = &i915_audio_component_ops;
760
	acomp->dev = i915_kdev;
761 762 763
	BUILD_BUG_ON(MAX_PORTS != I915_MAX_PORTS);
	for (i = 0; i < ARRAY_SIZE(acomp->aud_sample_rate); i++)
		acomp->aud_sample_rate[i] = 0;
764
	dev_priv->audio_component = acomp;
765
	drm_modeset_unlock_all(&dev_priv->drm);
I
Imre Deak 已提交
766 767 768 769

	return 0;
}

770 771
static void i915_audio_component_unbind(struct device *i915_kdev,
					struct device *hda_kdev, void *data)
I
Imre Deak 已提交
772 773
{
	struct i915_audio_component *acomp = data;
774
	struct drm_i915_private *dev_priv = kdev_to_i915(i915_kdev);
I
Imre Deak 已提交
775

776
	drm_modeset_lock_all(&dev_priv->drm);
I
Imre Deak 已提交
777 778
	acomp->ops = NULL;
	acomp->dev = NULL;
779
	dev_priv->audio_component = NULL;
780
	drm_modeset_unlock_all(&dev_priv->drm);
I
Imre Deak 已提交
781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807
}

static const struct component_ops i915_audio_component_bind_ops = {
	.bind	= i915_audio_component_bind,
	.unbind	= i915_audio_component_unbind,
};

/**
 * i915_audio_component_init - initialize and register the audio component
 * @dev_priv: i915 device instance
 *
 * This will register with the component framework a child component which
 * will bind dynamically to the snd_hda_intel driver's corresponding master
 * component when the latter is registered. During binding the child
 * initializes an instance of struct i915_audio_component which it receives
 * from the master. The master can then start to use the interface defined by
 * this struct. Each side can break the binding at any point by deregistering
 * its own component after which each side's component unbind callback is
 * called.
 *
 * We ignore any error during registration and continue with reduced
 * functionality (i.e. without HDMI audio).
 */
void i915_audio_component_init(struct drm_i915_private *dev_priv)
{
	int ret;

808
	ret = component_add(dev_priv->drm.dev, &i915_audio_component_bind_ops);
I
Imre Deak 已提交
809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829
	if (ret < 0) {
		DRM_ERROR("failed to add audio component (%d)\n", ret);
		/* continue with reduced functionality */
		return;
	}

	dev_priv->audio_component_registered = true;
}

/**
 * i915_audio_component_cleanup - deregister the audio component
 * @dev_priv: i915 device instance
 *
 * Deregisters the audio component, breaking any existing binding to the
 * corresponding snd_hda_intel driver's master component.
 */
void i915_audio_component_cleanup(struct drm_i915_private *dev_priv)
{
	if (!dev_priv->audio_component_registered)
		return;

830
	component_del(dev_priv->drm.dev, &i915_audio_component_bind_ops);
I
Imre Deak 已提交
831 832
	dev_priv->audio_component_registered = false;
}