xref: /linux/sound/hda/codecs/hdmi/intelhdmi.c (revision 3f2a5ba784b808109cac0aac921213e43143a216)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Intel HDMI codec support
4  */
5 
6 #include <linux/init.h>
7 #include <linux/slab.h>
8 #include <linux/module.h>
9 #include <sound/core.h>
10 #include <sound/hdaudio.h>
11 #include <sound/hda_i915.h>
12 #include <sound/hda_codec.h>
13 #include "hda_local.h"
14 #include "hdmi_local.h"
15 
16 static bool enable_silent_stream =
17 IS_ENABLED(CONFIG_SND_HDA_INTEL_HDMI_SILENT_STREAM);
18 module_param(enable_silent_stream, bool, 0644);
19 MODULE_PARM_DESC(enable_silent_stream, "Enable Silent Stream for HDMI devices");
20 
21 enum {
22 	MODEL_HSW,
23 	MODEL_GLK,
24 	MODEL_ICL,
25 	MODEL_TGL,
26 	MODEL_ADLP,
27 	MODEL_BYT,
28 	MODEL_CPT,
29 };
30 
31 #define INTEL_GET_VENDOR_VERB	0xf81
32 #define INTEL_SET_VENDOR_VERB	0x781
33 #define INTEL_EN_DP12		0x02	/* enable DP 1.2 features */
34 #define INTEL_EN_ALL_PIN_CVTS	0x01	/* enable 2nd & 3rd pins and convertors */
35 
36 static void intel_haswell_enable_all_pins(struct hda_codec *codec,
37 					  bool update_tree)
38 {
39 	unsigned int vendor_param;
40 	struct hdmi_spec *spec = codec->spec;
41 
42 	vendor_param = snd_hda_codec_read(codec, spec->vendor_nid, 0,
43 				INTEL_GET_VENDOR_VERB, 0);
44 	if (vendor_param == -1 || vendor_param & INTEL_EN_ALL_PIN_CVTS)
45 		return;
46 
47 	vendor_param |= INTEL_EN_ALL_PIN_CVTS;
48 	vendor_param = snd_hda_codec_read(codec, spec->vendor_nid, 0,
49 				INTEL_SET_VENDOR_VERB, vendor_param);
50 	if (vendor_param == -1)
51 		return;
52 
53 	if (update_tree)
54 		snd_hda_codec_update_widgets(codec);
55 }
56 
57 static void intel_haswell_fixup_enable_dp12(struct hda_codec *codec)
58 {
59 	unsigned int vendor_param;
60 	struct hdmi_spec *spec = codec->spec;
61 
62 	vendor_param = snd_hda_codec_read(codec, spec->vendor_nid, 0,
63 				INTEL_GET_VENDOR_VERB, 0);
64 	if (vendor_param == -1 || vendor_param & INTEL_EN_DP12)
65 		return;
66 
67 	/* enable DP1.2 mode */
68 	vendor_param |= INTEL_EN_DP12;
69 	snd_hdac_regmap_add_vendor_verb(&codec->core, INTEL_SET_VENDOR_VERB);
70 	snd_hda_codec_write_cache(codec, spec->vendor_nid, 0,
71 				INTEL_SET_VENDOR_VERB, vendor_param);
72 }
73 
74 /* Haswell needs to re-issue the vendor-specific verbs before turning to D0.
75  * Otherwise you may get severe h/w communication errors.
76  */
77 static void haswell_set_power_state(struct hda_codec *codec, hda_nid_t fg,
78 				unsigned int power_state)
79 {
80 	/* check codec->spec: it can be called before the probe gets called */
81 	if (codec->spec) {
82 		if (power_state == AC_PWRST_D0) {
83 			intel_haswell_enable_all_pins(codec, false);
84 			intel_haswell_fixup_enable_dp12(codec);
85 		}
86 	}
87 
88 	snd_hda_codec_read(codec, fg, 0, AC_VERB_SET_POWER_STATE, power_state);
89 	snd_hda_codec_set_power_to_all(codec, fg, power_state);
90 }
91 
92 /* There is a fixed mapping between audio pin node and display port.
93  * on SNB, IVY, HSW, BSW, SKL, BXT, KBL:
94  * Pin Widget 5 - PORT B (port = 1 in i915 driver)
95  * Pin Widget 6 - PORT C (port = 2 in i915 driver)
96  * Pin Widget 7 - PORT D (port = 3 in i915 driver)
97  *
98  * on VLV, ILK:
99  * Pin Widget 4 - PORT B (port = 1 in i915 driver)
100  * Pin Widget 5 - PORT C (port = 2 in i915 driver)
101  * Pin Widget 6 - PORT D (port = 3 in i915 driver)
102  */
103 static int intel_base_nid(struct hda_codec *codec)
104 {
105 	switch (codec->core.vendor_id) {
106 	case 0x80860054: /* ILK */
107 	case 0x80862804: /* ILK */
108 	case 0x80862882: /* VLV */
109 		return 4;
110 	default:
111 		return 5;
112 	}
113 }
114 
115 static int intel_pin2port(void *audio_ptr, int pin_nid)
116 {
117 	struct hda_codec *codec = audio_ptr;
118 	struct hdmi_spec *spec = codec->spec;
119 	int base_nid, i;
120 
121 	if (!spec->port_num) {
122 		base_nid = intel_base_nid(codec);
123 		if (WARN_ON(pin_nid < base_nid || pin_nid >= base_nid + 3))
124 			return -1;
125 		return pin_nid - base_nid + 1;
126 	}
127 
128 	/*
129 	 * looking for the pin number in the mapping table and return
130 	 * the index which indicate the port number
131 	 */
132 	for (i = 0; i < spec->port_num; i++) {
133 		if (pin_nid == spec->port_map[i])
134 			return i;
135 	}
136 
137 	codec_info(codec, "Can't find the HDMI/DP port for pin NID 0x%x\n", pin_nid);
138 	return -1;
139 }
140 
141 static int intel_port2pin(struct hda_codec *codec, int port)
142 {
143 	struct hdmi_spec *spec = codec->spec;
144 
145 	if (!spec->port_num) {
146 		/* we assume only from port-B to port-D */
147 		if (port < 1 || port > 3)
148 			return 0;
149 		return port + intel_base_nid(codec) - 1;
150 	}
151 
152 	if (port < 0 || port >= spec->port_num)
153 		return 0;
154 	return spec->port_map[port];
155 }
156 
157 static void intel_pin_eld_notify(void *audio_ptr, int port, int pipe)
158 {
159 	struct hda_codec *codec = audio_ptr;
160 	int pin_nid;
161 	int dev_id = pipe;
162 
163 	pin_nid = intel_port2pin(codec, port);
164 	if (!pin_nid)
165 		return;
166 	/* skip notification during system suspend (but not in runtime PM);
167 	 * the state will be updated at resume
168 	 */
169 	if (codec->core.dev.power.power_state.event == PM_EVENT_SUSPEND)
170 		return;
171 
172 	snd_hdac_i915_set_bclk(&codec->bus->core);
173 	snd_hda_hdmi_check_presence_and_report(codec, pin_nid, dev_id);
174 }
175 
176 static const struct drm_audio_component_audio_ops intel_audio_ops = {
177 	.pin2port = intel_pin2port,
178 	.pin_eld_notify = intel_pin_eld_notify,
179 };
180 
181 /* register i915 component pin_eld_notify callback */
182 static void register_i915_notifier(struct hda_codec *codec)
183 {
184 	struct hdmi_spec *spec = codec->spec;
185 
186 	spec->use_acomp_notifier = true;
187 	spec->port2pin = intel_port2pin;
188 	snd_hda_hdmi_setup_drm_audio_ops(codec, &intel_audio_ops);
189 	snd_hdac_acomp_register_notifier(&codec->bus->core,
190 					&spec->drm_audio_ops);
191 	/* no need for forcible resume for jack check thanks to notifier */
192 	codec->relaxed_resume = 1;
193 }
194 
195 #define I915_SILENT_RATE		48000
196 #define I915_SILENT_CHANNELS		2
197 #define I915_SILENT_FORMAT_BITS	16
198 #define I915_SILENT_FMT_MASK		0xf
199 
200 static void silent_stream_enable_i915(struct hda_codec *codec,
201 				      struct hdmi_spec_per_pin *per_pin)
202 {
203 	unsigned int format;
204 
205 	snd_hdac_sync_audio_rate(&codec->core, per_pin->pin_nid,
206 				 per_pin->dev_id, I915_SILENT_RATE);
207 
208 	/* trigger silent stream generation in hw */
209 	format = snd_hdac_stream_format(I915_SILENT_CHANNELS, I915_SILENT_FORMAT_BITS,
210 					I915_SILENT_RATE);
211 	snd_hda_codec_setup_stream(codec, per_pin->cvt_nid,
212 				   I915_SILENT_FMT_MASK, I915_SILENT_FMT_MASK, format);
213 	usleep_range(100, 200);
214 	snd_hda_codec_setup_stream(codec, per_pin->cvt_nid, I915_SILENT_FMT_MASK, 0, format);
215 
216 	per_pin->channels = I915_SILENT_CHANNELS;
217 	snd_hda_hdmi_setup_audio_infoframe(codec, per_pin, per_pin->non_pcm);
218 }
219 
220 static void silent_stream_set_kae(struct hda_codec *codec,
221 				  struct hdmi_spec_per_pin *per_pin,
222 				  bool enable)
223 {
224 	unsigned int param;
225 
226 	codec_dbg(codec, "HDMI: KAE %d cvt-NID=0x%x\n", enable, per_pin->cvt_nid);
227 
228 	param = snd_hda_codec_read(codec, per_pin->cvt_nid, 0, AC_VERB_GET_DIGI_CONVERT_1, 0);
229 	param = (param >> 16) & 0xff;
230 
231 	if (enable)
232 		param |= AC_DIG3_KAE;
233 	else
234 		param &= ~AC_DIG3_KAE;
235 
236 	snd_hda_codec_write(codec, per_pin->cvt_nid, 0, AC_VERB_SET_DIGI_CONVERT_3, param);
237 }
238 
239 static void i915_set_silent_stream(struct hda_codec *codec,
240 				   struct hdmi_spec_per_pin *per_pin,
241 				   bool enable)
242 {
243 	struct hdmi_spec *spec = codec->spec;
244 
245 	switch (spec->silent_stream_type) {
246 	case SILENT_STREAM_KAE:
247 		if (enable) {
248 			silent_stream_enable_i915(codec, per_pin);
249 			silent_stream_set_kae(codec, per_pin, true);
250 		} else {
251 			silent_stream_set_kae(codec, per_pin, false);
252 		}
253 		break;
254 	case SILENT_STREAM_I915:
255 		if (enable) {
256 			silent_stream_enable_i915(codec, per_pin);
257 			snd_hda_power_up_pm(codec);
258 		} else {
259 			/* release ref taken in silent_stream_enable() */
260 			snd_hda_power_down_pm(codec);
261 		}
262 		break;
263 	default:
264 		break;
265 	}
266 }
267 
268 static void haswell_verify_D0(struct hda_codec *codec,
269 			      hda_nid_t cvt_nid, hda_nid_t nid)
270 {
271 	int pwr;
272 
273 	/* For Haswell, the converter 1/2 may keep in D3 state after bootup,
274 	 * thus pins could only choose converter 0 for use. Make sure the
275 	 * converters are in correct power state
276 	 */
277 	if (!snd_hda_check_power_state(codec, cvt_nid, AC_PWRST_D0))
278 		snd_hda_codec_write(codec, cvt_nid, 0, AC_VERB_SET_POWER_STATE, AC_PWRST_D0);
279 
280 	if (!snd_hda_check_power_state(codec, nid, AC_PWRST_D0)) {
281 		snd_hda_codec_write(codec, nid, 0, AC_VERB_SET_POWER_STATE,
282 				    AC_PWRST_D0);
283 		msleep(40);
284 		pwr = snd_hda_codec_read(codec, nid, 0, AC_VERB_GET_POWER_STATE, 0);
285 		pwr = (pwr & AC_PWRST_ACTUAL) >> AC_PWRST_ACTUAL_SHIFT;
286 		codec_dbg(codec, "Haswell HDMI audio: Power for NID 0x%x is now D%d\n", nid, pwr);
287 	}
288 }
289 
290 /* Assure the pin select the right convetor */
291 static void intel_verify_pin_cvt_connect(struct hda_codec *codec,
292 			struct hdmi_spec_per_pin *per_pin)
293 {
294 	hda_nid_t pin_nid = per_pin->pin_nid;
295 	int mux_idx, curr;
296 
297 	mux_idx = per_pin->mux_idx;
298 	curr = snd_hda_codec_read(codec, pin_nid, 0,
299 					  AC_VERB_GET_CONNECT_SEL, 0);
300 	if (curr != mux_idx)
301 		snd_hda_codec_write_cache(codec, pin_nid, 0,
302 					    AC_VERB_SET_CONNECT_SEL,
303 					    mux_idx);
304 }
305 
306 /* get the mux index for the converter of the pins
307  * converter's mux index is the same for all pins on Intel platform
308  */
309 static int intel_cvt_id_to_mux_idx(struct hdmi_spec *spec,
310 			hda_nid_t cvt_nid)
311 {
312 	int i;
313 
314 	for (i = 0; i < spec->num_cvts; i++)
315 		if (spec->cvt_nids[i] == cvt_nid)
316 			return i;
317 	return -EINVAL;
318 }
319 
320 /* Intel HDMI workaround to fix audio routing issue:
321  * For some Intel display codecs, pins share the same connection list.
322  * So a conveter can be selected by multiple pins and playback on any of these
323  * pins will generate sound on the external display, because audio flows from
324  * the same converter to the display pipeline. Also muting one pin may make
325  * other pins have no sound output.
326  * So this function assures that an assigned converter for a pin is not selected
327  * by any other pins.
328  */
329 static void intel_not_share_assigned_cvt(struct hda_codec *codec,
330 					 hda_nid_t pin_nid,
331 					 int dev_id, int mux_idx)
332 {
333 	struct hdmi_spec *spec = codec->spec;
334 	hda_nid_t nid;
335 	int cvt_idx, curr;
336 	struct hdmi_spec_per_cvt *per_cvt;
337 	struct hdmi_spec_per_pin *per_pin;
338 	int pin_idx;
339 
340 	/* configure the pins connections */
341 	for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
342 		int dev_id_saved;
343 		int dev_num;
344 
345 		per_pin = get_pin(spec, pin_idx);
346 		/*
347 		 * pin not connected to monitor
348 		 * no need to operate on it
349 		 */
350 		if (!per_pin->pcm)
351 			continue;
352 
353 		if ((per_pin->pin_nid == pin_nid) &&
354 			(per_pin->dev_id == dev_id))
355 			continue;
356 
357 		/*
358 		 * if per_pin->dev_id >= dev_num,
359 		 * snd_hda_get_dev_select() will fail,
360 		 * and the following operation is unpredictable.
361 		 * So skip this situation.
362 		 */
363 		dev_num = snd_hda_get_num_devices(codec, per_pin->pin_nid) + 1;
364 		if (per_pin->dev_id >= dev_num)
365 			continue;
366 
367 		nid = per_pin->pin_nid;
368 
369 		/*
370 		 * Calling this function should not impact
371 		 * on the device entry selection
372 		 * So let's save the dev id for each pin,
373 		 * and restore it when return
374 		 */
375 		dev_id_saved = snd_hda_get_dev_select(codec, nid);
376 		snd_hda_set_dev_select(codec, nid, per_pin->dev_id);
377 		curr = snd_hda_codec_read(codec, nid, 0,
378 					  AC_VERB_GET_CONNECT_SEL, 0);
379 		if (curr != mux_idx) {
380 			snd_hda_set_dev_select(codec, nid, dev_id_saved);
381 			continue;
382 		}
383 
384 
385 		/* choose an unassigned converter. The conveters in the
386 		 * connection list are in the same order as in the codec.
387 		 */
388 		for (cvt_idx = 0; cvt_idx < spec->num_cvts; cvt_idx++) {
389 			per_cvt = get_cvt(spec, cvt_idx);
390 			if (!per_cvt->assigned) {
391 				codec_dbg(codec,
392 					  "choose cvt %d for pin NID 0x%x\n",
393 					  cvt_idx, nid);
394 				snd_hda_codec_write_cache(codec, nid, 0,
395 					    AC_VERB_SET_CONNECT_SEL,
396 					    cvt_idx);
397 				break;
398 			}
399 		}
400 		snd_hda_set_dev_select(codec, nid, dev_id_saved);
401 	}
402 }
403 
404 /* A wrapper of intel_not_share_asigned_cvt() */
405 static void intel_not_share_assigned_cvt_nid(struct hda_codec *codec,
406 			hda_nid_t pin_nid, int dev_id, hda_nid_t cvt_nid)
407 {
408 	int mux_idx;
409 	struct hdmi_spec *spec = codec->spec;
410 
411 	/* On Intel platform, the mapping of converter nid to
412 	 * mux index of the pins are always the same.
413 	 * The pin nid may be 0, this means all pins will not
414 	 * share the converter.
415 	 */
416 	mux_idx = intel_cvt_id_to_mux_idx(spec, cvt_nid);
417 	if (mux_idx >= 0)
418 		intel_not_share_assigned_cvt(codec, pin_nid, dev_id, mux_idx);
419 }
420 
421 /* setup_stream ops override for HSW+ */
422 static int i915_hsw_setup_stream(struct hda_codec *codec, hda_nid_t cvt_nid,
423 				 hda_nid_t pin_nid, int dev_id, u32 stream_tag,
424 				 int format)
425 {
426 	struct hdmi_spec *spec = codec->spec;
427 	int pin_idx = pin_id_to_pin_index(codec, pin_nid, dev_id);
428 	struct hdmi_spec_per_pin *per_pin;
429 	int res;
430 
431 	if (pin_idx < 0)
432 		per_pin = NULL;
433 	else
434 		per_pin = get_pin(spec, pin_idx);
435 
436 	haswell_verify_D0(codec, cvt_nid, pin_nid);
437 
438 	if (spec->silent_stream_type == SILENT_STREAM_KAE && per_pin && per_pin->silent_stream) {
439 		silent_stream_set_kae(codec, per_pin, false);
440 		/* wait for pending transfers in codec to clear */
441 		usleep_range(100, 200);
442 	}
443 
444 	res = snd_hda_hdmi_setup_stream(codec, cvt_nid, pin_nid, dev_id,
445 					stream_tag, format);
446 
447 	if (spec->silent_stream_type == SILENT_STREAM_KAE && per_pin && per_pin->silent_stream) {
448 		usleep_range(100, 200);
449 		silent_stream_set_kae(codec, per_pin, true);
450 	}
451 
452 	return res;
453 }
454 
455 /* pin_cvt_fixup ops override for HSW+ and VLV+ */
456 static void i915_pin_cvt_fixup(struct hda_codec *codec,
457 			       struct hdmi_spec_per_pin *per_pin,
458 			       hda_nid_t cvt_nid)
459 {
460 	if (per_pin) {
461 		haswell_verify_D0(codec, per_pin->cvt_nid, per_pin->pin_nid);
462 		snd_hda_set_dev_select(codec, per_pin->pin_nid,
463 			       per_pin->dev_id);
464 		intel_verify_pin_cvt_connect(codec, per_pin);
465 		intel_not_share_assigned_cvt(codec, per_pin->pin_nid,
466 				     per_pin->dev_id, per_pin->mux_idx);
467 	} else {
468 		intel_not_share_assigned_cvt_nid(codec, 0, 0, cvt_nid);
469 	}
470 }
471 
472 static int i915_hdmi_suspend(struct hda_codec *codec)
473 {
474 	struct hdmi_spec *spec = codec->spec;
475 	bool silent_streams = false;
476 	int pin_idx, res;
477 
478 	res = snd_hda_hdmi_generic_suspend(codec);
479 	if (spec->silent_stream_type != SILENT_STREAM_KAE)
480 		return res;
481 
482 	for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
483 		struct hdmi_spec_per_pin *per_pin = get_pin(spec, pin_idx);
484 
485 		if (per_pin->silent_stream) {
486 			silent_streams = true;
487 			break;
488 		}
489 	}
490 
491 	if (silent_streams) {
492 		/*
493 		 * stream-id should remain programmed when codec goes
494 		 * to runtime suspend
495 		 */
496 		codec->no_stream_clean_at_suspend = 1;
497 
498 		/*
499 		 * the system might go to S3, in which case keep-alive
500 		 * must be reprogrammed upon resume
501 		 */
502 		codec->forced_resume = 1;
503 
504 		codec_dbg(codec, "HDMI: KAE active at suspend\n");
505 	} else {
506 		codec->no_stream_clean_at_suspend = 0;
507 		codec->forced_resume = 0;
508 	}
509 
510 	return res;
511 }
512 
513 static int i915_hdmi_resume(struct hda_codec *codec)
514 {
515 	struct hdmi_spec *spec = codec->spec;
516 	int pin_idx, res;
517 
518 	res = snd_hda_hdmi_generic_resume(codec);
519 	if (spec->silent_stream_type != SILENT_STREAM_KAE)
520 		return res;
521 
522 	/* KAE not programmed at suspend, nothing to do here */
523 	if (!codec->no_stream_clean_at_suspend)
524 		return res;
525 
526 	for (pin_idx = 0; pin_idx < spec->num_pins; pin_idx++) {
527 		struct hdmi_spec_per_pin *per_pin = get_pin(spec, pin_idx);
528 
529 		/*
530 		 * If system was in suspend with monitor connected,
531 		 * the codec setting may have been lost. Re-enable
532 		 * keep-alive.
533 		 */
534 		if (per_pin->silent_stream) {
535 			unsigned int param;
536 
537 			param = snd_hda_codec_read(codec, per_pin->cvt_nid, 0,
538 						   AC_VERB_GET_CONV, 0);
539 			if (!param) {
540 				codec_dbg(codec, "HDMI: KAE: restore stream id\n");
541 				silent_stream_enable_i915(codec, per_pin);
542 			}
543 
544 			param = snd_hda_codec_read(codec, per_pin->cvt_nid, 0,
545 						   AC_VERB_GET_DIGI_CONVERT_1, 0);
546 			if (!(param & (AC_DIG3_KAE << 16))) {
547 				codec_dbg(codec, "HDMI: KAE: restore DIG3_KAE\n");
548 				silent_stream_set_kae(codec, per_pin, true);
549 			}
550 		}
551 	}
552 
553 	return res;
554 }
555 
556 /* precondition and allocation for Intel codecs */
557 static int alloc_intel_hdmi(struct hda_codec *codec)
558 {
559 	/* requires i915 binding */
560 	if (!codec->bus->core.audio_component) {
561 		codec_info(codec, "No i915 binding for Intel HDMI/DP codec\n");
562 		/* set probe_id here to prevent generic fallback binding */
563 		codec->probe_id = HDA_CODEC_ID_SKIP_PROBE;
564 		return -ENODEV;
565 	}
566 
567 	return snd_hda_hdmi_generic_alloc(codec);
568 }
569 
570 /* parse and post-process for Intel codecs */
571 static int parse_intel_hdmi(struct hda_codec *codec)
572 {
573 	int err, retries = 3;
574 
575 	do {
576 		err = snd_hda_hdmi_parse_codec(codec);
577 	} while (err < 0 && retries--);
578 
579 	if (err < 0)
580 		return err;
581 
582 	snd_hda_hdmi_generic_init_per_pins(codec);
583 	register_i915_notifier(codec);
584 	return 0;
585 }
586 
587 /* Intel Haswell and onwards; audio component with eld notifier */
588 static int intel_hsw_common_init(struct hda_codec *codec, hda_nid_t vendor_nid,
589 				 const int *port_map, int port_num, int dev_num,
590 				 bool send_silent_stream)
591 {
592 	struct hdmi_spec *spec;
593 
594 	spec = codec->spec;
595 	codec->dp_mst = true;
596 	spec->vendor_nid = vendor_nid;
597 	spec->port_map = port_map;
598 	spec->port_num = port_num;
599 	spec->intel_hsw_fixup = true;
600 	spec->dev_num = dev_num;
601 
602 	intel_haswell_enable_all_pins(codec, true);
603 	intel_haswell_fixup_enable_dp12(codec);
604 
605 	codec->display_power_control = 1;
606 
607 	codec->depop_delay = 0;
608 	codec->auto_runtime_pm = 1;
609 
610 	spec->ops.setup_stream = i915_hsw_setup_stream;
611 	spec->ops.pin_cvt_fixup = i915_pin_cvt_fixup;
612 	spec->ops.silent_stream = i915_set_silent_stream;
613 
614 	/*
615 	 * Enable silent stream feature, if it is enabled via
616 	 * module param or Kconfig option
617 	 */
618 	if (send_silent_stream)
619 		spec->silent_stream_type = SILENT_STREAM_I915;
620 
621 	return parse_intel_hdmi(codec);
622 }
623 
624 static int probe_i915_hsw_hdmi(struct hda_codec *codec)
625 {
626 	return intel_hsw_common_init(codec, 0x08, NULL, 0, 3,
627 				     enable_silent_stream);
628 }
629 
630 static int probe_i915_glk_hdmi(struct hda_codec *codec)
631 {
632 	/*
633 	 * Silent stream calls audio component .get_power() from
634 	 * .pin_eld_notify(). On GLK this will deadlock in i915 due
635 	 * to the audio vs. CDCLK workaround.
636 	 */
637 	return intel_hsw_common_init(codec, 0x0b, NULL, 0, 3, false);
638 }
639 
640 static int probe_i915_icl_hdmi(struct hda_codec *codec)
641 {
642 	/*
643 	 * pin to port mapping table where the value indicate the pin number and
644 	 * the index indicate the port number.
645 	 */
646 	static const int map[] = {0x0, 0x4, 0x6, 0x8, 0xa, 0xb};
647 
648 	return intel_hsw_common_init(codec, 0x02, map, ARRAY_SIZE(map), 3,
649 				     enable_silent_stream);
650 }
651 
652 static int probe_i915_tgl_hdmi(struct hda_codec *codec)
653 {
654 	/*
655 	 * pin to port mapping table where the value indicate the pin number and
656 	 * the index indicate the port number.
657 	 */
658 	static const int map[] = {0x4, 0x6, 0x8, 0xa, 0xb, 0xc, 0xd, 0xe, 0xf};
659 
660 	return intel_hsw_common_init(codec, 0x02, map, ARRAY_SIZE(map), 4,
661 				     enable_silent_stream);
662 }
663 
664 static int probe_i915_adlp_hdmi(struct hda_codec *codec)
665 {
666 	struct hdmi_spec *spec;
667 	int res;
668 
669 	res = probe_i915_tgl_hdmi(codec);
670 	if (!res) {
671 		spec = codec->spec;
672 
673 		if (spec->silent_stream_type)
674 			spec->silent_stream_type = SILENT_STREAM_KAE;
675 	}
676 
677 	return res;
678 }
679 
680 /* Intel Baytrail and Braswell; with eld notifier */
681 static int probe_i915_byt_hdmi(struct hda_codec *codec)
682 {
683 	struct hdmi_spec *spec;
684 
685 	spec = codec->spec;
686 
687 	/* For Valleyview/Cherryview, only the display codec is in the display
688 	 * power well and can use link_power ops to request/release the power.
689 	 */
690 	codec->display_power_control = 1;
691 
692 	codec->depop_delay = 0;
693 	codec->auto_runtime_pm = 1;
694 
695 	spec->ops.pin_cvt_fixup = i915_pin_cvt_fixup;
696 
697 	return parse_intel_hdmi(codec);
698 }
699 
700 /* Intel IronLake, SandyBridge and IvyBridge; with eld notifier */
701 static int probe_i915_cpt_hdmi(struct hda_codec *codec)
702 {
703 	return parse_intel_hdmi(codec);
704 }
705 
706 /*
707  * common driver probe
708  */
709 static int intelhdmi_probe(struct hda_codec *codec, const struct hda_device_id *id)
710 {
711 	int err;
712 
713 	err = alloc_intel_hdmi(codec);
714 	if (err < 0)
715 		return err;
716 
717 	switch (id->driver_data) {
718 	case MODEL_HSW:
719 		err = probe_i915_hsw_hdmi(codec);
720 		break;
721 	case MODEL_GLK:
722 		err = probe_i915_glk_hdmi(codec);
723 		break;
724 	case MODEL_ICL:
725 		err = probe_i915_icl_hdmi(codec);
726 		break;
727 	case MODEL_TGL:
728 		err = probe_i915_tgl_hdmi(codec);
729 		break;
730 	case MODEL_ADLP:
731 		err = probe_i915_adlp_hdmi(codec);
732 		break;
733 	case MODEL_BYT:
734 		err = probe_i915_byt_hdmi(codec);
735 		break;
736 	case MODEL_CPT:
737 		err = probe_i915_cpt_hdmi(codec);
738 		break;
739 	default:
740 		err = -EINVAL;
741 		break;
742 	}
743 
744 	if (err < 0) {
745 		snd_hda_hdmi_generic_spec_free(codec);
746 		return err;
747 	}
748 
749 	return 0;
750 }
751 
752 static const struct hda_codec_ops intelhdmi_codec_ops = {
753 	.probe = intelhdmi_probe,
754 	.remove = snd_hda_hdmi_generic_remove,
755 	.init = snd_hda_hdmi_generic_init,
756 	.build_pcms = snd_hda_hdmi_generic_build_pcms,
757 	.build_controls = snd_hda_hdmi_generic_build_controls,
758 	.unsol_event = snd_hda_hdmi_generic_unsol_event,
759 	.suspend = i915_hdmi_suspend,
760 	.resume = i915_hdmi_resume,
761 	.set_power_state = haswell_set_power_state,
762 };
763 
764 /*
765  * driver entries
766  */
767 static const struct hda_device_id snd_hda_id_intelhdmi[] = {
768 	HDA_CODEC_ID_MODEL(0x80860054, "IbexPeak HDMI",		MODEL_CPT),
769 	HDA_CODEC_ID_MODEL(0x80862800, "Geminilake HDMI",	MODEL_GLK),
770 	HDA_CODEC_ID_MODEL(0x80862804, "IbexPeak HDMI",		MODEL_CPT),
771 	HDA_CODEC_ID_MODEL(0x80862805, "CougarPoint HDMI",	MODEL_CPT),
772 	HDA_CODEC_ID_MODEL(0x80862806, "PantherPoint HDMI",	MODEL_CPT),
773 	HDA_CODEC_ID_MODEL(0x80862807, "Haswell HDMI",		MODEL_HSW),
774 	HDA_CODEC_ID_MODEL(0x80862808, "Broadwell HDMI",	MODEL_HSW),
775 	HDA_CODEC_ID_MODEL(0x80862809, "Skylake HDMI",		MODEL_HSW),
776 	HDA_CODEC_ID_MODEL(0x8086280a, "Broxton HDMI",		MODEL_HSW),
777 	HDA_CODEC_ID_MODEL(0x8086280b, "Kabylake HDMI",		MODEL_HSW),
778 	HDA_CODEC_ID_MODEL(0x8086280c, "Cannonlake HDMI",	MODEL_GLK),
779 	HDA_CODEC_ID_MODEL(0x8086280d, "Geminilake HDMI",	MODEL_GLK),
780 	HDA_CODEC_ID_MODEL(0x8086280f, "Icelake HDMI",		MODEL_ICL),
781 	HDA_CODEC_ID_MODEL(0x80862812, "Tigerlake HDMI",	MODEL_TGL),
782 	HDA_CODEC_ID_MODEL(0x80862814, "DG1 HDMI",		MODEL_TGL),
783 	HDA_CODEC_ID_MODEL(0x80862815, "Alderlake HDMI",	MODEL_TGL),
784 	HDA_CODEC_ID_MODEL(0x80862816, "Rocketlake HDMI",	MODEL_TGL),
785 	HDA_CODEC_ID_MODEL(0x80862818, "Raptorlake HDMI",	MODEL_TGL),
786 	HDA_CODEC_ID_MODEL(0x80862819, "DG2 HDMI",		MODEL_TGL),
787 	HDA_CODEC_ID_MODEL(0x8086281a, "Jasperlake HDMI",	MODEL_ICL),
788 	HDA_CODEC_ID_MODEL(0x8086281b, "Elkhartlake HDMI",	MODEL_ICL),
789 	HDA_CODEC_ID_MODEL(0x8086281c, "Alderlake-P HDMI",	MODEL_ADLP),
790 	HDA_CODEC_ID_MODEL(0x8086281d, "Meteor Lake HDMI",	MODEL_ADLP),
791 	HDA_CODEC_ID_MODEL(0x8086281e, "Battlemage HDMI",	MODEL_ADLP),
792 	HDA_CODEC_ID_MODEL(0x8086281f, "Raptor Lake P HDMI",	MODEL_ADLP),
793 	HDA_CODEC_ID_MODEL(0x80862820, "Lunar Lake HDMI",	MODEL_ADLP),
794 	HDA_CODEC_ID_MODEL(0x80862822, "Panther Lake HDMI",	MODEL_ADLP),
795 	HDA_CODEC_ID_MODEL(0x80862823, "Wildcat Lake HDMI",	MODEL_ADLP),
796 	HDA_CODEC_ID_MODEL(0x80862882, "Valleyview2 HDMI",	MODEL_BYT),
797 	HDA_CODEC_ID_MODEL(0x80862883, "Braswell HDMI",		MODEL_BYT),
798 	{} /* terminator */
799 };
800 MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_intelhdmi);
801 
802 MODULE_LICENSE("GPL");
803 MODULE_DESCRIPTION("Intel HDMI HD-audio codec");
804 MODULE_IMPORT_NS("SND_HDA_CODEC_HDMI");
805 
806 static struct hda_codec_driver intelhdmi_driver = {
807 	.id = snd_hda_id_intelhdmi,
808 	.ops = &intelhdmi_codec_ops,
809 };
810 
811 module_hda_codec_driver(intelhdmi_driver);
812