1 // SPDX-License-Identifier: GPL-2.0-only
3 * Intel Kabylake I2S Machine Driver with MAXIM98927
6 * Copyright (C) 2017, Intel Corporation. All rights reserved.
9 * Intel Skylake I2S Machine driver
12 #include <linux/input.h>
13 #include <linux/module.h>
14 #include <linux/platform_device.h>
15 #include <sound/core.h>
16 #include <sound/jack.h>
17 #include <sound/pcm.h>
18 #include <sound/pcm_params.h>
19 #include <sound/soc.h>
20 #include <sound/soc-acpi.h>
21 #include "../../codecs/rt5663.h"
22 #include "../../codecs/hdac_hdmi.h"
23 #include <linux/clk.h>
24 #include <linux/clk-provider.h>
25 #include <linux/clkdev.h>
27 #define KBL_REALTEK_CODEC_DAI "rt5663-aif"
28 #define KBL_MAXIM_CODEC_DAI "max98927-aif1"
29 #define DMIC_CH(p) p->list[p->count-1]
30 #define MAXIM_DEV0_NAME "i2c-MX98927:00"
31 #define MAXIM_DEV1_NAME "i2c-MX98927:01"
33 static struct snd_soc_card
*kabylake_audio_card
;
34 static const struct snd_pcm_hw_constraint_list
*dmic_constraints
;
35 static struct snd_soc_jack skylake_hdmi
[3];
38 struct list_head head
;
39 struct snd_soc_dai
*codec_dai
;
43 struct kbl_rt5663_private
{
44 struct snd_soc_jack kabylake_headset
;
45 struct list_head hdmi_pcm_list
;
51 KBL_DPCM_AUDIO_PB
= 0,
54 KBL_DPCM_AUDIO_ECHO_REF_CP
,
55 KBL_DPCM_AUDIO_REF_CP
,
56 KBL_DPCM_AUDIO_DMIC_CP
,
57 KBL_DPCM_AUDIO_HDMI1_PB
,
58 KBL_DPCM_AUDIO_HDMI2_PB
,
59 KBL_DPCM_AUDIO_HDMI3_PB
,
62 static const struct snd_kcontrol_new kabylake_controls
[] = {
63 SOC_DAPM_PIN_SWITCH("Headphone Jack"),
64 SOC_DAPM_PIN_SWITCH("Headset Mic"),
65 SOC_DAPM_PIN_SWITCH("Left Spk"),
66 SOC_DAPM_PIN_SWITCH("Right Spk"),
69 static int platform_clock_control(struct snd_soc_dapm_widget
*w
,
70 struct snd_kcontrol
*k
, int event
)
72 struct snd_soc_dapm_context
*dapm
= w
->dapm
;
73 struct snd_soc_card
*card
= dapm
->card
;
74 struct kbl_rt5663_private
*priv
= snd_soc_card_get_drvdata(card
);
78 * MCLK/SCLK need to be ON early for a successful synchronization of
79 * codec internal clock. And the clocks are turned off during
80 * POST_PMD after the stream is stopped.
83 case SND_SOC_DAPM_PRE_PMU
:
85 ret
= clk_set_rate(priv
->mclk
, 24000000);
87 dev_err(card
->dev
, "Can't set rate for mclk, err: %d\n",
92 ret
= clk_prepare_enable(priv
->mclk
);
94 dev_err(card
->dev
, "Can't enable mclk, err: %d\n", ret
);
99 ret
= clk_set_rate(priv
->sclk
, 3072000);
101 dev_err(card
->dev
, "Can't set rate for sclk, err: %d\n",
103 clk_disable_unprepare(priv
->mclk
);
107 ret
= clk_prepare_enable(priv
->sclk
);
109 dev_err(card
->dev
, "Can't enable sclk, err: %d\n", ret
);
110 clk_disable_unprepare(priv
->mclk
);
113 case SND_SOC_DAPM_POST_PMD
:
114 clk_disable_unprepare(priv
->mclk
);
115 clk_disable_unprepare(priv
->sclk
);
124 static const struct snd_soc_dapm_widget kabylake_widgets
[] = {
125 SND_SOC_DAPM_HP("Headphone Jack", NULL
),
126 SND_SOC_DAPM_MIC("Headset Mic", NULL
),
127 SND_SOC_DAPM_SPK("Left Spk", NULL
),
128 SND_SOC_DAPM_SPK("Right Spk", NULL
),
129 SND_SOC_DAPM_MIC("SoC DMIC", NULL
),
130 SND_SOC_DAPM_SPK("HDMI1", NULL
),
131 SND_SOC_DAPM_SPK("HDMI2", NULL
),
132 SND_SOC_DAPM_SPK("HDMI3", NULL
),
133 SND_SOC_DAPM_SUPPLY("Platform Clock", SND_SOC_NOPM
, 0, 0,
134 platform_clock_control
, SND_SOC_DAPM_PRE_PMU
|
135 SND_SOC_DAPM_POST_PMD
),
138 static const struct snd_soc_dapm_route kabylake_map
[] = {
139 /* HP jack connectors - unknown if we have jack detection */
140 { "Headphone Jack", NULL
, "Platform Clock" },
141 { "Headphone Jack", NULL
, "HPOL" },
142 { "Headphone Jack", NULL
, "HPOR" },
145 { "Left Spk", NULL
, "Left BE_OUT" },
146 { "Right Spk", NULL
, "Right BE_OUT" },
149 { "Headset Mic", NULL
, "Platform Clock" },
150 { "IN1P", NULL
, "Headset Mic" },
151 { "IN1N", NULL
, "Headset Mic" },
152 { "DMic", NULL
, "SoC DMIC" },
154 /* CODEC BE connections */
155 { "Left HiFi Playback", NULL
, "ssp0 Tx" },
156 { "Right HiFi Playback", NULL
, "ssp0 Tx" },
157 { "ssp0 Tx", NULL
, "spk_out" },
159 { "AIF Playback", NULL
, "ssp1 Tx" },
160 { "ssp1 Tx", NULL
, "codec1_out" },
162 { "hs_in", NULL
, "ssp1 Rx" },
163 { "ssp1 Rx", NULL
, "AIF Capture" },
165 /* IV feedback path */
166 { "codec0_fb_in", NULL
, "ssp0 Rx"},
167 { "ssp0 Rx", NULL
, "Left HiFi Capture" },
168 { "ssp0 Rx", NULL
, "Right HiFi Capture" },
171 { "dmic01_hifi", NULL
, "DMIC01 Rx" },
172 { "DMIC01 Rx", NULL
, "DMIC AIF" },
174 { "hifi3", NULL
, "iDisp3 Tx"},
175 { "iDisp3 Tx", NULL
, "iDisp3_out"},
176 { "hifi2", NULL
, "iDisp2 Tx"},
177 { "iDisp2 Tx", NULL
, "iDisp2_out"},
178 { "hifi1", NULL
, "iDisp1 Tx"},
179 { "iDisp1 Tx", NULL
, "iDisp1_out"},
183 KBL_DPCM_AUDIO_5663_PB
= 0,
184 KBL_DPCM_AUDIO_5663_CP
,
185 KBL_DPCM_AUDIO_5663_HDMI1_PB
,
186 KBL_DPCM_AUDIO_5663_HDMI2_PB
,
189 static const struct snd_kcontrol_new kabylake_5663_controls
[] = {
190 SOC_DAPM_PIN_SWITCH("Headphone Jack"),
191 SOC_DAPM_PIN_SWITCH("Headset Mic"),
194 static const struct snd_soc_dapm_widget kabylake_5663_widgets
[] = {
195 SND_SOC_DAPM_HP("Headphone Jack", NULL
),
196 SND_SOC_DAPM_MIC("Headset Mic", NULL
),
197 SND_SOC_DAPM_SPK("DP", NULL
),
198 SND_SOC_DAPM_SPK("HDMI", NULL
),
199 SND_SOC_DAPM_SUPPLY("Platform Clock", SND_SOC_NOPM
, 0, 0,
200 platform_clock_control
, SND_SOC_DAPM_PRE_PMU
|
201 SND_SOC_DAPM_POST_PMD
),
204 static const struct snd_soc_dapm_route kabylake_5663_map
[] = {
205 { "Headphone Jack", NULL
, "Platform Clock" },
206 { "Headphone Jack", NULL
, "HPOL" },
207 { "Headphone Jack", NULL
, "HPOR" },
210 { "Headset Mic", NULL
, "Platform Clock" },
211 { "IN1P", NULL
, "Headset Mic" },
212 { "IN1N", NULL
, "Headset Mic" },
214 { "HDMI", NULL
, "hif5 Output" },
215 { "DP", NULL
, "hif6 Output" },
217 /* CODEC BE connections */
218 { "AIF Playback", NULL
, "ssp1 Tx" },
219 { "ssp1 Tx", NULL
, "codec1_out" },
221 { "codec0_in", NULL
, "ssp1 Rx" },
222 { "ssp1 Rx", NULL
, "AIF Capture" },
224 { "hifi2", NULL
, "iDisp2 Tx"},
225 { "iDisp2 Tx", NULL
, "iDisp2_out"},
226 { "hifi1", NULL
, "iDisp1 Tx"},
227 { "iDisp1 Tx", NULL
, "iDisp1_out"},
230 static struct snd_soc_codec_conf max98927_codec_conf
[] = {
232 .dlc
= COMP_CODEC_CONF(MAXIM_DEV0_NAME
),
233 .name_prefix
= "Right",
236 .dlc
= COMP_CODEC_CONF(MAXIM_DEV1_NAME
),
237 .name_prefix
= "Left",
241 static int kabylake_rt5663_fe_init(struct snd_soc_pcm_runtime
*rtd
)
244 struct snd_soc_dapm_context
*dapm
;
245 struct snd_soc_component
*component
= rtd
->cpu_dai
->component
;
247 dapm
= snd_soc_component_get_dapm(component
);
248 ret
= snd_soc_dapm_ignore_suspend(dapm
, "Reference Capture");
250 dev_err(rtd
->dev
, "Ref Cap ignore suspend failed %d\n", ret
);
257 static int kabylake_rt5663_codec_init(struct snd_soc_pcm_runtime
*rtd
)
260 struct kbl_rt5663_private
*ctx
= snd_soc_card_get_drvdata(rtd
->card
);
261 struct snd_soc_component
*component
= rtd
->codec_dai
->component
;
262 struct snd_soc_jack
*jack
;
265 * Headset buttons map to the google Reference headset.
266 * These can be configured by userspace.
268 ret
= snd_soc_card_jack_new(kabylake_audio_card
, "Headset Jack",
269 SND_JACK_HEADSET
| SND_JACK_BTN_0
| SND_JACK_BTN_1
|
270 SND_JACK_BTN_2
| SND_JACK_BTN_3
, &ctx
->kabylake_headset
,
273 dev_err(rtd
->dev
, "Headset Jack creation failed %d\n", ret
);
277 jack
= &ctx
->kabylake_headset
;
278 snd_jack_set_key(jack
->jack
, SND_JACK_BTN_0
, KEY_PLAYPAUSE
);
279 snd_jack_set_key(jack
->jack
, SND_JACK_BTN_1
, KEY_VOICECOMMAND
);
280 snd_jack_set_key(jack
->jack
, SND_JACK_BTN_2
, KEY_VOLUMEUP
);
281 snd_jack_set_key(jack
->jack
, SND_JACK_BTN_3
, KEY_VOLUMEDOWN
);
283 snd_soc_component_set_jack(component
, &ctx
->kabylake_headset
, NULL
);
288 static int kabylake_rt5663_max98927_codec_init(struct snd_soc_pcm_runtime
*rtd
)
292 ret
= kabylake_rt5663_codec_init(rtd
);
296 ret
= snd_soc_dapm_ignore_suspend(&rtd
->card
->dapm
, "SoC DMIC");
298 dev_err(rtd
->dev
, "SoC DMIC ignore suspend failed %d\n", ret
);
305 static int kabylake_hdmi_init(struct snd_soc_pcm_runtime
*rtd
, int device
)
307 struct kbl_rt5663_private
*ctx
= snd_soc_card_get_drvdata(rtd
->card
);
308 struct snd_soc_dai
*dai
= rtd
->codec_dai
;
309 struct kbl_hdmi_pcm
*pcm
;
311 pcm
= devm_kzalloc(rtd
->card
->dev
, sizeof(*pcm
), GFP_KERNEL
);
315 pcm
->device
= device
;
316 pcm
->codec_dai
= dai
;
318 list_add_tail(&pcm
->head
, &ctx
->hdmi_pcm_list
);
323 static int kabylake_hdmi1_init(struct snd_soc_pcm_runtime
*rtd
)
325 return kabylake_hdmi_init(rtd
, KBL_DPCM_AUDIO_HDMI1_PB
);
328 static int kabylake_hdmi2_init(struct snd_soc_pcm_runtime
*rtd
)
330 return kabylake_hdmi_init(rtd
, KBL_DPCM_AUDIO_HDMI2_PB
);
333 static int kabylake_hdmi3_init(struct snd_soc_pcm_runtime
*rtd
)
335 return kabylake_hdmi_init(rtd
, KBL_DPCM_AUDIO_HDMI3_PB
);
338 static int kabylake_5663_hdmi1_init(struct snd_soc_pcm_runtime
*rtd
)
340 return kabylake_hdmi_init(rtd
, KBL_DPCM_AUDIO_5663_HDMI1_PB
);
343 static int kabylake_5663_hdmi2_init(struct snd_soc_pcm_runtime
*rtd
)
345 return kabylake_hdmi_init(rtd
, KBL_DPCM_AUDIO_5663_HDMI2_PB
);
348 static unsigned int rates
[] = {
352 static const struct snd_pcm_hw_constraint_list constraints_rates
= {
353 .count
= ARRAY_SIZE(rates
),
358 static unsigned int channels
[] = {
362 static const struct snd_pcm_hw_constraint_list constraints_channels
= {
363 .count
= ARRAY_SIZE(channels
),
368 static int kbl_fe_startup(struct snd_pcm_substream
*substream
)
370 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
373 * On this platform for PCM device we support,
379 runtime
->hw
.channels_max
= 2;
380 snd_pcm_hw_constraint_list(runtime
, 0, SNDRV_PCM_HW_PARAM_CHANNELS
,
381 &constraints_channels
);
383 runtime
->hw
.formats
= SNDRV_PCM_FMTBIT_S16_LE
;
384 snd_pcm_hw_constraint_msbits(runtime
, 0, 16, 16);
386 snd_pcm_hw_constraint_list(runtime
, 0,
387 SNDRV_PCM_HW_PARAM_RATE
, &constraints_rates
);
392 static const struct snd_soc_ops kabylake_rt5663_fe_ops
= {
393 .startup
= kbl_fe_startup
,
396 static int kabylake_ssp_fixup(struct snd_soc_pcm_runtime
*rtd
,
397 struct snd_pcm_hw_params
*params
)
399 struct snd_interval
*rate
= hw_param_interval(params
,
400 SNDRV_PCM_HW_PARAM_RATE
);
401 struct snd_interval
*chan
= hw_param_interval(params
,
402 SNDRV_PCM_HW_PARAM_CHANNELS
);
403 struct snd_mask
*fmt
= hw_param_mask(params
, SNDRV_PCM_HW_PARAM_FORMAT
);
404 struct snd_soc_dpcm
*dpcm
= container_of(
405 params
, struct snd_soc_dpcm
, hw_params
);
406 struct snd_soc_dai_link
*fe_dai_link
= dpcm
->fe
->dai_link
;
407 struct snd_soc_dai_link
*be_dai_link
= dpcm
->be
->dai_link
;
410 * The ADSP will convert the FE rate to 48k, stereo, 24 bit
412 if (!strcmp(fe_dai_link
->name
, "Kbl Audio Port") ||
413 !strcmp(fe_dai_link
->name
, "Kbl Audio Headset Playback") ||
414 !strcmp(fe_dai_link
->name
, "Kbl Audio Capture Port")) {
415 rate
->min
= rate
->max
= 48000;
416 chan
->min
= chan
->max
= 2;
418 snd_mask_set_format(fmt
, SNDRV_PCM_FORMAT_S24_LE
);
421 * The speaker on the SSP0 supports S16_LE and not S24_LE.
422 * thus changing the mask here
424 if (!strcmp(be_dai_link
->name
, "SSP0-Codec"))
425 snd_mask_set_format(fmt
, SNDRV_PCM_FORMAT_S16_LE
);
430 static int kabylake_rt5663_hw_params(struct snd_pcm_substream
*substream
,
431 struct snd_pcm_hw_params
*params
)
433 struct snd_soc_pcm_runtime
*rtd
= substream
->private_data
;
434 struct snd_soc_dai
*codec_dai
= rtd
->codec_dai
;
437 /* use ASRC for internal clocks, as PLL rate isn't multiple of BCLK */
438 rt5663_sel_asrc_clk_src(codec_dai
->component
,
439 RT5663_DA_STEREO_FILTER
| RT5663_AD_STEREO_FILTER
,
440 RT5663_CLK_SEL_I2S1_ASRC
);
442 ret
= snd_soc_dai_set_sysclk(codec_dai
,
443 RT5663_SCLK_S_MCLK
, 24576000, SND_SOC_CLOCK_IN
);
445 dev_err(rtd
->dev
, "snd_soc_dai_set_sysclk err = %d\n", ret
);
450 static struct snd_soc_ops kabylake_rt5663_ops
= {
451 .hw_params
= kabylake_rt5663_hw_params
,
454 static int kabylake_dmic_fixup(struct snd_soc_pcm_runtime
*rtd
,
455 struct snd_pcm_hw_params
*params
)
457 struct snd_interval
*chan
= hw_param_interval(params
,
458 SNDRV_PCM_HW_PARAM_CHANNELS
);
460 if (params_channels(params
) == 2 || DMIC_CH(dmic_constraints
) == 2)
461 chan
->min
= chan
->max
= 2;
463 chan
->min
= chan
->max
= 4;
468 static int kabylake_ssp0_hw_params(struct snd_pcm_substream
*substream
,
469 struct snd_pcm_hw_params
*params
)
471 struct snd_soc_pcm_runtime
*rtd
= substream
->private_data
;
472 struct snd_soc_dai
*codec_dai
;
475 for_each_rtd_codec_dai(rtd
, j
, codec_dai
) {
476 if (!strcmp(codec_dai
->component
->name
, MAXIM_DEV0_NAME
)) {
478 * Use channel 4 and 5 for the first amp
480 ret
= snd_soc_dai_set_tdm_slot(codec_dai
, 0x30, 3, 8, 16);
482 dev_err(rtd
->dev
, "set TDM slot err:%d\n", ret
);
486 if (!strcmp(codec_dai
->component
->name
, MAXIM_DEV1_NAME
)) {
488 * Use channel 6 and 7 for the second amp
490 ret
= snd_soc_dai_set_tdm_slot(codec_dai
, 0xC0, 3, 8, 16);
492 dev_err(rtd
->dev
, "set TDM slot err:%d\n", ret
);
500 static struct snd_soc_ops kabylake_ssp0_ops
= {
501 .hw_params
= kabylake_ssp0_hw_params
,
504 static unsigned int channels_dmic
[] = {
508 static struct snd_pcm_hw_constraint_list constraints_dmic_channels
= {
509 .count
= ARRAY_SIZE(channels_dmic
),
510 .list
= channels_dmic
,
514 static const unsigned int dmic_2ch
[] = {
518 static const struct snd_pcm_hw_constraint_list constraints_dmic_2ch
= {
519 .count
= ARRAY_SIZE(dmic_2ch
),
524 static int kabylake_dmic_startup(struct snd_pcm_substream
*substream
)
526 struct snd_pcm_runtime
*runtime
= substream
->runtime
;
528 runtime
->hw
.channels_max
= DMIC_CH(dmic_constraints
);
529 snd_pcm_hw_constraint_list(runtime
, 0, SNDRV_PCM_HW_PARAM_CHANNELS
,
532 return snd_pcm_hw_constraint_list(substream
->runtime
, 0,
533 SNDRV_PCM_HW_PARAM_RATE
, &constraints_rates
);
536 static struct snd_soc_ops kabylake_dmic_ops
= {
537 .startup
= kabylake_dmic_startup
,
540 static unsigned int rates_16000
[] = {
544 static const struct snd_pcm_hw_constraint_list constraints_16000
= {
545 .count
= ARRAY_SIZE(rates_16000
),
549 static const unsigned int ch_mono
[] = {
553 static const struct snd_pcm_hw_constraint_list constraints_refcap
= {
554 .count
= ARRAY_SIZE(ch_mono
),
558 static int kabylake_refcap_startup(struct snd_pcm_substream
*substream
)
560 substream
->runtime
->hw
.channels_max
= 1;
561 snd_pcm_hw_constraint_list(substream
->runtime
, 0,
562 SNDRV_PCM_HW_PARAM_CHANNELS
,
563 &constraints_refcap
);
565 return snd_pcm_hw_constraint_list(substream
->runtime
, 0,
566 SNDRV_PCM_HW_PARAM_RATE
,
570 static struct snd_soc_ops skylake_refcap_ops
= {
571 .startup
= kabylake_refcap_startup
,
574 SND_SOC_DAILINK_DEF(dummy
,
575 DAILINK_COMP_ARRAY(COMP_DUMMY()));
577 SND_SOC_DAILINK_DEF(system
,
578 DAILINK_COMP_ARRAY(COMP_CPU("System Pin")));
580 SND_SOC_DAILINK_DEF(system2
,
581 DAILINK_COMP_ARRAY(COMP_CPU("System Pin2")));
583 SND_SOC_DAILINK_DEF(echoref
,
584 DAILINK_COMP_ARRAY(COMP_CPU("Echoref Pin")));
586 SND_SOC_DAILINK_DEF(reference
,
587 DAILINK_COMP_ARRAY(COMP_CPU("Reference Pin")));
589 SND_SOC_DAILINK_DEF(dmic
,
590 DAILINK_COMP_ARRAY(COMP_CPU("DMIC Pin")));
592 SND_SOC_DAILINK_DEF(hdmi1
,
593 DAILINK_COMP_ARRAY(COMP_CPU("HDMI1 Pin")));
595 SND_SOC_DAILINK_DEF(hdmi2
,
596 DAILINK_COMP_ARRAY(COMP_CPU("HDMI2 Pin")));
598 SND_SOC_DAILINK_DEF(hdmi3
,
599 DAILINK_COMP_ARRAY(COMP_CPU("HDMI3 Pin")));
601 SND_SOC_DAILINK_DEF(ssp0_pin
,
602 DAILINK_COMP_ARRAY(COMP_CPU("SSP0 Pin")));
603 SND_SOC_DAILINK_DEF(ssp0_codec
,
605 /* Left */ COMP_CODEC(MAXIM_DEV0_NAME
, KBL_MAXIM_CODEC_DAI
),
606 /* Right */ COMP_CODEC(MAXIM_DEV1_NAME
, KBL_MAXIM_CODEC_DAI
)));
608 SND_SOC_DAILINK_DEF(ssp1_pin
,
609 DAILINK_COMP_ARRAY(COMP_CPU("SSP1 Pin")));
610 SND_SOC_DAILINK_DEF(ssp1_codec
,
611 DAILINK_COMP_ARRAY(COMP_CODEC("i2c-10EC5663:00",
612 KBL_REALTEK_CODEC_DAI
)));
614 SND_SOC_DAILINK_DEF(dmic01_pin
,
615 DAILINK_COMP_ARRAY(COMP_CPU("DMIC01 Pin")));
616 SND_SOC_DAILINK_DEF(dmic_codec
,
617 DAILINK_COMP_ARRAY(COMP_CODEC("dmic-codec", "dmic-hifi")));
619 SND_SOC_DAILINK_DEF(idisp1_pin
,
620 DAILINK_COMP_ARRAY(COMP_CPU("iDisp1 Pin")));
621 SND_SOC_DAILINK_DEF(idisp1_codec
,
622 DAILINK_COMP_ARRAY(COMP_CODEC("ehdaudio0D2", "intel-hdmi-hifi1")));
624 SND_SOC_DAILINK_DEF(idisp2_pin
,
625 DAILINK_COMP_ARRAY(COMP_CPU("iDisp2 Pin")));
626 SND_SOC_DAILINK_DEF(idisp2_codec
,
627 DAILINK_COMP_ARRAY(COMP_CODEC("ehdaudio0D2", "intel-hdmi-hifi2")));
629 SND_SOC_DAILINK_DEF(idisp3_pin
,
630 DAILINK_COMP_ARRAY(COMP_CPU("iDisp3 Pin")));
631 SND_SOC_DAILINK_DEF(idisp3_codec
,
632 DAILINK_COMP_ARRAY(COMP_CODEC("ehdaudio0D2", "intel-hdmi-hifi3")));
634 SND_SOC_DAILINK_DEF(platform
,
635 DAILINK_COMP_ARRAY(COMP_PLATFORM("0000:00:1f.3")));
637 /* kabylake digital audio interface glue - connects codec <--> CPU */
638 static struct snd_soc_dai_link kabylake_dais
[] = {
639 /* Front End DAI links */
640 [KBL_DPCM_AUDIO_PB
] = {
641 .name
= "Kbl Audio Port",
642 .stream_name
= "Audio",
645 .init
= kabylake_rt5663_fe_init
,
647 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
649 .ops
= &kabylake_rt5663_fe_ops
,
650 SND_SOC_DAILINK_REG(system
, dummy
, platform
),
652 [KBL_DPCM_AUDIO_CP
] = {
653 .name
= "Kbl Audio Capture Port",
654 .stream_name
= "Audio Record",
658 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
660 .ops
= &kabylake_rt5663_fe_ops
,
661 SND_SOC_DAILINK_REG(system
, dummy
, platform
),
663 [KBL_DPCM_AUDIO_HS_PB
] = {
664 .name
= "Kbl Audio Headset Playback",
665 .stream_name
= "Headset Audio",
669 SND_SOC_DAILINK_REG(system2
, dummy
, platform
),
671 [KBL_DPCM_AUDIO_ECHO_REF_CP
] = {
672 .name
= "Kbl Audio Echo Reference cap",
673 .stream_name
= "Echoreference Capture",
677 SND_SOC_DAILINK_REG(echoref
, dummy
, platform
),
679 [KBL_DPCM_AUDIO_REF_CP
] = {
680 .name
= "Kbl Audio Reference cap",
681 .stream_name
= "Wake on Voice",
686 .ops
= &skylake_refcap_ops
,
687 SND_SOC_DAILINK_REG(reference
, dummy
, platform
),
689 [KBL_DPCM_AUDIO_DMIC_CP
] = {
690 .name
= "Kbl Audio DMIC cap",
691 .stream_name
= "dmiccap",
696 .ops
= &kabylake_dmic_ops
,
697 SND_SOC_DAILINK_REG(dmic
, dummy
, platform
),
699 [KBL_DPCM_AUDIO_HDMI1_PB
] = {
700 .name
= "Kbl HDMI Port1",
701 .stream_name
= "Hdmi1",
705 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
708 SND_SOC_DAILINK_REG(hdmi1
, dummy
, platform
),
710 [KBL_DPCM_AUDIO_HDMI2_PB
] = {
711 .name
= "Kbl HDMI Port2",
712 .stream_name
= "Hdmi2",
716 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
719 SND_SOC_DAILINK_REG(hdmi2
, dummy
, platform
),
721 [KBL_DPCM_AUDIO_HDMI3_PB
] = {
722 .name
= "Kbl HDMI Port3",
723 .stream_name
= "Hdmi3",
725 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
730 SND_SOC_DAILINK_REG(hdmi3
, dummy
, platform
),
733 /* Back End DAI links */
736 .name
= "SSP0-Codec",
739 .dai_fmt
= SND_SOC_DAIFMT_DSP_B
|
740 SND_SOC_DAIFMT_NB_NF
|
741 SND_SOC_DAIFMT_CBS_CFS
,
742 .ignore_pmdown_time
= 1,
743 .be_hw_params_fixup
= kabylake_ssp_fixup
,
745 .ops
= &kabylake_ssp0_ops
,
746 SND_SOC_DAILINK_REG(ssp0_pin
, ssp0_codec
, platform
),
750 .name
= "SSP1-Codec",
753 .init
= kabylake_rt5663_max98927_codec_init
,
754 .dai_fmt
= SND_SOC_DAIFMT_I2S
| SND_SOC_DAIFMT_NB_NF
|
755 SND_SOC_DAIFMT_CBS_CFS
,
756 .ignore_pmdown_time
= 1,
757 .be_hw_params_fixup
= kabylake_ssp_fixup
,
758 .ops
= &kabylake_rt5663_ops
,
761 SND_SOC_DAILINK_REG(ssp1_pin
, ssp1_codec
, platform
),
766 .be_hw_params_fixup
= kabylake_dmic_fixup
,
770 SND_SOC_DAILINK_REG(dmic01_pin
, dmic_codec
, platform
),
776 .init
= kabylake_hdmi1_init
,
778 SND_SOC_DAILINK_REG(idisp1_pin
, idisp1_codec
, platform
),
783 .init
= kabylake_hdmi2_init
,
786 SND_SOC_DAILINK_REG(idisp2_pin
, idisp2_codec
, platform
),
791 .init
= kabylake_hdmi3_init
,
794 SND_SOC_DAILINK_REG(idisp3_pin
, idisp3_codec
, platform
),
798 static struct snd_soc_dai_link kabylake_5663_dais
[] = {
799 /* Front End DAI links */
800 [KBL_DPCM_AUDIO_5663_PB
] = {
801 .name
= "Kbl Audio Port",
802 .stream_name
= "Audio",
806 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
808 .ops
= &kabylake_rt5663_fe_ops
,
809 SND_SOC_DAILINK_REG(system
, dummy
, platform
),
811 [KBL_DPCM_AUDIO_5663_CP
] = {
812 .name
= "Kbl Audio Capture Port",
813 .stream_name
= "Audio Record",
817 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
819 .ops
= &kabylake_rt5663_fe_ops
,
820 SND_SOC_DAILINK_REG(system
, dummy
, platform
),
822 [KBL_DPCM_AUDIO_5663_HDMI1_PB
] = {
823 .name
= "Kbl HDMI Port1",
824 .stream_name
= "Hdmi1",
828 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
831 SND_SOC_DAILINK_REG(hdmi1
, dummy
, platform
),
833 [KBL_DPCM_AUDIO_5663_HDMI2_PB
] = {
834 .name
= "Kbl HDMI Port2",
835 .stream_name
= "Hdmi2",
839 SND_SOC_DPCM_TRIGGER_POST
, SND_SOC_DPCM_TRIGGER_POST
},
842 SND_SOC_DAILINK_REG(hdmi2
, dummy
, platform
),
845 /* Back End DAI links */
848 .name
= "SSP1-Codec",
851 .init
= kabylake_rt5663_codec_init
,
852 .dai_fmt
= SND_SOC_DAIFMT_I2S
| SND_SOC_DAIFMT_NB_NF
|
853 SND_SOC_DAIFMT_CBS_CFS
,
854 .ignore_pmdown_time
= 1,
855 .be_hw_params_fixup
= kabylake_ssp_fixup
,
856 .ops
= &kabylake_rt5663_ops
,
859 SND_SOC_DAILINK_REG(ssp1_pin
, ssp1_codec
, platform
),
865 .init
= kabylake_5663_hdmi1_init
,
867 SND_SOC_DAILINK_REG(idisp1_pin
, idisp1_codec
, platform
),
872 .init
= kabylake_5663_hdmi2_init
,
875 SND_SOC_DAILINK_REG(idisp2_pin
, idisp2_codec
, platform
),
880 static int kabylake_card_late_probe(struct snd_soc_card
*card
)
882 struct kbl_rt5663_private
*ctx
= snd_soc_card_get_drvdata(card
);
883 struct kbl_hdmi_pcm
*pcm
;
884 struct snd_soc_component
*component
= NULL
;
886 char jack_name
[NAME_SIZE
];
888 list_for_each_entry(pcm
, &ctx
->hdmi_pcm_list
, head
) {
889 component
= pcm
->codec_dai
->component
;
890 snprintf(jack_name
, sizeof(jack_name
),
891 "HDMI/DP, pcm=%d Jack", pcm
->device
);
892 err
= snd_soc_card_jack_new(card
, jack_name
,
893 SND_JACK_AVOUT
, &skylake_hdmi
[i
],
899 err
= hdac_hdmi_jack_init(pcm
->codec_dai
, pcm
->device
,
910 return hdac_hdmi_jack_port_init(component
, &card
->dapm
);
913 /* kabylake audio machine driver for SPT + RT5663 */
914 static struct snd_soc_card kabylake_audio_card_rt5663_m98927
= {
915 .name
= "kblrt5663max",
916 .owner
= THIS_MODULE
,
917 .dai_link
= kabylake_dais
,
918 .num_links
= ARRAY_SIZE(kabylake_dais
),
919 .controls
= kabylake_controls
,
920 .num_controls
= ARRAY_SIZE(kabylake_controls
),
921 .dapm_widgets
= kabylake_widgets
,
922 .num_dapm_widgets
= ARRAY_SIZE(kabylake_widgets
),
923 .dapm_routes
= kabylake_map
,
924 .num_dapm_routes
= ARRAY_SIZE(kabylake_map
),
925 .codec_conf
= max98927_codec_conf
,
926 .num_configs
= ARRAY_SIZE(max98927_codec_conf
),
927 .fully_routed
= true,
928 .late_probe
= kabylake_card_late_probe
,
931 /* kabylake audio machine driver for RT5663 */
932 static struct snd_soc_card kabylake_audio_card_rt5663
= {
934 .owner
= THIS_MODULE
,
935 .dai_link
= kabylake_5663_dais
,
936 .num_links
= ARRAY_SIZE(kabylake_5663_dais
),
937 .controls
= kabylake_5663_controls
,
938 .num_controls
= ARRAY_SIZE(kabylake_5663_controls
),
939 .dapm_widgets
= kabylake_5663_widgets
,
940 .num_dapm_widgets
= ARRAY_SIZE(kabylake_5663_widgets
),
941 .dapm_routes
= kabylake_5663_map
,
942 .num_dapm_routes
= ARRAY_SIZE(kabylake_5663_map
),
943 .fully_routed
= true,
944 .late_probe
= kabylake_card_late_probe
,
947 static int kabylake_audio_probe(struct platform_device
*pdev
)
949 struct kbl_rt5663_private
*ctx
;
950 struct snd_soc_acpi_mach
*mach
;
953 ctx
= devm_kzalloc(&pdev
->dev
, sizeof(*ctx
), GFP_KERNEL
);
957 INIT_LIST_HEAD(&ctx
->hdmi_pcm_list
);
959 kabylake_audio_card
=
960 (struct snd_soc_card
*)pdev
->id_entry
->driver_data
;
962 kabylake_audio_card
->dev
= &pdev
->dev
;
963 snd_soc_card_set_drvdata(kabylake_audio_card
, ctx
);
965 mach
= (&pdev
->dev
)->platform_data
;
967 dmic_constraints
= mach
->mach_params
.dmic_num
== 2 ?
968 &constraints_dmic_2ch
: &constraints_dmic_channels
;
970 ctx
->mclk
= devm_clk_get(&pdev
->dev
, "ssp1_mclk");
971 if (IS_ERR(ctx
->mclk
)) {
972 ret
= PTR_ERR(ctx
->mclk
);
973 if (ret
== -ENOENT
) {
975 "Failed to get ssp1_sclk, defer probe\n");
976 return -EPROBE_DEFER
;
979 dev_err(&pdev
->dev
, "Failed to get ssp1_mclk with err:%d\n",
984 ctx
->sclk
= devm_clk_get(&pdev
->dev
, "ssp1_sclk");
985 if (IS_ERR(ctx
->sclk
)) {
986 ret
= PTR_ERR(ctx
->sclk
);
987 if (ret
== -ENOENT
) {
989 "Failed to get ssp1_sclk, defer probe\n");
990 return -EPROBE_DEFER
;
993 dev_err(&pdev
->dev
, "Failed to get ssp1_sclk with err:%d\n",
998 return devm_snd_soc_register_card(&pdev
->dev
, kabylake_audio_card
);
1001 static const struct platform_device_id kbl_board_ids
[] = {
1003 .name
= "kbl_rt5663",
1004 .driver_data
= (kernel_ulong_t
)&kabylake_audio_card_rt5663
,
1007 .name
= "kbl_rt5663_m98927",
1009 (kernel_ulong_t
)&kabylake_audio_card_rt5663_m98927
,
1014 static struct platform_driver kabylake_audio
= {
1015 .probe
= kabylake_audio_probe
,
1017 .name
= "kbl_rt5663_m98927",
1018 .pm
= &snd_soc_pm_ops
,
1020 .id_table
= kbl_board_ids
,
1023 module_platform_driver(kabylake_audio
)
1025 /* Module information */
1026 MODULE_DESCRIPTION("Audio Machine driver-RT5663 & MAX98927 in I2S mode");
1027 MODULE_AUTHOR("Naveen M <naveen.m@intel.com>");
1028 MODULE_AUTHOR("Harsha Priya <harshapriya.n@intel.com>");
1029 MODULE_LICENSE("GPL v2");
1030 MODULE_ALIAS("platform:kbl_rt5663");
1031 MODULE_ALIAS("platform:kbl_rt5663_m98927");