Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit d6bdc0f7 authored by Barry Song's avatar Barry Song Committed by Mark Brown
Browse files

ASoC: ad193x: fix wrong register setting in ad193x_set_dai_fmt

parent 7add84aa
Loading
Loading
Loading
Loading
+25 −23
Original line number Original line Diff line number Diff line
@@ -163,9 +163,10 @@ static int ad193x_set_dai_fmt(struct snd_soc_dai *codec_dai,
		unsigned int fmt)
		unsigned int fmt)
{
{
	struct snd_soc_codec *codec = codec_dai->codec;
	struct snd_soc_codec *codec = codec_dai->codec;
	int adc_reg, dac_reg;
	int adc_reg1, adc_reg2, dac_reg;


	adc_reg = snd_soc_read(codec, AD193X_ADC_CTRL2);
	adc_reg1 = snd_soc_read(codec, AD193X_ADC_CTRL1);
	adc_reg2 = snd_soc_read(codec, AD193X_ADC_CTRL2);
	dac_reg = snd_soc_read(codec, AD193X_DAC_CTRL1);
	dac_reg = snd_soc_read(codec, AD193X_DAC_CTRL1);


	/* At present, the driver only support AUX ADC mode(SND_SOC_DAIFMT_I2S
	/* At present, the driver only support AUX ADC mode(SND_SOC_DAIFMT_I2S
@@ -173,12 +174,12 @@ static int ad193x_set_dai_fmt(struct snd_soc_dai *codec_dai,
	 */
	 */
	switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
	switch (fmt & SND_SOC_DAIFMT_FORMAT_MASK) {
	case SND_SOC_DAIFMT_I2S:
	case SND_SOC_DAIFMT_I2S:
		adc_reg &= ~AD193X_ADC_SERFMT_MASK;
		adc_reg1 &= ~AD193X_ADC_SERFMT_MASK;
		adc_reg |= AD193X_ADC_SERFMT_TDM;
		adc_reg1 |= AD193X_ADC_SERFMT_TDM;
		break;
		break;
	case SND_SOC_DAIFMT_DSP_A:
	case SND_SOC_DAIFMT_DSP_A:
		adc_reg &= ~AD193X_ADC_SERFMT_MASK;
		adc_reg1 &= ~AD193X_ADC_SERFMT_MASK;
		adc_reg |= AD193X_ADC_SERFMT_AUX;
		adc_reg1 |= AD193X_ADC_SERFMT_AUX;
		break;
		break;
	default:
	default:
		return -EINVAL;
		return -EINVAL;
@@ -186,27 +187,27 @@ static int ad193x_set_dai_fmt(struct snd_soc_dai *codec_dai,


	switch (fmt & SND_SOC_DAIFMT_INV_MASK) {
	switch (fmt & SND_SOC_DAIFMT_INV_MASK) {
	case SND_SOC_DAIFMT_NB_NF: /* normal bit clock + frame */
	case SND_SOC_DAIFMT_NB_NF: /* normal bit clock + frame */
		adc_reg &= ~AD193X_ADC_LEFT_HIGH;
		adc_reg2 &= ~AD193X_ADC_LEFT_HIGH;
		adc_reg &= ~AD193X_ADC_BCLK_INV;
		adc_reg2 &= ~AD193X_ADC_BCLK_INV;
		dac_reg &= ~AD193X_DAC_LEFT_HIGH;
		dac_reg &= ~AD193X_DAC_LEFT_HIGH;
		dac_reg &= ~AD193X_DAC_BCLK_INV;
		dac_reg &= ~AD193X_DAC_BCLK_INV;
		break;
		break;
	case SND_SOC_DAIFMT_NB_IF: /* normal bclk + invert frm */
	case SND_SOC_DAIFMT_NB_IF: /* normal bclk + invert frm */
		adc_reg |= AD193X_ADC_LEFT_HIGH;
		adc_reg2 |= AD193X_ADC_LEFT_HIGH;
		adc_reg &= ~AD193X_ADC_BCLK_INV;
		adc_reg2 &= ~AD193X_ADC_BCLK_INV;
		dac_reg |= AD193X_DAC_LEFT_HIGH;
		dac_reg |= AD193X_DAC_LEFT_HIGH;
		dac_reg &= ~AD193X_DAC_BCLK_INV;
		dac_reg &= ~AD193X_DAC_BCLK_INV;
		break;
		break;
	case SND_SOC_DAIFMT_IB_NF: /* invert bclk + normal frm */
	case SND_SOC_DAIFMT_IB_NF: /* invert bclk + normal frm */
		adc_reg &= ~AD193X_ADC_LEFT_HIGH;
		adc_reg2 &= ~AD193X_ADC_LEFT_HIGH;
		adc_reg |= AD193X_ADC_BCLK_INV;
		adc_reg2 |= AD193X_ADC_BCLK_INV;
		dac_reg &= ~AD193X_DAC_LEFT_HIGH;
		dac_reg &= ~AD193X_DAC_LEFT_HIGH;
		dac_reg |= AD193X_DAC_BCLK_INV;
		dac_reg |= AD193X_DAC_BCLK_INV;
		break;
		break;


	case SND_SOC_DAIFMT_IB_IF: /* invert bclk + frm */
	case SND_SOC_DAIFMT_IB_IF: /* invert bclk + frm */
		adc_reg |= AD193X_ADC_LEFT_HIGH;
		adc_reg2 |= AD193X_ADC_LEFT_HIGH;
		adc_reg |= AD193X_ADC_BCLK_INV;
		adc_reg2 |= AD193X_ADC_BCLK_INV;
		dac_reg |= AD193X_DAC_LEFT_HIGH;
		dac_reg |= AD193X_DAC_LEFT_HIGH;
		dac_reg |= AD193X_DAC_BCLK_INV;
		dac_reg |= AD193X_DAC_BCLK_INV;
		break;
		break;
@@ -216,26 +217,26 @@ static int ad193x_set_dai_fmt(struct snd_soc_dai *codec_dai,


	switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
	switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
	case SND_SOC_DAIFMT_CBM_CFM: /* codec clk & frm master */
	case SND_SOC_DAIFMT_CBM_CFM: /* codec clk & frm master */
		adc_reg |= AD193X_ADC_LCR_MASTER;
		adc_reg2 |= AD193X_ADC_LCR_MASTER;
		adc_reg |= AD193X_ADC_BCLK_MASTER;
		adc_reg2 |= AD193X_ADC_BCLK_MASTER;
		dac_reg |= AD193X_DAC_LCR_MASTER;
		dac_reg |= AD193X_DAC_LCR_MASTER;
		dac_reg |= AD193X_DAC_BCLK_MASTER;
		dac_reg |= AD193X_DAC_BCLK_MASTER;
		break;
		break;
	case SND_SOC_DAIFMT_CBS_CFM: /* codec clk slave & frm master */
	case SND_SOC_DAIFMT_CBS_CFM: /* codec clk slave & frm master */
		adc_reg |= AD193X_ADC_LCR_MASTER;
		adc_reg2 |= AD193X_ADC_LCR_MASTER;
		adc_reg &= ~AD193X_ADC_BCLK_MASTER;
		adc_reg2 &= ~AD193X_ADC_BCLK_MASTER;
		dac_reg |= AD193X_DAC_LCR_MASTER;
		dac_reg |= AD193X_DAC_LCR_MASTER;
		dac_reg &= ~AD193X_DAC_BCLK_MASTER;
		dac_reg &= ~AD193X_DAC_BCLK_MASTER;
		break;
		break;
	case SND_SOC_DAIFMT_CBM_CFS: /* codec clk master & frame slave */
	case SND_SOC_DAIFMT_CBM_CFS: /* codec clk master & frame slave */
		adc_reg &= ~AD193X_ADC_LCR_MASTER;
		adc_reg2 &= ~AD193X_ADC_LCR_MASTER;
		adc_reg |= AD193X_ADC_BCLK_MASTER;
		adc_reg2 |= AD193X_ADC_BCLK_MASTER;
		dac_reg &= ~AD193X_DAC_LCR_MASTER;
		dac_reg &= ~AD193X_DAC_LCR_MASTER;
		dac_reg |= AD193X_DAC_BCLK_MASTER;
		dac_reg |= AD193X_DAC_BCLK_MASTER;
		break;
		break;
	case SND_SOC_DAIFMT_CBS_CFS: /* codec clk & frm slave */
	case SND_SOC_DAIFMT_CBS_CFS: /* codec clk & frm slave */
		adc_reg &= ~AD193X_ADC_LCR_MASTER;
		adc_reg2 &= ~AD193X_ADC_LCR_MASTER;
		adc_reg &= ~AD193X_ADC_BCLK_MASTER;
		adc_reg2 &= ~AD193X_ADC_BCLK_MASTER;
		dac_reg &= ~AD193X_DAC_LCR_MASTER;
		dac_reg &= ~AD193X_DAC_LCR_MASTER;
		dac_reg &= ~AD193X_DAC_BCLK_MASTER;
		dac_reg &= ~AD193X_DAC_BCLK_MASTER;
		break;
		break;
@@ -243,7 +244,8 @@ static int ad193x_set_dai_fmt(struct snd_soc_dai *codec_dai,
		return -EINVAL;
		return -EINVAL;
	}
	}


	snd_soc_write(codec, AD193X_ADC_CTRL2, adc_reg);
	snd_soc_write(codec, AD193X_ADC_CTRL1, adc_reg1);
	snd_soc_write(codec, AD193X_ADC_CTRL2, adc_reg2);
	snd_soc_write(codec, AD193X_DAC_CTRL1, dac_reg);
	snd_soc_write(codec, AD193X_DAC_CTRL1, dac_reg);


	return 0;
	return 0;