Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1159685pxj; Sat, 8 May 2021 09:15:46 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx/vQdTPI123gOip7acZ2ZvGGVRa1SNuJQ371HcMDL7glcKDrdkfRRvwLifR+SyjyKysLKF X-Received: by 2002:aa7:cd4d:: with SMTP id v13mr18619122edw.218.1620490546761; Sat, 08 May 2021 09:15:46 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620490546; cv=none; d=google.com; s=arc-20160816; b=a9uGZh+VtMjDv3YimsegKAy80L2P8b8w6XZ6RBqcyr+cBi/YL4gb2e6Ox4Tl8P6M7K 4nD6dkeLsaL+dc/vFR3JgfycRX8ovpaINaK+s5uiYlZQgZ3Al0Q9I7wZsRmkTrQBxliy PtFJBB+i79aoAL+OUXWK+8t4ERZxQVY4LE59D58sHCyvU3kbLUI0BzRyb0cY72W9OTam oIi1jyuhruEKc791KYrnqvdEHZVEujZ1dsf44BrxOViP1hvULfcqo3lxwpI3oN3ns1Ch agyiWmJkN3M2VzmrQ0uGgcx0Z/f9kMiPn8t45j0H9BGiwqa8kuo5ZBEDwbsLtXXgW0Zl TUhQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=AoLMHLtnSXqDXmv1l9VmZU/L2ueAs242hMvwmObGhr0=; b=W9eRTaJKmgnCXyh5Az1xEJltJDFuCsg9tbzFBlUg//ejqONSsi+08pBSgvqKI+OAGz a9gtkQaDUAcTrgSRIs0L7M7AEDScYZ6HkntKsmbEsm0BFaOafJylgVHw57AdCa508krs cjJwNS427hmdFUb/9lDbn+ycByREwYNXLTsU6dZkzBLCS5fKz1P4q81dVSQL9/rlVCTK H17iukdEVf3zrX0xdAo3LYYGRJl2hcmXAufzSxJ+PyNSIBHQKsZYZlBAAXvCaQ+r6yQB G6RWEtQ5oYXXXfag361GvwkG0ap8vaLVS1Zg0MY+0wFuBVcWWYmOMpJrY22KZJ6Cfu39 NPdg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y7si7777866ejq.725.2021.05.08.09.15.23; Sat, 08 May 2021 09:15:46 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229649AbhEHQNE (ORCPT + 99 others); Sat, 8 May 2021 12:13:04 -0400 Received: from mail.kernel.org ([198.145.29.99]:58360 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229500AbhEHQNE (ORCPT ); Sat, 8 May 2021 12:13:04 -0400 Received: from jic23-huawei (cpc108967-cmbg20-2-0-cust86.5-4.cable.virginm.net [81.101.6.87]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id DEFEB61260; Sat, 8 May 2021 16:11:59 +0000 (UTC) Date: Sat, 8 May 2021 17:12:58 +0100 From: Jonathan Cameron To: Colin King Cc: Lars-Peter Clausen , Nathan Chancellor , Nick Desaulniers , Jon Brenner , linux-iio@vger.kernel.org, clang-built-linux@googlegroups.com, kernel-janitors@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] iio: tsl2583: Fix division by a zero lux_val Message-ID: <20210508171258.2ef71a70@jic23-huawei> In-Reply-To: <20210507183041.115864-1-colin.king@canonical.com> References: <20210507183041.115864-1-colin.king@canonical.com> X-Mailer: Claws Mail 3.17.8 (GTK+ 2.24.33; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 7 May 2021 19:30:41 +0100 Colin King wrote: > From: Colin Ian King > > The lux_val returned from tsl2583_get_lux can potentially be zero, > so check for this to avoid a division by zero and an overflowed > gain_trim_val. > > Fixes clang scan-build warning: > > drivers/iio/light/tsl2583.c:345:40: warning: Either the > condition 'lux_val<0' is redundant or there is division > by zero at line 345. [zerodivcond] > > Fixes: ac4f6eee8fe8 ("staging: iio: TAOS tsl258x: Device driver") > Signed-off-by: Colin Ian King Definitely looks like it could happen so applied to the fixes-togreg branch of iio.git and marked for stable. Thanks, Jonathan > --- > drivers/iio/light/tsl2583.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/drivers/iio/light/tsl2583.c b/drivers/iio/light/tsl2583.c > index 0f787bfc88fc..c9d8f07a6fcd 100644 > --- a/drivers/iio/light/tsl2583.c > +++ b/drivers/iio/light/tsl2583.c > @@ -341,6 +341,14 @@ static int tsl2583_als_calibrate(struct iio_dev *indio_dev) > return lux_val; > } > > + /* Avoid division by zero of lux_value later on */ > + if (lux_val == 0) { > + dev_err(&chip->client->dev, > + "%s: lux_val of 0 will produce out of range trim_value\n", > + __func__); > + return -ENODATA; > + } > + > gain_trim_val = (unsigned int)(((chip->als_settings.als_cal_target) > * chip->als_settings.als_gain_trim) / lux_val); > if ((gain_trim_val < 250) || (gain_trim_val > 4000)) {