Commit 384dc085 authored by Takashi Iwai's avatar Takashi Iwai

ALSA: usb-audio: Avoid unnecessary EP setups in prepare

The recent fix for USB suspend breakage moved the code to set up EP
from hw_params to prepare, but it means also the EP setup might be
called multiple times unnecessarily because the prepare callback can
be called multiple times without starting the stream (e.g. OSS
emulation).

This patch adds a new flag to struct snd_usb_substream indicating
whether the setup of EP is required, and do it only when necessary,
i.e. right after hw_params or suspend.
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 61a70950
...@@ -646,6 +646,8 @@ static int usb_audio_suspend(struct usb_interface *intf, pm_message_t message) ...@@ -646,6 +646,8 @@ static int usb_audio_suspend(struct usb_interface *intf, pm_message_t message)
list_for_each(p, &chip->pcm_list) { list_for_each(p, &chip->pcm_list) {
as = list_entry(p, struct snd_usb_stream, list); as = list_entry(p, struct snd_usb_stream, list);
snd_pcm_suspend_all(as->pcm); snd_pcm_suspend_all(as->pcm);
as->substream[0].need_setup_ep =
as->substream[1].need_setup_ep = true;
} }
} }
} else { } else {
......
...@@ -125,6 +125,7 @@ struct snd_usb_substream { ...@@ -125,6 +125,7 @@ struct snd_usb_substream {
struct snd_usb_endpoint *data_endpoint; struct snd_usb_endpoint *data_endpoint;
struct snd_usb_endpoint *sync_endpoint; struct snd_usb_endpoint *sync_endpoint;
unsigned long flags; unsigned long flags;
bool need_setup_ep; /* (re)configure EP at prepare? */
u64 formats; /* format bitmasks (all or'ed) */ u64 formats; /* format bitmasks (all or'ed) */
unsigned int num_formats; /* number of supported audio formats (list) */ unsigned int num_formats; /* number of supported audio formats (list) */
......
...@@ -510,6 +510,7 @@ static int snd_usb_hw_params(struct snd_pcm_substream *substream, ...@@ -510,6 +510,7 @@ static int snd_usb_hw_params(struct snd_pcm_substream *substream,
subs->interface = fmt->iface; subs->interface = fmt->iface;
subs->altset_idx = fmt->altset_idx; subs->altset_idx = fmt->altset_idx;
subs->need_setup_ep = true;
return 0; return 0;
} }
...@@ -568,9 +569,12 @@ static int snd_usb_pcm_prepare(struct snd_pcm_substream *substream) ...@@ -568,9 +569,12 @@ static int snd_usb_pcm_prepare(struct snd_pcm_substream *substream)
if (ret < 0) if (ret < 0)
return ret; return ret;
ret = configure_endpoint(subs); if (subs->need_setup_ep) {
if (ret < 0) ret = configure_endpoint(subs);
return ret; if (ret < 0)
return ret;
subs->need_setup_ep = false;
}
/* some unit conversions in runtime */ /* some unit conversions in runtime */
subs->data_endpoint->maxframesize = subs->data_endpoint->maxframesize =
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment