From mboxrd@z Thu Jan 1 00:00:00 1970 From: Dan Carpenter Date: Thu, 20 Oct 2011 06:09:10 +0000 Subject: [patch] [ALSA] hwdep: silence integer overflow warning Message-Id: <20111020060910.GA6101@elgon.mountain> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: Jaroslav Kysela Cc: Takashi Iwai , Paul Gortmaker , alsa-devel@alsa-project.org, kernel-janitors@vger.kernel.org Smatch complains that if device is INT_MAX then device + 1 can overflow. It just means we would have an annoying loop while we check all the devices from -2147483648 to SNDRV_MINOR_HWDEPS. Signed-off-by: Dan Carpenter diff --git a/sound/core/hwdep.c b/sound/core/hwdep.c index c7ceb28..edfdf6d 100644 --- a/sound/core/hwdep.c +++ b/sound/core/hwdep.c @@ -273,7 +273,14 @@ static int snd_hwdep_control_ioctl(struct snd_card *card, if (get_user(device, (int __user *)arg)) return -EFAULT; mutex_lock(®ister_mutex); - device = device < 0 ? 0 : device + 1; + + if (device < 0) + device = 0; + else if (device > SNDRV_MINOR_HWDEPS) + device = SNDRV_MINOR_HWDEPS; + else + device++; + while (device < SNDRV_MINOR_HWDEPS) { if (snd_hwdep_search(card, device)) break;