missing sound on kernel-5.15

Takashi Iwai tiwai at suse.de
Thu Sep 1 12:25:51 CEST 2022


On Thu, 01 Sep 2022 12:06:25 +0200,
chihhao chen wrote:
> 
> Hi Takashi,
> 
> I tested the patch and USB audio function works well.
> (Start and stop playback more than 20 times with Samsung USB C
> Earphone)

Great, thanks for quick testing!


Takashi

> 
> Thanks
> 
> On Thu, 2022-09-01 at 10:28 +0200, Takashi Iwai wrote:
> > On Thu, 01 Sep 2022 09:51:37 +0200,
> > Takashi Iwai wrote:
> > > 
> > > On Thu, 01 Sep 2022 07:50:40 +0200,
> > > chihhao chen wrote:
> > > > 
> > > > Hi Takashi,
> > > > 
> > > > The patch fixes this problem.
> > > > I tried it with "Product: Samsung USB C Earphone" and missing
> > > > sound
> > > > problem cannot be reproduced.
> > > 
> > > OK, it's a good news.  I'm going to add more information to the
> > > patch
> > > description about the regression and submit the patch.
> > 
> > Could you check whether the below cleanup patch on top of the
> > previous
> > one doesn't break things?  I lightly tested on my devices and don't
> > believe it would change the actual behavior, but just to be sure.
> > 
> > 
> > Takashi
> > 
> > -- 8< --
> > From: Takashi Iwai <tiwai at suse.de>
> > Subject: [PATCH] ALSA: usb-audio: Clean up endpoint setups at PCM
> > prepare
> > 
> > This patch cleans up the superfluous checks and calls for setting up
> > the endpoints at PCM prepare callback:
> > 
> > - Drop stop_endpoints() and sync_pending_stops() calls; the stream is
> >   guaranteed to have been already stopped and synced at each PCM
> >   prepare call by ALSA PCM core
> > 
> > - Call snd_usb_endpoint_prepare() unconditionally;
> >   the check for endpoint->need_setup is done in
> >   snd_pcm_hw_endpoint_prepare() itself
> > 
> > - Apply snd_usb_set_format_quirk() only when the endpoint is actually
> >   set up (i.e. the return code from snd_usb_endpoint_prepare() > 0)
> > 
> > - Move a few lines back into snd_usb_pcm_prepare();
> >   it's even easier to follow than a small useless function
> > 
> > Signed-off-by: Takashi Iwai <tiwai at suse.de>
> > ---
> >  sound/usb/pcm.c | 40 ++++++++++------------------------------
> >  1 file changed, 10 insertions(+), 30 deletions(-)
> > 
> > diff --git a/sound/usb/pcm.c b/sound/usb/pcm.c
> > index b604f7e95e82..4ed53a3dc922 100644
> > --- a/sound/usb/pcm.c
> > +++ b/sound/usb/pcm.c
> > @@ -433,35 +433,6 @@ static void close_endpoints(struct snd_usb_audio
> > *chip,
> >  	}
> >  }
> >  
> > -static int configure_endpoints(struct snd_usb_audio *chip,
> > -			       struct snd_usb_substream *subs)
> > -{
> > -	int err;
> > -
> > -	if (subs->data_endpoint->need_setup) {
> > -		/* stop any running stream beforehand */
> > -		if (stop_endpoints(subs, false))
> > -			sync_pending_stops(subs);
> > -		if (subs->sync_endpoint) {
> > -			err = snd_usb_endpoint_prepare(chip, subs-
> > >sync_endpoint);
> > -			if (err < 0)
> > -				return err;
> > -		}
> > -		err = snd_usb_endpoint_prepare(chip, subs-
> > >data_endpoint);
> > -		if (err < 0)
> > -			return err;
> > -		snd_usb_set_format_quirk(subs, subs->cur_audiofmt);
> > -	} else {
> > -		if (subs->sync_endpoint) {
> > -			err = snd_usb_endpoint_prepare(chip, subs-
> > >sync_endpoint);
> > -			if (err < 0)
> > -				return err;
> > -		}
> > -	}
> > -
> > -	return 0;
> > -}
> > -
> >  /*
> >   * hw_params callback
> >   *
> > @@ -640,9 +611,18 @@ static int snd_usb_pcm_prepare(struct
> > snd_pcm_substream *substream)
> >  		goto unlock;
> >  	}
> >  
> > -	ret = configure_endpoints(chip, subs);
> > +	if (subs->sync_endpoint) {
> > +		ret = snd_usb_endpoint_prepare(chip, subs-
> > >sync_endpoint);
> > +		if (ret < 0)
> > +			goto unlock;
> > +	}
> > +
> > +	ret = snd_usb_endpoint_prepare(chip, subs->data_endpoint);
> >  	if (ret < 0)
> >  		goto unlock;
> > +	else if (ret > 0)
> > +		snd_usb_set_format_quirk(subs, subs->cur_audiofmt);
> > +	ret = 0;
> >  
> >  	/* reset the pointer */
> >  	subs->buffer_bytes = frames_to_bytes(runtime, runtime-
> > >buffer_size);
> 


More information about the Alsa-devel mailing list