aboutsummaryrefslogtreecommitdiffstats
path: root/sound/usb/caiaq/audio.c
diff options
context:
space:
mode:
authorDaniel Mack <daniel@zonque.org>2014-10-07 14:25:13 +0200
committerTakashi Iwai <tiwai@suse.de>2014-10-07 14:34:25 +0200
commit897c329bcb2206dd025cdb7ba84831a4f3c872d0 (patch)
treea58a29af1e316491ddb6146ab0378dbb5e5a0d36 /sound/usb/caiaq/audio.c
parentALSA: hda - Make the inv dmic handling for Realtek use generic parser (diff)
downloadlinux-dev-897c329bcb2206dd025cdb7ba84831a4f3c872d0.tar.xz
linux-dev-897c329bcb2206dd025cdb7ba84831a4f3c872d0.zip
ALSA: usb: caiaq: check for cdev->n_streams > 1
Coverity spotted a possible DIV0 condition when cdev->n_streams is 0. Fix this by making sure the value is > 1 in snd_usb_caiaq_audio_init(). Signed-off-by: Daniel Mack <daniel@zonque.org> Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/usb/caiaq/audio.c')
-rw-r--r--sound/usb/caiaq/audio.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/sound/usb/caiaq/audio.c b/sound/usb/caiaq/audio.c
index 7103b0908d13..272844746135 100644
--- a/sound/usb/caiaq/audio.c
+++ b/sound/usb/caiaq/audio.c
@@ -816,6 +816,11 @@ int snd_usb_caiaq_audio_init(struct snd_usb_caiaqdev *cdev)
return -EINVAL;
}
+ if (cdev->n_streams < 2) {
+ dev_err(dev, "bogus number of streams: %d\n", cdev->n_streams);
+ return -EINVAL;
+ }
+
ret = snd_pcm_new(cdev->chip.card, cdev->product_name, 0,
cdev->n_audio_out, cdev->n_audio_in, &cdev->pcm);