ASoC: rt712-sdca: fix coding style and unconditionally return issues
authorShuming Fan <shumingf@realtek.com>
Fri, 10 Feb 2023 08:21:41 +0000 (16:21 +0800)
committerMark Brown <broonie@kernel.org>
Fri, 10 Feb 2023 15:08:13 +0000 (15:08 +0000)
This patch fixes
1. coding style issues
2. check if the setting was set already in rt712_sdca_mux_put callback

Signed-off-by: Shuming Fan <shumingf@realtek.com>
Link: https://lore.kernel.org/r/20230210082141.24077-1-shumingf@realtek.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/rt712-sdca.c

index cc3f6dae1871cda8bfbf46bbfe8e9ca1c42b2e33..8d2fa769bb2e2cdc6152c09de10d1eb3e73b9cc5 100644 (file)
@@ -366,8 +366,9 @@ static void rt712_sdca_btn_check_handler(struct work_struct *work)
                                break;
                        }
                }
-       } else
+       } else {
                rt712->jack_type = 0;
+       }
 
        dev_dbg(&rt712->slave->dev, "%s, btn_type=0x%x\n",      __func__, btn_type);
        snd_soc_jack_report(rt712->hs_jack, rt712->jack_type | btn_type,
@@ -707,6 +708,7 @@ static int rt712_sdca_mux_put(struct snd_kcontrol *kcontrol,
        struct soc_enum *e = (struct soc_enum *)kcontrol->private_value;
        unsigned int *item = ucontrol->value.enumerated.item;
        unsigned int mask_sft;
+       unsigned int val;
 
        if (item[0] >= e->items)
                return -EINVAL;
@@ -718,6 +720,11 @@ static int rt712_sdca_mux_put(struct snd_kcontrol *kcontrol,
        else
                return -EINVAL;
 
+       rt712_sdca_index_read(rt712, RT712_VENDOR_HDA_CTL, RT712_MIXER_CTL1, &val);
+       val = (val >> mask_sft) & 0x3;
+       if (!val)
+               return 0;
+
        rt712_sdca_index_write(rt712, RT712_VENDOR_HDA_CTL,
                RT712_MIXER_CTL1, 0x3fff);
        rt712_sdca_index_update_bits(rt712, RT712_VENDOR_HDA_CTL,
@@ -1094,19 +1101,24 @@ static int rt712_sdca_pcm_hw_params(struct snd_pcm_substream *substream,
        }
 
        /* set sampling frequency */
-       if (dai->id == RT712_AIF1) {
+       switch (dai->id) {
+       case RT712_AIF1:
                regmap_write(rt712->regmap,
                        SDW_SDCA_CTL(FUNC_NUM_JACK_CODEC, RT712_SDCA_ENT_CS01, RT712_SDCA_CTL_SAMPLE_FREQ_INDEX, 0),
                        sampling_rate);
                regmap_write(rt712->regmap,
                        SDW_SDCA_CTL(FUNC_NUM_JACK_CODEC, RT712_SDCA_ENT_CS11, RT712_SDCA_CTL_SAMPLE_FREQ_INDEX, 0),
                        sampling_rate);
-       }
-
-       if (dai->id == RT712_AIF2)
+               break;
+       case RT712_AIF2:
                regmap_write(rt712->regmap,
                        SDW_SDCA_CTL(FUNC_NUM_AMP, RT712_SDCA_ENT_CS31, RT712_SDCA_CTL_SAMPLE_FREQ_INDEX, 0),
                        sampling_rate);
+               break;
+       default:
+               dev_err(component->dev, "Wrong DAI id\n");
+               return -EINVAL;
+       }
 
        return 0;
 }