lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20240428124745.2cb0e2a2@jic23-huawei>
Date: Sun, 28 Apr 2024 12:47:45 +0100
From: Jonathan Cameron <jic23@...nel.org>
To: Subhajit Ghosh <subhajit.ghosh@...aklogic.com>
Cc: Lars-Peter Clausen <lars@...afoo.de>, Dan Carpenter
 <dan.carpenter@...aro.org>, linux-iio@...r.kernel.org,
 linux-kernel@...r.kernel.org
Subject: Re: [PATCH] iio: light: apds9306: Fix input arguments to in_range()

On Sat, 27 Apr 2024 18:39:14 +0930
Subhajit Ghosh <subhajit.ghosh@...aklogic.com> wrote:

> Third input argument to in_range() function requires the number of
> values in range, not the last value in that range. Update macro for
> persistence and adaptive threshold to reflect number of values
> supported instead of the maximum values supported.
> 
> Fixes: 620d1e6c7a3f ("iio: light: Add support for APDS9306 Light Sensor")
> Signed-off-by: Subhajit Ghosh <subhajit.ghosh@...aklogic.com>
Applied to the togreg branch of iio.git. Pushed out initially as testing
for 0-day to take a first look.

Thanks,

Jonathan

> ---
>  drivers/iio/light/apds9306.c | 12 ++++++------
>  1 file changed, 6 insertions(+), 6 deletions(-)
> 
> diff --git a/drivers/iio/light/apds9306.c b/drivers/iio/light/apds9306.c
> index 46c647ccd44c..d6627b3e6000 100644
> --- a/drivers/iio/light/apds9306.c
> +++ b/drivers/iio/light/apds9306.c
> @@ -55,8 +55,8 @@
>  #define APDS9306_ALS_DATA_STAT_MASK	BIT(3)
>  
>  #define APDS9306_ALS_THRES_VAL_MAX	(BIT(20) - 1)
> -#define APDS9306_ALS_THRES_VAR_VAL_MAX	(BIT(3) - 1)
> -#define APDS9306_ALS_PERSIST_VAL_MAX	(BIT(4) - 1)
> +#define APDS9306_ALS_THRES_VAR_NUM_VALS	8
> +#define APDS9306_ALS_PERSIST_NUM_VALS	16
>  #define APDS9306_ALS_READ_DATA_DELAY_US	(20 * USEC_PER_MSEC)
>  #define APDS9306_NUM_REPEAT_RATES	7
>  #define APDS9306_INT_SRC_CLEAR	0
> @@ -726,7 +726,7 @@ static int apds9306_event_period_get(struct apds9306_data *data, int *val)
>  	if (ret)
>  		return ret;
>  
> -	if (!in_range(period, 0, APDS9306_ALS_PERSIST_VAL_MAX))
> +	if (!in_range(period, 0, APDS9306_ALS_PERSIST_NUM_VALS))
>  		return -EINVAL;
>  
>  	*val = period;
> @@ -738,7 +738,7 @@ static int apds9306_event_period_set(struct apds9306_data *data, int val)
>  {
>  	struct apds9306_regfields *rf = &data->rf;
>  
> -	if (!in_range(val, 0, APDS9306_ALS_PERSIST_VAL_MAX))
> +	if (!in_range(val, 0, APDS9306_ALS_PERSIST_NUM_VALS))
>  		return -EINVAL;
>  
>  	return regmap_field_write(rf->int_persist_val, val);
> @@ -796,7 +796,7 @@ static int apds9306_event_thresh_adaptive_get(struct apds9306_data *data, int *v
>  	if (ret)
>  		return ret;
>  
> -	if (!in_range(thr_adpt, 0, APDS9306_ALS_THRES_VAR_VAL_MAX))
> +	if (!in_range(thr_adpt, 0, APDS9306_ALS_THRES_VAR_NUM_VALS))
>  		return -EINVAL;
>  
>  	*val = thr_adpt;
> @@ -808,7 +808,7 @@ static int apds9306_event_thresh_adaptive_set(struct apds9306_data *data, int va
>  {
>  	struct apds9306_regfields *rf = &data->rf;
>  
> -	if (!in_range(val, 0, APDS9306_ALS_THRES_VAR_VAL_MAX))
> +	if (!in_range(val, 0, APDS9306_ALS_THRES_VAR_NUM_VALS))
>  		return -EINVAL;
>  
>  	return regmap_field_write(rf->int_thresh_var_val, val);
> 
> base-commit: b80ad8e3cd2712b78b98804d1f59199680d8ed91


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ