linux/sound/firewire
Andrey Shumilin 72cafe63b3 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 826b5de90c
("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: 826b5de90c ("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>
2024-10-21 09:09:21 +02:00
..
bebob ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
dice ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
digi00x ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
fireface ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
fireworks ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
motu ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
oxfw ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
tascam ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
amdtp-am824.c
amdtp-am824.h
amdtp-stream-trace.h
amdtp-stream.c ALSA: firewire-lib: Avoid division by zero in apply_constraint_to_size() 2024-10-21 09:09:21 +02:00
amdtp-stream.h Revert "ALSA: firewire-lib: obsolete workqueue for period update" 2024-07-31 11:28:13 +02:00
cmp.c
cmp.h
fcp.c
fcp.h
isight.c ALSA: firewire: use nonatomic PCM operation 2024-09-04 21:51:54 +09:00
iso-resources.c
iso-resources.h
Kconfig
lib.c
lib.h
Makefile
packets-buffer.c
packets-buffer.h