On Wed, 03 Mar 2021 19:29:58 +0100,
Vitaly Rodionov wrote:
> @@ -1243,6 +1258,8 @@ static int patch_cs4213(struct hda_codec *codec)
>  #define CIR_I2C_QWRITE       0x005D
>  #define CIR_I2C_QREAD        0x005E
>  
> +static struct mutex cs8409_i2c_mux;

Any reason that this must be the global mutex?  I suppose it can fit
in own spec->i2c_mutex instead?


> +static void cs8409_cs42l42_cap_sync_hook(struct hda_codec *codec,
> +                                      struct snd_kcontrol *kcontrol,
> +                                      struct snd_ctl_elem_value *ucontrol)
> +{
> +     struct cs_spec *spec = codec->spec;
> +     unsigned int curval, expval;
> +     /* CS8409 DMIC Pin only allows the setting of the Stream Parameters in
> +      * Power State D0. When a headset is unplugged, and the path is 
> switched to
> +      * the DMIC, the Stream is restarted with the new ADC, but this is done 
> in
> +      * Power State D3. Restart the Stream now DMIC is in D0.
> +      */
> +     if (spec->gen.cur_adc == CS8409_CS42L42_DMIC_ADC_PIN_NID) {
> +             curval = snd_hda_codec_read(codec, spec->gen.cur_adc,
> +                     0, AC_VERB_GET_CONV, 0);
> +             expval = (spec->gen.cur_adc_stream_tag << 4) | 0;
> +             if (curval != expval) {
> +                     codec_dbg(codec, "%s Restarting Stream after DMIC 
> switch\n", __func__);
> +                     __snd_hda_codec_cleanup_stream(codec, 
> spec->gen.cur_adc, 1);
> +                     snd_hda_codec_setup_stream(codec, spec->gen.cur_adc,
> +                                        spec->gen.cur_adc_stream_tag, 0,
> +                                        spec->gen.cur_adc_format);

Hrm, this looks a big scary.  We may need to reconsider how to handle
this better later, but it's OK as long as you've tested with this
code...

> +static int cs8409_cs42l42_init(struct hda_codec *codec)
> +{
> +     int ret = 0;
> +
> +     ret = snd_hda_gen_init(codec);
> +
> +     if (!ret) {
> +             /* On Dell platforms with suspend D3 mode support we
> +              * have to re-initialise cs8409 bridge and companion
> +              * cs42l42 codec
> +              */
> +             snd_hda_sequence_write(codec, cs8409_cs42l42_init_verbs);
> +             snd_hda_sequence_write(codec, cs8409_cs42l42_add_verbs);
> +
> +             cs8409_cs42l42_hw_init(codec);

Ah... the init stuff at resume appears finally here.  This part should
be in the second patch instead.

> +static int cs8409_cs42l42_exec_verb(struct hdac_device *dev,
> +             unsigned int cmd, unsigned int flags, unsigned int *res)
> +{
> +     struct hda_codec *codec = container_of(dev, struct hda_codec, core);
> +     struct cs_spec *spec = codec->spec;
> +
> +     unsigned int nid = 0;
> +     unsigned int verb = 0;

The blank line above should be removed.

> +     case CS8409_CS42L42_HP_PIN_NID:
> +             if (verb == AC_VERB_GET_PIN_SENSE) {
> +                     *res = 
> (spec->cs42l42_hp_jack_in)?AC_PINSENSE_PRESENCE:0;

The spaces are needed around operators.
Similar coding-style issues are seen other places.  Please try to run
scripts/checkpatch.pl.


thanks,

Takashi

Reply via email to