Commit d64c5cf8 authored by Liam Girdwood's avatar Liam Girdwood Committed by Takashi Iwai

ALSA: pcm: Allow drivers to set R/W wait time.

Currently ALSA core blocks userspace for about 10 seconds for PCM R/W IO.
This needs to be configurable for modern hardware like DSPs where no
pointer update in milliseconds can indicate terminal DSP errors.

Add a substream variable to set the wait time in ms. This allows userspace
and drivers to recover more quickly from terminal DSP errors.
Signed-off-by: default avatarLiam Girdwood <liam.r.girdwood@linux.intel.com>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent e647f5a5
...@@ -462,6 +462,7 @@ struct snd_pcm_substream { ...@@ -462,6 +462,7 @@ struct snd_pcm_substream {
/* -- timer section -- */ /* -- timer section -- */
struct snd_timer *timer; /* timer */ struct snd_timer *timer; /* timer */
unsigned timer_running: 1; /* time is running */ unsigned timer_running: 1; /* time is running */
long wait_time; /* time in ms for R/W to wait for avail */
/* -- next substream -- */ /* -- next substream -- */
struct snd_pcm_substream *next; struct snd_pcm_substream *next;
/* -- linked substreams -- */ /* -- linked substreams -- */
......
...@@ -1833,13 +1833,20 @@ static int wait_for_avail(struct snd_pcm_substream *substream, ...@@ -1833,13 +1833,20 @@ static int wait_for_avail(struct snd_pcm_substream *substream,
if (runtime->no_period_wakeup) if (runtime->no_period_wakeup)
wait_time = MAX_SCHEDULE_TIMEOUT; wait_time = MAX_SCHEDULE_TIMEOUT;
else { else {
/* use wait time from substream if available */
if (substream->wait_time) {
wait_time = substream->wait_time;
} else {
wait_time = 10; wait_time = 10;
if (runtime->rate) { if (runtime->rate) {
long t = runtime->period_size * 2 / runtime->rate; long t = runtime->period_size * 2 /
runtime->rate;
wait_time = max(t, wait_time); wait_time = max(t, wait_time);
} }
wait_time = msecs_to_jiffies(wait_time * 1000); wait_time = msecs_to_jiffies(wait_time * 1000);
} }
}
for (;;) { for (;;) {
if (signal_pending(current)) { if (signal_pending(current)) {
......
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