[alsa-devel] [PATCH] ASoC: cht_bsw_rt5672: Use HID translation unit

Takashi Iwai tiwai at suse.de
Wed Nov 30 14:47:19 CET 2016


On Fri, 25 Nov 2016 15:40:18 +0100,
Takashi Iwai wrote:
> 
> Instead of hard-coded "i2c-10EC5670:00", use the translation helper to
> avoid the mismatch between i2c-codec and ACPI strings just like what
> we've done for bytcr_rt5640.  This gives more robust binding on funky
> devices like Dell Wyse 3040.
> 
> Signed-off-by: Takashi Iwai <tiwai at suse.de>

Vinod, Pierre, Liam, could you guys review?


thanks,

Takashi

> ---
>  sound/soc/intel/boards/cht_bsw_rt5672.c | 30 ++++++++++++++++++++++++++++--
>  1 file changed, 28 insertions(+), 2 deletions(-)
> 
> diff --git a/sound/soc/intel/boards/cht_bsw_rt5672.c b/sound/soc/intel/boards/cht_bsw_rt5672.c
> index df9d254baa18..fe607d8701a0 100644
> --- a/sound/soc/intel/boards/cht_bsw_rt5672.c
> +++ b/sound/soc/intel/boards/cht_bsw_rt5672.c
> @@ -25,12 +25,14 @@
>  #include <sound/jack.h>
>  #include "../../codecs/rt5670.h"
>  #include "../atom/sst-atom-controls.h"
> +#include "../common/sst-acpi.h"
>  
>  /* The platform clock #3 outputs 19.2Mhz clock to codec as I2S MCLK */
>  #define CHT_PLAT_CLK_3_HZ	19200000
>  #define CHT_CODEC_DAI	"rt5670-aif1"
>  
>  static struct snd_soc_jack cht_bsw_headset;
> +static char cht_bsw_codec_name[16];
>  
>  /* Headset jack detection DAPM pins */
>  static struct snd_soc_jack_pin cht_bsw_headset_pins[] = {
> @@ -295,7 +297,7 @@ static int cht_suspend_pre(struct snd_soc_card *card)
>  	struct snd_soc_codec *codec;
>  
>  	list_for_each_entry(codec, &card->codec_dev_list, card_list) {
> -		if (!strcmp(codec->component.name, "i2c-10EC5670:00")) {
> +		if (!strcmp(codec->component.name, cht_bsw_codec_name)) {
>  			dev_dbg(codec->dev, "disabling jack detect before going to suspend.\n");
>  			rt5670_jack_suspend(codec);
>  			break;
> @@ -309,7 +311,7 @@ static int cht_resume_post(struct snd_soc_card *card)
>  	struct snd_soc_codec *codec;
>  
>  	list_for_each_entry(codec, &card->codec_dev_list, card_list) {
> -		if (!strcmp(codec->component.name, "i2c-10EC5670:00")) {
> +		if (!strcmp(codec->component.name, cht_bsw_codec_name)) {
>  			dev_dbg(codec->dev, "enabling jack detect for resume.\n");
>  			rt5670_jack_resume(codec);
>  			break;
> @@ -335,9 +337,33 @@ static struct snd_soc_card snd_soc_card_cht = {
>  	.resume_post = cht_resume_post,
>  };
>  
> +#define RT5672_I2C_DEFAULT	"i2c-10EC5670:00"
> +
>  static int snd_cht_mc_probe(struct platform_device *pdev)
>  {
>  	int ret_val = 0;
> +	struct sst_acpi_mach *mach = pdev->dev.platform_data;
> +	const char *i2c_name;
> +	int i;
> +
> +	strcpy(cht_bsw_codec_name, RT5672_I2C_DEFAULT);
> +
> +	/* fixup codec name based on HID */
> +	if (mach) {
> +		i2c_name = sst_acpi_find_name_from_hid(mach->id);
> +		if (i2c_name) {
> +			snprintf(cht_bsw_codec_name, sizeof(cht_bsw_codec_name),
> +				 "i2c-%s", i2c_name);
> +			for (i = 0; i < ARRAY_SIZE(cht_dailink); i++) {
> +				if (!strcmp(cht_dailink[i].codec_name,
> +					    RT5672_I2C_DEFAULT)) {
> +					cht_dailink[i].codec_name =
> +						cht_bsw_codec_name;
> +					break;
> +				}
> +			}
> +		}
> +	}
>  
>  	/* register the soc card */
>  	snd_soc_card_cht.dev = &pdev->dev;
> -- 
> 2.10.2
> 
> _______________________________________________
> Alsa-devel mailing list
> Alsa-devel at alsa-project.org
> http://mailman.alsa-project.org/mailman/listinfo/alsa-devel
> 


More information about the Alsa-devel mailing list