diff options
Diffstat (limited to 'sound/soc/intel/boards')
| -rw-r--r-- | sound/soc/intel/boards/Kconfig | 195 | ||||
| -rw-r--r-- | sound/soc/intel/boards/bytcht_da7213.c | 4 | ||||
| -rw-r--r-- | sound/soc/intel/boards/bytcht_es8316.c | 26 | ||||
| -rw-r--r-- | sound/soc/intel/boards/bytcr_rt5640.c | 4 | ||||
| -rw-r--r-- | sound/soc/intel/boards/bytcr_rt5651.c | 50 | ||||
| -rw-r--r-- | sound/soc/intel/boards/cht_bsw_rt5645.c | 6 | ||||
| -rw-r--r-- | sound/soc/intel/boards/cht_bsw_rt5672.c | 4 | ||||
| -rw-r--r-- | sound/soc/intel/boards/haswell.c | 2 | ||||
| -rw-r--r-- | sound/soc/intel/boards/kbl_rt5663_max98927.c | 4 | ||||
| -rw-r--r-- | sound/soc/intel/boards/kbl_rt5663_rt5514_max98927.c | 4 | ||||
| -rw-r--r-- | sound/soc/intel/boards/mfld_machine.c | 428 | 
11 files changed, 179 insertions, 548 deletions
| diff --git a/sound/soc/intel/boards/Kconfig b/sound/soc/intel/boards/Kconfig index 6f754708a48c..d4e103615f51 100644 --- a/sound/soc/intel/boards/Kconfig +++ b/sound/soc/intel/boards/Kconfig @@ -1,183 +1,183 @@ -config SND_SOC_INTEL_MACH -	tristate "Intel Audio machine drivers" +menuconfig SND_SOC_INTEL_MACH +	bool "Intel Machine drivers"  	depends on SND_SOC_INTEL_SST_TOPLEVEL -	select SND_SOC_ACPI_INTEL_MATCH if ACPI +	help +         Intel ASoC Machine Drivers. If you have a Intel machine that +         has an audio controller with a DSP and I2S or DMIC port, then +         enable this option by saying Y + +         Note that the answer to this question doesn't directly affect the +         kernel: saying N will just cause the configurator to skip all +         the questions about Intel ASoC machine drivers.  if SND_SOC_INTEL_MACH -config SND_MFLD_MACHINE -	tristate "SOC Machine Audio driver for Intel Medfield MID platform" -	depends on INTEL_SCU_IPC -	select SND_SOC_SN95031 -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_PCI -	help -          This adds support for ASoC machine driver for Intel(R) MID Medfield platform -          used as alsa device in audio substem in Intel(R) MID devices -          Say Y if you have such a device. -          If unsure select "N". +if SND_SOC_INTEL_HASWELL  config SND_SOC_INTEL_HASWELL_MACH -	tristate "ASoC Audio DSP support for Intel Haswell Lynxpoint" +	tristate "Haswell Lynxpoint"  	depends on X86_INTEL_LPSS && I2C && I2C_DESIGNWARE_PLATFORM -	depends on SND_SOC_INTEL_HASWELL  	select SND_SOC_RT5640  	help  	  This adds support for the Lynxpoint Audio DSP on Intel(R) Haswell -	  Ultrabook platforms. -	  Say Y if you have such a device. +	  Ultrabook platforms. This is a recommended option. +	  Say Y or m if you have such a device.  	  If unsure select "N".  config SND_SOC_INTEL_BDW_RT5677_MACH -	tristate "ASoC Audio driver for Intel Broadwell with RT5677 codec" -	depends on X86_INTEL_LPSS && GPIOLIB && I2C -	depends on SND_SOC_INTEL_HASWELL +	tristate "Broadwell with RT5677 codec" +	depends on X86_INTEL_LPSS && I2C && I2C_DESIGNWARE_PLATFORM && GPIOLIB  	select SND_SOC_RT5677  	help  	  This adds support for Intel Broadwell platform based boards with -	  the RT5677 audio codec. +	  the RT5677 audio codec. This is a recommended option. +	  Say Y or m if you have such a device. +	  If unsure select "N".  config SND_SOC_INTEL_BROADWELL_MACH -	tristate "ASoC Audio DSP support for Intel Broadwell Wildcatpoint" +	tristate "Broadwell Wildcatpoint"  	depends on X86_INTEL_LPSS && I2C && I2C_DESIGNWARE_PLATFORM -	depends on SND_SOC_INTEL_HASWELL  	select SND_SOC_RT286  	help  	  This adds support for the Wilcatpoint Audio DSP on Intel(R) Broadwell  	  Ultrabook platforms. -	  Say Y if you have such a device. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N". +endif ## SND_SOC_INTEL_HASWELL + +if SND_SOC_INTEL_BAYTRAIL  config SND_SOC_INTEL_BYT_MAX98090_MACH -	tristate "ASoC Audio driver for Intel Baytrail with MAX98090 codec" +	tristate "Baytrail with MAX98090 codec"  	depends on X86_INTEL_LPSS && I2C -	depends on SND_SST_IPC_ACPI = n -	depends on SND_SOC_INTEL_BAYTRAIL  	select SND_SOC_MAX98090  	help  	  This adds audio driver for Intel Baytrail platform based boards -	  with the MAX98090 audio codec. +	  with the MAX98090 audio codec. This driver is deprecated, use +	  SND_SOC_INTEL_CHT_BSW_MAX98090_TI_MACH instead for better +	  functionality.  config SND_SOC_INTEL_BYT_RT5640_MACH -	tristate "ASoC Audio driver for Intel Baytrail with RT5640 codec" +	tristate "Baytrail with RT5640 codec"  	depends on X86_INTEL_LPSS && I2C -	depends on SND_SST_IPC_ACPI = n -	depends on SND_SOC_INTEL_BAYTRAIL  	select SND_SOC_RT5640  	help  	  This adds audio driver for Intel Baytrail platform based boards  	  with the RT5640 audio codec. This driver is deprecated, use  	  SND_SOC_INTEL_BYTCR_RT5640_MACH instead for better functionality. +endif ## SND_SOC_INTEL_BAYTRAIL + +if SND_SST_ATOM_HIFI2_PLATFORM +  config SND_SOC_INTEL_BYTCR_RT5640_MACH -        tristate "ASoC Audio driver for Intel Baytrail and Baytrail-CR with RT5640 codec" -	depends on X86 && I2C && ACPI +	tristate "Baytrail and Baytrail-CR with RT5640 codec" +	depends on X86_INTEL_LPSS && I2C && ACPI +	select SND_SOC_ACPI  	select SND_SOC_RT5640 -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help -          This adds support for ASoC machine driver for Intel(R) Baytrail and Baytrail-CR -          platforms with RT5640 audio codec. -          Say Y if you have such a device. -          If unsure select "N". +	  This adds support for ASoC machine driver for Intel(R) Baytrail and Baytrail-CR +	  platforms with RT5640 audio codec. +	  Say Y or m if you have such a device. This is a recommended option. +	  If unsure select "N".  config SND_SOC_INTEL_BYTCR_RT5651_MACH -        tristate "ASoC Audio driver for Intel Baytrail and Baytrail-CR with RT5651 codec" -	depends on X86 && I2C && ACPI +	tristate "Baytrail and Baytrail-CR with RT5651 codec" +	depends on X86_INTEL_LPSS && I2C && ACPI +	select SND_SOC_ACPI  	select SND_SOC_RT5651 -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help -          This adds support for ASoC machine driver for Intel(R) Baytrail and Baytrail-CR -          platforms with RT5651 audio codec. -          Say Y if you have such a device. -          If unsure select "N". +	  This adds support for ASoC machine driver for Intel(R) Baytrail and Baytrail-CR +	  platforms with RT5651 audio codec. +	  Say Y or m if you have such a device. This is a recommended option. +	  If unsure select "N".  config SND_SOC_INTEL_CHT_BSW_RT5672_MACH -        tristate "ASoC Audio driver for Intel Cherrytrail & Braswell with RT5672 codec" +	tristate "Cherrytrail & Braswell with RT5672 codec"  	depends on X86_INTEL_LPSS && I2C && ACPI -        select SND_SOC_RT5670 -        depends on SND_SST_ATOM_HIFI2_PLATFORM -        select SND_SST_IPC_ACPI +	select SND_SOC_ACPI +	select SND_SOC_RT5670          help            This adds support for ASoC machine driver for Intel(R) Cherrytrail & Braswell            platforms with RT5672 audio codec. -          Say Y if you have such a device. +          Say Y or m if you have such a device. This is a recommended option.            If unsure select "N".  config SND_SOC_INTEL_CHT_BSW_RT5645_MACH -	tristate "ASoC Audio driver for Intel Cherrytrail & Braswell with RT5645/5650 codec" +	tristate "Cherrytrail & Braswell with RT5645/5650 codec"  	depends on X86_INTEL_LPSS && I2C && ACPI +	select SND_SOC_ACPI  	select SND_SOC_RT5645 -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help  	  This adds support for ASoC machine driver for Intel(R) Cherrytrail & Braswell  	  platforms with RT5645/5650 audio codec. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_CHT_BSW_MAX98090_TI_MACH -	tristate "ASoC Audio driver for Intel Cherrytrail & Braswell with MAX98090 & TI codec" +	tristate "Cherrytrail & Braswell with MAX98090 & TI codec"  	depends on X86_INTEL_LPSS && I2C && ACPI  	select SND_SOC_MAX98090  	select SND_SOC_TS3A227E -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help  	  This adds support for ASoC machine driver for Intel(R) Cherrytrail & Braswell  	  platforms with MAX98090 audio codec it also can support TI jack chip as aux device. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_BYT_CHT_DA7213_MACH -	tristate "ASoC Audio driver for Intel Baytrail & Cherrytrail with DA7212/7213 codec" +	tristate "Baytrail & Cherrytrail with DA7212/7213 codec"  	depends on X86_INTEL_LPSS && I2C && ACPI +	select SND_SOC_ACPI  	select SND_SOC_DA7213 -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help  	  This adds support for ASoC machine driver for Intel(R) Baytrail & CherryTrail  	  platforms with DA7212/7213 audio codec. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_BYT_CHT_ES8316_MACH -	tristate "ASoC Audio driver for Intel Baytrail & Cherrytrail with ES8316 codec" +	tristate "Baytrail & Cherrytrail with ES8316 codec"  	depends on X86_INTEL_LPSS && I2C && ACPI +	select SND_SOC_ACPI  	select SND_SOC_ES8316 -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help  	  This adds support for ASoC machine driver for Intel(R) Baytrail &  	  Cherrytrail platforms with ES8316 audio codec. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_BYT_CHT_NOCODEC_MACH -	tristate "ASoC Audio driver for Intel Baytrail & Cherrytrail platform with no codec (MinnowBoard MAX, Up)" +	tristate "Baytrail & Cherrytrail platform with no codec (MinnowBoard MAX, Up)"  	depends on X86_INTEL_LPSS && I2C && ACPI -	depends on SND_SST_ATOM_HIFI2_PLATFORM -	select SND_SST_IPC_ACPI  	help  	  This adds support for ASoC machine driver for the MinnowBoard Max or  	  Up boards and provides access to I2S signals on the Low-Speed -	  connector +	  connector. This is not a recommended option outside of these cases. +	  It is not intended to be enabled by distros by default. +	  Say Y or m if you have such a device. +  	  If unsure select "N". +endif ## SND_SST_ATOM_HIFI2_PLATFORM + +if SND_SOC_INTEL_SKYLAKE +  config SND_SOC_INTEL_SKL_RT286_MACH -	tristate "ASoC Audio driver for SKL with RT286 I2S mode" -	depends on X86 && ACPI && I2C -	depends on SND_SOC_INTEL_SKYLAKE +	tristate "SKL with RT286 I2S mode" +	depends on MFD_INTEL_LPSS && I2C && ACPI  	select SND_SOC_RT286  	select SND_SOC_DMIC  	select SND_SOC_HDAC_HDMI  	help  	   This adds support for ASoC machine driver for Skylake platforms  	   with RT286 I2S audio codec. -	   Say Y if you have such a device. +	   Say Y or m if you have such a device.  	   If unsure select "N".  config SND_SOC_INTEL_SKL_NAU88L25_SSM4567_MACH -	tristate "ASoC Audio driver for SKL with NAU88L25 and SSM4567 in I2S Mode" -	depends on X86_INTEL_LPSS && I2C -	depends on SND_SOC_INTEL_SKYLAKE +	tristate "SKL with NAU88L25 and SSM4567 in I2S Mode" +	depends on MFD_INTEL_LPSS && I2C && ACPI  	select SND_SOC_NAU8825  	select SND_SOC_SSM4567  	select SND_SOC_DMIC @@ -185,13 +185,12 @@ config SND_SOC_INTEL_SKL_NAU88L25_SSM4567_MACH  	help  	  This adds support for ASoC Onboard Codec I2S machine driver. This will  	  create an alsa sound card for NAU88L25 + SSM4567. -	  Say Y if you have such a device. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_SKL_NAU88L25_MAX98357A_MACH -	tristate "ASoC Audio driver for SKL with NAU88L25 and MAX98357A in I2S Mode" -	depends on X86_INTEL_LPSS && I2C -	depends on SND_SOC_INTEL_SKYLAKE +	tristate "SKL with NAU88L25 and MAX98357A in I2S Mode" +	depends on MFD_INTEL_LPSS && I2C && ACPI  	select SND_SOC_NAU8825  	select SND_SOC_MAX98357A  	select SND_SOC_DMIC @@ -199,13 +198,12 @@ config SND_SOC_INTEL_SKL_NAU88L25_MAX98357A_MACH  	help  	  This adds support for ASoC Onboard Codec I2S machine driver. This will  	  create an alsa sound card for NAU88L25 + MAX98357A. -	  Say Y if you have such a device. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_BXT_DA7219_MAX98357A_MACH -	tristate "ASoC Audio driver for Broxton with DA7219 and MAX98357A in I2S Mode" -	depends on X86 && ACPI && I2C -	depends on SND_SOC_INTEL_SKYLAKE +	tristate "Broxton with DA7219 and MAX98357A in I2S Mode" +	depends on MFD_INTEL_LPSS && I2C && ACPI  	select SND_SOC_DA7219  	select SND_SOC_MAX98357A  	select SND_SOC_DMIC @@ -214,13 +212,12 @@ config SND_SOC_INTEL_BXT_DA7219_MAX98357A_MACH  	help  	   This adds support for ASoC machine driver for Broxton-P platforms  	   with DA7219 + MAX98357A I2S audio codec. -	   Say Y if you have such a device. +	   Say Y or m if you have such a device. This is a recommended option.  	   If unsure select "N".  config SND_SOC_INTEL_BXT_RT298_MACH -	tristate "ASoC Audio driver for Broxton with RT298 I2S mode" -	depends on X86 && ACPI && I2C -	depends on SND_SOC_INTEL_SKYLAKE +	tristate "Broxton with RT298 I2S mode" +	depends on MFD_INTEL_LPSS && I2C && ACPI  	select SND_SOC_RT298  	select SND_SOC_DMIC  	select SND_SOC_HDAC_HDMI @@ -228,14 +225,12 @@ config SND_SOC_INTEL_BXT_RT298_MACH  	help  	   This adds support for ASoC machine driver for Broxton platforms  	   with RT286 I2S audio codec. -	   Say Y if you have such a device. +	   Say Y or m if you have such a device. This is a recommended option.  	   If unsure select "N".  config SND_SOC_INTEL_KBL_RT5663_MAX98927_MACH -	tristate "ASoC Audio driver for KBL with RT5663 and MAX98927 in I2S Mode" -	depends on X86_INTEL_LPSS && I2C -	select SND_SOC_INTEL_SST -	depends on SND_SOC_INTEL_SKYLAKE +	tristate "KBL with RT5663 and MAX98927 in I2S Mode" +	depends on MFD_INTEL_LPSS && I2C && ACPI  	select SND_SOC_RT5663  	select SND_SOC_MAX98927  	select SND_SOC_DMIC @@ -243,14 +238,13 @@ config SND_SOC_INTEL_KBL_RT5663_MAX98927_MACH  	help  	  This adds support for ASoC Onboard Codec I2S machine driver. This will  	  create an alsa sound card for RT5663 + MAX98927. -	  Say Y if you have such a device. +	  Say Y or m if you have such a device. This is a recommended option.  	  If unsure select "N".  config SND_SOC_INTEL_KBL_RT5663_RT5514_MAX98927_MACH -        tristate "ASoC Audio driver for KBL with RT5663, RT5514 and MAX98927 in I2S Mode" -        depends on X86_INTEL_LPSS && I2C && SPI -        select SND_SOC_INTEL_SST -        depends on SND_SOC_INTEL_SKYLAKE +        tristate "KBL with RT5663, RT5514 and MAX98927 in I2S Mode" +        depends on MFD_INTEL_LPSS && I2C && ACPI +        depends on SPI          select SND_SOC_RT5663          select SND_SOC_RT5514          select SND_SOC_RT5514_SPI @@ -259,7 +253,8 @@ config SND_SOC_INTEL_KBL_RT5663_RT5514_MAX98927_MACH          help            This adds support for ASoC Onboard Codec I2S machine driver. This will            create an alsa sound card for RT5663 + RT5514 + MAX98927. -          Say Y if you have such a device. +          Say Y or m if you have such a device. This is a recommended option.            If unsure select "N". +endif ## SND_SOC_INTEL_SKYLAKE -endif +endif ## SND_SOC_INTEL_MACH diff --git a/sound/soc/intel/boards/bytcht_da7213.c b/sound/soc/intel/boards/bytcht_da7213.c index c4d82ad41bd7..2179dedb28ad 100644 --- a/sound/soc/intel/boards/bytcht_da7213.c +++ b/sound/soc/intel/boards/bytcht_da7213.c @@ -219,7 +219,7 @@ static struct snd_soc_card bytcht_da7213_card = {  	.num_dapm_routes = ARRAY_SIZE(audio_map),  }; -static char codec_name[16]; /* i2c-<HID>:00 with HID being 8 chars */ +static char codec_name[SND_ACPI_I2C_ID_LEN];  static int bytcht_da7213_probe(struct platform_device *pdev)  { @@ -243,7 +243,7 @@ static int bytcht_da7213_probe(struct platform_device *pdev)  	}  	/* fixup codec name based on HID */ -	i2c_name = snd_soc_acpi_find_name_from_hid(mach->id); +	i2c_name = acpi_dev_get_first_match_name(mach->id, NULL, -1);  	if (i2c_name) {  		snprintf(codec_name, sizeof(codec_name),  			"%s%s", "i2c-", i2c_name); diff --git a/sound/soc/intel/boards/bytcht_es8316.c b/sound/soc/intel/boards/bytcht_es8316.c index 8088396717e3..305e7f4fe55a 100644 --- a/sound/soc/intel/boards/bytcht_es8316.c +++ b/sound/soc/intel/boards/bytcht_es8316.c @@ -232,15 +232,39 @@ static struct snd_soc_card byt_cht_es8316_card = {  	.fully_routed = true,  }; +static char codec_name[SND_ACPI_I2C_ID_LEN]; +  static int snd_byt_cht_es8316_mc_probe(struct platform_device *pdev)  { -	int ret = 0;  	struct byt_cht_es8316_private *priv; +	struct snd_soc_acpi_mach *mach; +	const char *i2c_name = NULL; +	int dai_index = 0; +	int i; +	int ret = 0;  	priv = devm_kzalloc(&pdev->dev, sizeof(*priv), GFP_ATOMIC);  	if (!priv)  		return -ENOMEM; +	mach = (&pdev->dev)->platform_data; +	/* fix index of codec dai */ +	for (i = 0; i < ARRAY_SIZE(byt_cht_es8316_dais); i++) { +		if (!strcmp(byt_cht_es8316_dais[i].codec_name, +			    "i2c-ESSX8316:00")) { +			dai_index = i; +			break; +		} +	} + +	/* fixup codec name based on HID */ +	i2c_name = acpi_dev_get_first_match_name(mach->id, NULL, -1); +	if (i2c_name) { +		snprintf(codec_name, sizeof(codec_name), +			"%s%s", "i2c-", i2c_name); +		byt_cht_es8316_dais[dai_index].codec_name = codec_name; +	} +  	/* register the soc card */  	byt_cht_es8316_card.dev = &pdev->dev;  	snd_soc_card_set_drvdata(&byt_cht_es8316_card, priv); diff --git a/sound/soc/intel/boards/bytcr_rt5640.c b/sound/soc/intel/boards/bytcr_rt5640.c index f2c0fc415e52..b6a1cfeec830 100644 --- a/sound/soc/intel/boards/bytcr_rt5640.c +++ b/sound/soc/intel/boards/bytcr_rt5640.c @@ -713,7 +713,7 @@ static struct snd_soc_card byt_rt5640_card = {  	.fully_routed = true,  }; -static char byt_rt5640_codec_name[16]; /* i2c-<HID>:00 with HID being 8 chars */ +static char byt_rt5640_codec_name[SND_ACPI_I2C_ID_LEN];  static char byt_rt5640_codec_aif_name[12]; /*  = "rt5640-aif[1|2]" */  static char byt_rt5640_cpu_dai_name[10]; /*  = "ssp[0|2]-port" */ @@ -762,7 +762,7 @@ static int snd_byt_rt5640_mc_probe(struct platform_device *pdev)  	}  	/* fixup codec name based on HID */ -	i2c_name = snd_soc_acpi_find_name_from_hid(mach->id); +	i2c_name = acpi_dev_get_first_match_name(mach->id, NULL, -1);  	if (i2c_name) {  		snprintf(byt_rt5640_codec_name, sizeof(byt_rt5640_codec_name),  			"%s%s", "i2c-", i2c_name); diff --git a/sound/soc/intel/boards/bytcr_rt5651.c b/sound/soc/intel/boards/bytcr_rt5651.c index d955836c6870..456526a93dd5 100644 --- a/sound/soc/intel/boards/bytcr_rt5651.c +++ b/sound/soc/intel/boards/bytcr_rt5651.c @@ -38,6 +38,8 @@ enum {  	BYT_RT5651_DMIC_MAP,  	BYT_RT5651_IN1_MAP,  	BYT_RT5651_IN2_MAP, +	BYT_RT5651_IN1_IN2_MAP, +	BYT_RT5651_IN3_MAP,  };  #define BYT_RT5651_MAP(quirk)	((quirk) & GENMASK(7, 0)) @@ -62,6 +64,8 @@ static void log_quirks(struct device *dev)  		dev_info(dev, "quirk IN1_MAP enabled");  	if (BYT_RT5651_MAP(byt_rt5651_quirk) == BYT_RT5651_IN2_MAP)  		dev_info(dev, "quirk IN2_MAP enabled"); +	if (BYT_RT5651_MAP(byt_rt5651_quirk) == BYT_RT5651_IN3_MAP) +		dev_info(dev, "quirk IN3_MAP enabled");  	if (byt_rt5651_quirk & BYT_RT5651_DMIC_EN)  		dev_info(dev, "quirk DMIC enabled");  	if (byt_rt5651_quirk & BYT_RT5651_MCLK_EN) @@ -127,6 +131,7 @@ static const struct snd_soc_dapm_widget byt_rt5651_widgets[] = {  	SND_SOC_DAPM_MIC("Headset Mic", NULL),  	SND_SOC_DAPM_MIC("Internal Mic", NULL),  	SND_SOC_DAPM_SPK("Speaker", NULL), +	SND_SOC_DAPM_LINE("Line In", NULL),  	SND_SOC_DAPM_SUPPLY("Platform Clock", SND_SOC_NOPM, 0, 0,  			    platform_clock_control, SND_SOC_DAPM_PRE_PMU |  			    SND_SOC_DAPM_POST_PMD), @@ -138,6 +143,7 @@ static const struct snd_soc_dapm_route byt_rt5651_audio_map[] = {  	{"Headset Mic", NULL, "Platform Clock"},  	{"Internal Mic", NULL, "Platform Clock"},  	{"Speaker", NULL, "Platform Clock"}, +	{"Line In", NULL, "Platform Clock"},  	{"AIF1 Playback", NULL, "ssp2 Tx"},  	{"ssp2 Tx", NULL, "codec_out0"}, @@ -151,6 +157,9 @@ static const struct snd_soc_dapm_route byt_rt5651_audio_map[] = {  	{"Headphone", NULL, "HPOR"},  	{"Speaker", NULL, "LOUTL"},  	{"Speaker", NULL, "LOUTR"}, +	{"IN2P", NULL, "Line In"}, +	{"IN2N", NULL, "Line In"}, +  };  static const struct snd_soc_dapm_route byt_rt5651_intmic_dmic_map[] = { @@ -171,11 +180,25 @@ static const struct snd_soc_dapm_route byt_rt5651_intmic_in2_map[] = {  	{"IN2P", NULL, "Internal Mic"},  }; +static const struct snd_soc_dapm_route byt_rt5651_intmic_in1_in2_map[] = { +	{"Internal Mic", NULL, "micbias1"}, +	{"IN1P", NULL, "Internal Mic"}, +	{"IN2P", NULL, "Internal Mic"}, +	{"IN3P", NULL, "Headset Mic"}, +}; + +static const struct snd_soc_dapm_route byt_rt5651_intmic_in3_map[] = { +	{"Internal Mic", NULL, "micbias1"}, +	{"IN3P", NULL, "Headset Mic"}, +	{"IN1P", NULL, "Internal Mic"}, +}; +  static const struct snd_kcontrol_new byt_rt5651_controls[] = {  	SOC_DAPM_PIN_SWITCH("Headphone"),  	SOC_DAPM_PIN_SWITCH("Headset Mic"),  	SOC_DAPM_PIN_SWITCH("Internal Mic"),  	SOC_DAPM_PIN_SWITCH("Speaker"), +	SOC_DAPM_PIN_SWITCH("Line In"),  };  static struct snd_soc_jack_pin bytcr_jack_pins[] = { @@ -247,8 +270,16 @@ static const struct dmi_system_id byt_rt5651_quirk_table[] = {  			DMI_MATCH(DMI_SYS_VENDOR, "Circuitco"),  			DMI_MATCH(DMI_PRODUCT_NAME, "Minnowboard Max B3 PLATFORM"),  		}, -		.driver_data = (void *)(BYT_RT5651_DMIC_MAP | -					BYT_RT5651_DMIC_EN), +		.driver_data = (void *)(BYT_RT5651_IN3_MAP), +	}, +	{ +		.callback = byt_rt5651_quirk_cb, +		.matches = { +			DMI_MATCH(DMI_SYS_VENDOR, "ADI"), +			DMI_MATCH(DMI_PRODUCT_NAME, "Minnowboard Turbot"), +		}, +		.driver_data = (void *)(BYT_RT5651_MCLK_EN | +					BYT_RT5651_IN3_MAP),  	},  	{  		.callback = byt_rt5651_quirk_cb, @@ -256,7 +287,8 @@ static const struct dmi_system_id byt_rt5651_quirk_table[] = {  			DMI_MATCH(DMI_SYS_VENDOR, "KIANO"),  			DMI_MATCH(DMI_PRODUCT_NAME, "KIANO SlimNote 14.2"),  		}, -		.driver_data = (void *)(BYT_RT5651_IN2_MAP), +		.driver_data = (void *)(BYT_RT5651_MCLK_EN | +					BYT_RT5651_IN1_IN2_MAP),  	},  	{}  }; @@ -281,6 +313,14 @@ static int byt_rt5651_init(struct snd_soc_pcm_runtime *runtime)  		custom_map = byt_rt5651_intmic_in2_map;  		num_routes = ARRAY_SIZE(byt_rt5651_intmic_in2_map);  		break; +	case BYT_RT5651_IN1_IN2_MAP: +		custom_map = byt_rt5651_intmic_in1_in2_map; +		num_routes = ARRAY_SIZE(byt_rt5651_intmic_in1_in2_map); +		break; +	case BYT_RT5651_IN3_MAP: +		custom_map = byt_rt5651_intmic_in3_map; +		num_routes = ARRAY_SIZE(byt_rt5651_intmic_in3_map); +		break;  	default:  		custom_map = byt_rt5651_intmic_dmic_map;  		num_routes = ARRAY_SIZE(byt_rt5651_intmic_dmic_map); @@ -469,7 +509,7 @@ static struct snd_soc_card byt_rt5651_card = {  	.fully_routed = true,  }; -static char byt_rt5651_codec_name[16]; /* i2c-<HID>:00 with HID being 8 chars */ +static char byt_rt5651_codec_name[SND_ACPI_I2C_ID_LEN];  static int snd_byt_rt5651_mc_probe(struct platform_device *pdev)  { @@ -499,7 +539,7 @@ static int snd_byt_rt5651_mc_probe(struct platform_device *pdev)  	}  	/* fixup codec name based on HID */ -	i2c_name = snd_soc_acpi_find_name_from_hid(mach->id); +	i2c_name = acpi_dev_get_first_match_name(mach->id, NULL, -1);  	if (i2c_name) {  		snprintf(byt_rt5651_codec_name, sizeof(byt_rt5651_codec_name),  			"%s%s", "i2c-", i2c_name); diff --git a/sound/soc/intel/boards/cht_bsw_rt5645.c b/sound/soc/intel/boards/cht_bsw_rt5645.c index 18d129caa974..976ea6bf9539 100644 --- a/sound/soc/intel/boards/cht_bsw_rt5645.c +++ b/sound/soc/intel/boards/cht_bsw_rt5645.c @@ -49,7 +49,7 @@ struct cht_acpi_card {  struct cht_mc_private {  	struct snd_soc_jack jack;  	struct cht_acpi_card *acpi_card; -	char codec_name[16]; +	char codec_name[SND_ACPI_I2C_ID_LEN];  	struct clk *mclk;  }; @@ -499,7 +499,7 @@ static struct cht_acpi_card snd_soc_cards[] = {  	{"10EC5650", CODEC_TYPE_RT5650, &snd_soc_card_chtrt5650},  }; -static char cht_rt5645_codec_name[16]; /* i2c-<HID>:00 with HID being 8 chars */ +static char cht_rt5645_codec_name[SND_ACPI_I2C_ID_LEN];  static char cht_rt5645_codec_aif_name[12]; /*  = "rt5645-aif[1|2]" */  static char cht_rt5645_cpu_dai_name[10]; /*  = "ssp[0|2]-port" */ @@ -566,7 +566,7 @@ static int snd_cht_mc_probe(struct platform_device *pdev)  		}  	/* fixup codec name based on HID */ -	i2c_name = snd_soc_acpi_find_name_from_hid(mach->id); +	i2c_name = acpi_dev_get_first_match_name(mach->id, NULL, -1);  	if (i2c_name) {  		snprintf(cht_rt5645_codec_name, sizeof(cht_rt5645_codec_name),  			"%s%s", "i2c-", i2c_name); diff --git a/sound/soc/intel/boards/cht_bsw_rt5672.c b/sound/soc/intel/boards/cht_bsw_rt5672.c index f8f21eee9b2d..c14a52d2f714 100644 --- a/sound/soc/intel/boards/cht_bsw_rt5672.c +++ b/sound/soc/intel/boards/cht_bsw_rt5672.c @@ -35,7 +35,7 @@  struct cht_mc_private {  	struct snd_soc_jack headset; -	char codec_name[16]; +	char codec_name[SND_ACPI_I2C_ID_LEN];  	struct clk *mclk;  }; @@ -396,7 +396,7 @@ static int snd_cht_mc_probe(struct platform_device *pdev)  	/* fixup codec name based on HID */  	if (mach) { -		i2c_name = snd_soc_acpi_find_name_from_hid(mach->id); +		i2c_name = acpi_dev_get_first_match_name(mach->id, NULL, -1);  		if (i2c_name) {  			snprintf(drv->codec_name, sizeof(drv->codec_name),  				 "i2c-%s", i2c_name); diff --git a/sound/soc/intel/boards/haswell.c b/sound/soc/intel/boards/haswell.c index 5e1ea0371c90..3c5160779204 100644 --- a/sound/soc/intel/boards/haswell.c +++ b/sound/soc/intel/boards/haswell.c @@ -76,7 +76,7 @@ static int haswell_rt5640_hw_params(struct snd_pcm_substream *substream,  	}  	/* set correct codec filter for DAI format and clock config */ -	snd_soc_update_bits(rtd->codec, 0x83, 0xffff, 0x8000); +	snd_soc_component_update_bits(codec_dai->component, 0x83, 0xffff, 0x8000);  	return ret;  } diff --git a/sound/soc/intel/boards/kbl_rt5663_max98927.c b/sound/soc/intel/boards/kbl_rt5663_max98927.c index 6f9a8bcf20f3..bf7014ca486f 100644 --- a/sound/soc/intel/boards/kbl_rt5663_max98927.c +++ b/sound/soc/intel/boards/kbl_rt5663_max98927.c @@ -101,7 +101,7 @@ static const struct snd_soc_dapm_route kabylake_map[] = {  	{ "ssp0 Tx", NULL, "spk_out" },  	{ "AIF Playback", NULL, "ssp1 Tx" }, -	{ "ssp1 Tx", NULL, "hs_out" }, +	{ "ssp1 Tx", NULL, "codec1_out" },  	{ "hs_in", NULL, "ssp1 Rx" },  	{ "ssp1 Rx", NULL, "AIF Capture" }, @@ -225,7 +225,7 @@ static int kabylake_rt5663_codec_init(struct snd_soc_pcm_runtime *rtd)  	}  	jack = &ctx->kabylake_headset; -	snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_MEDIA); +	snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_PLAYPAUSE);  	snd_jack_set_key(jack->jack, SND_JACK_BTN_1, KEY_VOICECOMMAND);  	snd_jack_set_key(jack->jack, SND_JACK_BTN_2, KEY_VOLUMEUP);  	snd_jack_set_key(jack->jack, SND_JACK_BTN_3, KEY_VOLUMEDOWN); diff --git a/sound/soc/intel/boards/kbl_rt5663_rt5514_max98927.c b/sound/soc/intel/boards/kbl_rt5663_rt5514_max98927.c index 6072164f2d43..90ea98f01c4c 100644 --- a/sound/soc/intel/boards/kbl_rt5663_rt5514_max98927.c +++ b/sound/soc/intel/boards/kbl_rt5663_rt5514_max98927.c @@ -109,7 +109,7 @@ static const struct snd_soc_dapm_route kabylake_map[] = {  	{ "ssp0 Tx", NULL, "spk_out" },  	{ "AIF Playback", NULL, "ssp1 Tx" }, -	{ "ssp1 Tx", NULL, "hs_out" }, +	{ "ssp1 Tx", NULL, "codec1_out" },  	{ "hs_in", NULL, "ssp1 Rx" },  	{ "ssp1 Rx", NULL, "AIF Capture" }, @@ -195,7 +195,7 @@ static int kabylake_rt5663_codec_init(struct snd_soc_pcm_runtime *rtd)  	}  	jack = &ctx->kabylake_headset; -	snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_MEDIA); +	snd_jack_set_key(jack->jack, SND_JACK_BTN_0, KEY_PLAYPAUSE);  	snd_jack_set_key(jack->jack, SND_JACK_BTN_1, KEY_VOICECOMMAND);  	snd_jack_set_key(jack->jack, SND_JACK_BTN_2, KEY_VOLUMEUP);  	snd_jack_set_key(jack->jack, SND_JACK_BTN_3, KEY_VOLUMEDOWN); diff --git a/sound/soc/intel/boards/mfld_machine.c b/sound/soc/intel/boards/mfld_machine.c deleted file mode 100644 index 6f44acfb4aae..000000000000 --- a/sound/soc/intel/boards/mfld_machine.c +++ /dev/null @@ -1,428 +0,0 @@ -/* - *  mfld_machine.c - ASoc Machine driver for Intel Medfield MID platform - * - *  Copyright (C) 2010 Intel Corp - *  Author: Vinod Koul <vinod.koul@intel.com> - *  Author: Harsha Priya <priya.harsha@intel.com> - *  ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - * - *  This program is free software; you can redistribute it and/or modify - *  it under the terms of the GNU General Public License as published by - *  the Free Software Foundation; version 2 of the License. - * - *  This program is distributed in the hope that it will be useful, but - *  WITHOUT ANY WARRANTY; without even the implied warranty of - *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU - *  General Public License for more details. - * - *  You should have received a copy of the GNU General Public License along - *  with this program; if not, write to the Free Software Foundation, Inc., - *  59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. - * - * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - */ - -#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt - -#include <linux/init.h> -#include <linux/device.h> -#include <linux/slab.h> -#include <linux/io.h> -#include <linux/module.h> -#include <sound/pcm.h> -#include <sound/pcm_params.h> -#include <sound/soc.h> -#include <sound/jack.h> -#include "../codecs/sn95031.h" - -#define MID_MONO 1 -#define MID_STEREO 2 -#define MID_MAX_CAP 5 -#define MFLD_JACK_INSERT 0x04 - -enum soc_mic_bias_zones { -	MFLD_MV_START = 0, -	/* mic bias volutage range for Headphones*/ -	MFLD_MV_HP = 400, -	/* mic bias volutage range for American Headset*/ -	MFLD_MV_AM_HS = 650, -	/* mic bias volutage range for Headset*/ -	MFLD_MV_HS = 2000, -	MFLD_MV_UNDEFINED, -}; - -static unsigned int	hs_switch; -static unsigned int	lo_dac; -static struct snd_soc_codec *mfld_codec; - -struct mfld_mc_private { -	void __iomem *int_base; -	u8 interrupt_status; -}; - -struct snd_soc_jack mfld_jack; - -/*Headset jack detection DAPM pins */ -static struct snd_soc_jack_pin mfld_jack_pins[] = { -	{ -		.pin = "Headphones", -		.mask = SND_JACK_HEADPHONE, -	}, -	{ -		.pin = "AMIC1", -		.mask = SND_JACK_MICROPHONE, -	}, -}; - -/* jack detection voltage zones */ -static struct snd_soc_jack_zone mfld_zones[] = { -	{MFLD_MV_START, MFLD_MV_AM_HS, SND_JACK_HEADPHONE}, -	{MFLD_MV_AM_HS, MFLD_MV_HS, SND_JACK_HEADSET}, -}; - -/* sound card controls */ -static const char * const headset_switch_text[] = {"Earpiece", "Headset"}; - -static const char * const lo_text[] = {"Vibra", "Headset", "IHF", "None"}; - -static const struct soc_enum headset_enum = -	SOC_ENUM_SINGLE_EXT(2, headset_switch_text); - -static const struct soc_enum lo_enum = -	SOC_ENUM_SINGLE_EXT(4, lo_text); - -static int headset_get_switch(struct snd_kcontrol *kcontrol, -	struct snd_ctl_elem_value *ucontrol) -{ -	ucontrol->value.enumerated.item[0] = hs_switch; -	return 0; -} - -static int headset_set_switch(struct snd_kcontrol *kcontrol, -	struct snd_ctl_elem_value *ucontrol) -{ -	struct snd_soc_card *card = snd_kcontrol_chip(kcontrol); -	struct snd_soc_dapm_context *dapm = &card->dapm; - -	if (ucontrol->value.enumerated.item[0] == hs_switch) -		return 0; - -	snd_soc_dapm_mutex_lock(dapm); - -	if (ucontrol->value.enumerated.item[0]) { -		pr_debug("hs_set HS path\n"); -		snd_soc_dapm_enable_pin_unlocked(dapm, "Headphones"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "EPOUT"); -	} else { -		pr_debug("hs_set EP path\n"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "Headphones"); -		snd_soc_dapm_enable_pin_unlocked(dapm, "EPOUT"); -	} - -	snd_soc_dapm_sync_unlocked(dapm); - -	snd_soc_dapm_mutex_unlock(dapm); - -	hs_switch = ucontrol->value.enumerated.item[0]; - -	return 0; -} - -static void lo_enable_out_pins(struct snd_soc_dapm_context *dapm) -{ -	snd_soc_dapm_enable_pin_unlocked(dapm, "IHFOUTL"); -	snd_soc_dapm_enable_pin_unlocked(dapm, "IHFOUTR"); -	snd_soc_dapm_enable_pin_unlocked(dapm, "LINEOUTL"); -	snd_soc_dapm_enable_pin_unlocked(dapm, "LINEOUTR"); -	snd_soc_dapm_enable_pin_unlocked(dapm, "VIB1OUT"); -	snd_soc_dapm_enable_pin_unlocked(dapm, "VIB2OUT"); -	if (hs_switch) { -		snd_soc_dapm_enable_pin_unlocked(dapm, "Headphones"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "EPOUT"); -	} else { -		snd_soc_dapm_disable_pin_unlocked(dapm, "Headphones"); -		snd_soc_dapm_enable_pin_unlocked(dapm, "EPOUT"); -	} -} - -static int lo_get_switch(struct snd_kcontrol *kcontrol, -	struct snd_ctl_elem_value *ucontrol) -{ -	ucontrol->value.enumerated.item[0] = lo_dac; -	return 0; -} - -static int lo_set_switch(struct snd_kcontrol *kcontrol, -	struct snd_ctl_elem_value *ucontrol) -{ -	struct snd_soc_card *card = snd_kcontrol_chip(kcontrol); -	struct snd_soc_dapm_context *dapm = &card->dapm; - -	if (ucontrol->value.enumerated.item[0] == lo_dac) -		return 0; - -	snd_soc_dapm_mutex_lock(dapm); - -	/* we dont want to work with last state of lineout so just enable all -	 * pins and then disable pins not required -	 */ -	lo_enable_out_pins(dapm); - -	switch (ucontrol->value.enumerated.item[0]) { -	case 0: -		pr_debug("set vibra path\n"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "VIB1OUT"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "VIB2OUT"); -		snd_soc_update_bits(mfld_codec, SN95031_LOCTL, 0x66, 0); -		break; - -	case 1: -		pr_debug("set hs  path\n"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "Headphones"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "EPOUT"); -		snd_soc_update_bits(mfld_codec, SN95031_LOCTL, 0x66, 0x22); -		break; - -	case 2: -		pr_debug("set spkr path\n"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "IHFOUTL"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "IHFOUTR"); -		snd_soc_update_bits(mfld_codec, SN95031_LOCTL, 0x66, 0x44); -		break; - -	case 3: -		pr_debug("set null path\n"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "LINEOUTL"); -		snd_soc_dapm_disable_pin_unlocked(dapm, "LINEOUTR"); -		snd_soc_update_bits(mfld_codec, SN95031_LOCTL, 0x66, 0x66); -		break; -	} - -	snd_soc_dapm_sync_unlocked(dapm); - -	snd_soc_dapm_mutex_unlock(dapm); - -	lo_dac = ucontrol->value.enumerated.item[0]; -	return 0; -} - -static const struct snd_kcontrol_new mfld_snd_controls[] = { -	SOC_ENUM_EXT("Playback Switch", headset_enum, -			headset_get_switch, headset_set_switch), -	SOC_ENUM_EXT("Lineout Mux", lo_enum, -			lo_get_switch, lo_set_switch), -}; - -static const struct snd_soc_dapm_widget mfld_widgets[] = { -	SND_SOC_DAPM_HP("Headphones", NULL), -	SND_SOC_DAPM_MIC("Mic", NULL), -}; - -static const struct snd_soc_dapm_route mfld_map[] = { -	{"Headphones", NULL, "HPOUTR"}, -	{"Headphones", NULL, "HPOUTL"}, -	{"Mic", NULL, "AMIC1"}, -}; - -static void mfld_jack_check(unsigned int intr_status) -{ -	struct mfld_jack_data jack_data; - -	if (!mfld_codec) -		return; - -	jack_data.mfld_jack = &mfld_jack; -	jack_data.intr_id = intr_status; - -	sn95031_jack_detection(mfld_codec, &jack_data); -	/* TODO: add american headset detection post gpiolib support */ -} - -static int mfld_init(struct snd_soc_pcm_runtime *runtime) -{ -	struct snd_soc_dapm_context *dapm = &runtime->card->dapm; -	int ret_val; - -	/* default is earpiece pin, userspace sets it explcitly */ -	snd_soc_dapm_disable_pin(dapm, "Headphones"); -	/* default is lineout NC, userspace sets it explcitly */ -	snd_soc_dapm_disable_pin(dapm, "LINEOUTL"); -	snd_soc_dapm_disable_pin(dapm, "LINEOUTR"); -	lo_dac = 3; -	hs_switch = 0; -	/* we dont use linein in this so set to NC */ -	snd_soc_dapm_disable_pin(dapm, "LINEINL"); -	snd_soc_dapm_disable_pin(dapm, "LINEINR"); - -	/* Headset and button jack detection */ -	ret_val = snd_soc_card_jack_new(runtime->card, -			"Intel(R) MID Audio Jack", SND_JACK_HEADSET | -			SND_JACK_BTN_0 | SND_JACK_BTN_1, &mfld_jack, -			mfld_jack_pins, ARRAY_SIZE(mfld_jack_pins)); -	if (ret_val) { -		pr_err("jack creation failed\n"); -		return ret_val; -	} - -	ret_val = snd_soc_jack_add_zones(&mfld_jack, -			ARRAY_SIZE(mfld_zones), mfld_zones); -	if (ret_val) { -		pr_err("adding jack zones failed\n"); -		return ret_val; -	} - -	mfld_codec = runtime->codec; - -	/* we want to check if anything is inserted at boot, -	 * so send a fake event to codec and it will read adc -	 * to find if anything is there or not */ -	mfld_jack_check(MFLD_JACK_INSERT); -	return ret_val; -} - -static struct snd_soc_dai_link mfld_msic_dailink[] = { -	{ -		.name = "Medfield Headset", -		.stream_name = "Headset", -		.cpu_dai_name = "Headset-cpu-dai", -		.codec_dai_name = "SN95031 Headset", -		.codec_name = "sn95031", -		.platform_name = "sst-platform", -		.init = mfld_init, -	}, -	{ -		.name = "Medfield Speaker", -		.stream_name = "Speaker", -		.cpu_dai_name = "Speaker-cpu-dai", -		.codec_dai_name = "SN95031 Speaker", -		.codec_name = "sn95031", -		.platform_name = "sst-platform", -		.init = NULL, -	}, -	{ -		.name = "Medfield Vibra", -		.stream_name = "Vibra1", -		.cpu_dai_name = "Vibra1-cpu-dai", -		.codec_dai_name = "SN95031 Vibra1", -		.codec_name = "sn95031", -		.platform_name = "sst-platform", -		.init = NULL, -	}, -	{ -		.name = "Medfield Haptics", -		.stream_name = "Vibra2", -		.cpu_dai_name = "Vibra2-cpu-dai", -		.codec_dai_name = "SN95031 Vibra2", -		.codec_name = "sn95031", -		.platform_name = "sst-platform", -		.init = NULL, -	}, -	{ -		.name = "Medfield Compress", -		.stream_name = "Speaker", -		.cpu_dai_name = "Compress-cpu-dai", -		.codec_dai_name = "SN95031 Speaker", -		.codec_name = "sn95031", -		.platform_name = "sst-platform", -		.init = NULL, -	}, -}; - -/* SoC card */ -static struct snd_soc_card snd_soc_card_mfld = { -	.name = "medfield_audio", -	.owner = THIS_MODULE, -	.dai_link = mfld_msic_dailink, -	.num_links = ARRAY_SIZE(mfld_msic_dailink), - -	.controls = mfld_snd_controls, -	.num_controls = ARRAY_SIZE(mfld_snd_controls), -	.dapm_widgets = mfld_widgets, -	.num_dapm_widgets = ARRAY_SIZE(mfld_widgets), -	.dapm_routes = mfld_map, -	.num_dapm_routes = ARRAY_SIZE(mfld_map), -}; - -static irqreturn_t snd_mfld_jack_intr_handler(int irq, void *dev) -{ -	struct mfld_mc_private *mc_private = (struct mfld_mc_private *) dev; - -	memcpy_fromio(&mc_private->interrupt_status, -			((void *)(mc_private->int_base)), -			sizeof(u8)); -	return IRQ_WAKE_THREAD; -} - -static irqreturn_t snd_mfld_jack_detection(int irq, void *data) -{ -	struct mfld_mc_private *mc_drv_ctx = (struct mfld_mc_private *) data; - -	mfld_jack_check(mc_drv_ctx->interrupt_status); - -	return IRQ_HANDLED; -} - -static int snd_mfld_mc_probe(struct platform_device *pdev) -{ -	int ret_val = 0, irq; -	struct mfld_mc_private *mc_drv_ctx; -	struct resource *irq_mem; - -	pr_debug("snd_mfld_mc_probe called\n"); - -	/* retrive the irq number */ -	irq = platform_get_irq(pdev, 0); - -	/* audio interrupt base of SRAM location where -	 * interrupts are stored by System FW */ -	mc_drv_ctx = devm_kzalloc(&pdev->dev, sizeof(*mc_drv_ctx), GFP_ATOMIC); -	if (!mc_drv_ctx) -		return -ENOMEM; - -	irq_mem = platform_get_resource_byname( -				pdev, IORESOURCE_MEM, "IRQ_BASE"); -	if (!irq_mem) { -		pr_err("no mem resource given\n"); -		return -ENODEV; -	} -	mc_drv_ctx->int_base = devm_ioremap_nocache(&pdev->dev, irq_mem->start, -						    resource_size(irq_mem)); -	if (!mc_drv_ctx->int_base) { -		pr_err("Mapping of cache failed\n"); -		return -ENOMEM; -	} -	/* register for interrupt */ -	ret_val = devm_request_threaded_irq(&pdev->dev, irq, -			snd_mfld_jack_intr_handler, -			snd_mfld_jack_detection, -			IRQF_SHARED, pdev->dev.driver->name, mc_drv_ctx); -	if (ret_val) { -		pr_err("cannot register IRQ\n"); -		return ret_val; -	} -	/* register the soc card */ -	snd_soc_card_mfld.dev = &pdev->dev; -	ret_val = devm_snd_soc_register_card(&pdev->dev, &snd_soc_card_mfld); -	if (ret_val) { -		pr_debug("snd_soc_register_card failed %d\n", ret_val); -		return ret_val; -	} -	platform_set_drvdata(pdev, mc_drv_ctx); -	pr_debug("successfully exited probe\n"); -	return 0; -} - -static struct platform_driver snd_mfld_mc_driver = { -	.driver = { -		.name = "msic_audio", -	}, -	.probe = snd_mfld_mc_probe, -}; - -module_platform_driver(snd_mfld_mc_driver); - -MODULE_DESCRIPTION("ASoC Intel(R) MID Machine driver"); -MODULE_AUTHOR("Vinod Koul <vinod.koul@intel.com>"); -MODULE_AUTHOR("Harsha Priya <priya.harsha@intel.com>"); -MODULE_LICENSE("GPL v2"); -MODULE_ALIAS("platform:msic-audio"); | 

