Skip to content

Commit 72cafe6

Browse files
Andrey Shumilintiwai
authored andcommitted
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 826b5de ("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: 826b5de ("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>
1 parent 164cd0e commit 72cafe6

File tree

1 file changed

+3
-0
lines changed

1 file changed

+3
-0
lines changed

sound/firewire/amdtp-stream.c

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -172,6 +172,9 @@ static int apply_constraint_to_size(struct snd_pcm_hw_params *params,
172172
step = max(step, amdtp_syt_intervals[i]);
173173
}
174174

175+
if (step == 0)
176+
return -EINVAL;
177+
175178
t.min = roundup(s->min, step);
176179
t.max = rounddown(s->max, step);
177180
t.integer = 1;

0 commit comments

Comments
 (0)