diff options
author | Andrey Shumilin <shum.sdl@nppct.ru> | 2024-10-18 08:00:18 +0200 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2024-10-21 09:09:21 +0200 |
commit | 72cafe63b35d06b5cfbaf807e90ae657907858da (patch) | |
tree | a572477f0375e0ea8bf20b6ed3932cf7a2dd18f0 | |
parent | ALSA: hda/conexant - Use cached pin control for Node 0x1d on HP EliteOne 1000 G2 (diff) | |
download | linux-72cafe63b35d06b5cfbaf807e90ae657907858da.tar.xz linux-72cafe63b35d06b5cfbaf807e90ae657907858da.zip |
ALSA: firewire-lib: Avoid division by zero in apply_constraint_to_size()
The step variable is initialized to zero. It is changed in the loop,
but if it's not changed it will remain zero. Add a variable check
before the division.
The observed behavior was introduced by commit 826b5de90c0b
("ALSA: firewire-lib: fix insufficient PCM rule for period/buffer size"),
and it is difficult to show that any of the interval parameters will
satisfy the snd_interval_test() condition with data from the
amdtp_rate_table[] table.
Found by Linux Verification Center (linuxtesting.org) with SVACE.
Fixes: 826b5de90c0b ("ALSA: firewire-lib: fix insufficient PCM rule for period/buffer size")
Signed-off-by: Andrey Shumilin <shum.sdl@nppct.ru>
Reviewed-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
Link: https://patch.msgid.link/20241018060018.1189537-1-shum.sdl@nppct.ru
Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r-- | sound/firewire/amdtp-stream.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/sound/firewire/amdtp-stream.c b/sound/firewire/amdtp-stream.c index c72b2a754775..7fc51f829ecc 100644 --- a/sound/firewire/amdtp-stream.c +++ b/sound/firewire/amdtp-stream.c @@ -172,6 +172,9 @@ static int apply_constraint_to_size(struct snd_pcm_hw_params *params, step = max(step, amdtp_syt_intervals[i]); } + if (step == 0) + return -EINVAL; + t.min = roundup(s->min, step); t.max = rounddown(s->max, step); t.integer = 1; |