Commit 5363857b authored by Takashi Iwai's avatar Takashi Iwai

ALSA: pcm: Fix interval evaluation with openmin/max

As addressed in alsa-lib (commit b420056604f0), we need to fix the
case where the evaluation of PCM interval "(x x+1]" leading to
-EINVAL.  After applying rules, such an interval may be translated as
"(x x+1)".

Fixes: ff2d6acd ("ALSA: pcm: Fix snd_interval_refine first/last with open min/max")
Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarTakashi Iwai <tiwai@suse.de>
parent 3deef52c
...@@ -254,11 +254,13 @@ static inline int snd_interval_empty(const struct snd_interval *i) ...@@ -254,11 +254,13 @@ static inline int snd_interval_empty(const struct snd_interval *i)
static inline int snd_interval_single(const struct snd_interval *i) static inline int snd_interval_single(const struct snd_interval *i)
{ {
return (i->min == i->max || return (i->min == i->max ||
(i->min + 1 == i->max && i->openmax)); (i->min + 1 == i->max && (i->openmin || i->openmax)));
} }
static inline int snd_interval_value(const struct snd_interval *i) static inline int snd_interval_value(const struct snd_interval *i)
{ {
if (i->openmin && !i->openmax)
return i->max;
return i->min; return i->min;
} }
......
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