ALSA: pcm: Remove yet superfluous WARN_ON()
authorTakashi Iwai <tiwai@suse.de>
Wed, 10 Jan 2018 22:48:05 +0000 (23:48 +0100)
committerTakashi Iwai <tiwai@suse.de>
Wed, 10 Jan 2018 23:01:26 +0000 (00:01 +0100)
muldiv32() contains a snd_BUG_ON() (which is morphed as WARN_ON() with
debug option) for checking the case of 0 / 0.  This would be helpful
if this happens only as a logical error; however, since the hw refine
is performed with any data set provided by user, the inconsistent
values that can trigger such a condition might be passed easily.
Actually, syzbot caught this by passing some zero'ed old hw_params
ioctl.

So, having snd_BUG_ON() there is simply superfluous and rather
harmful to give unnecessary confusions.  Let's get rid of it.

Reported-by: syzbot+7e6ee55011deeebce15d@syzkaller.appspotmail.com
Cc: <stable@vger.kernel.org>
Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/core/pcm_lib.c

index db7894bb028ccc6ca941c45c4a7e37602ec1228d..faa67861cbc17e1ff7a9e409f76c717179d22370 100644 (file)
@@ -560,7 +560,6 @@ static inline unsigned int muldiv32(unsigned int a, unsigned int b,
 {
        u_int64_t n = (u_int64_t) a * b;
        if (c == 0) {
-               snd_BUG_ON(!n);
                *r = 0;
                return UINT_MAX;
        }