Re: [PATCH 1/1] drivers:iio:light:isl29125: added macros for sensing range

From: Jonathan Cameron
Date: Sun Jun 26 2016 - 09:57:10 EST


On 24/06/16 12:16, Bijosh Thykkoottathil wrote:
> Added macros for sensing range as the corresponding magic numbers
> were used at multiple places.
> - SENSING_RANGE_0 for 375 lux full range
> - SENSING_RANGE_1 for 10k lux full range
>
> Signed-off-by: Bijosh Thykkoottathil <bijosh.t@xxxxxxxxxxx>
Hi Bijosh,

Macros are great for making cases of 'magic numbers' more readable.
However here we are wrapping up 'real' numbers in macros that actually
obscure what they are...

Now the fact they are used twice does make it a little more worthwhile.
Peter, what do you think? Your driver so up to you ;)
*one buck passed*
> ---
> drivers/iio/light/isl29125.c | 11 +++++++----
> 1 file changed, 7 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/iio/light/isl29125.c b/drivers/iio/light/isl29125.c
> index e2945a2..83a5a7a 100644
> --- a/drivers/iio/light/isl29125.c
> +++ b/drivers/iio/light/isl29125.c
> @@ -44,6 +44,9 @@
> #define ISL29125_MODE_B 0x3
> #define ISL29125_MODE_RGB 0x5
>
> +#define SENSING_RANGE_0 5722 /* 375 lux full range */
> +#define SENSING_RANGE_1 152590 /* 10k lux full range */
> +
> #define ISL29125_MODE_RANGE BIT(3)
>
> #define ISL29125_STATUS_CONV BIT(1)
> @@ -140,9 +143,9 @@ static int isl29125_read_raw(struct iio_dev *indio_dev,
> case IIO_CHAN_INFO_SCALE:
> *val = 0;
> if (data->conf1 & ISL29125_MODE_RANGE)
> - *val2 = 152590; /* 10k lux full range */
> + *val2 = SENSING_RANGE_1; /* 10k lux full range */
> else
> - *val2 = 5722; /* 375 lux full range */
> + *val2 = SENSING_RANGE_0; /* 375 lux full range */
> return IIO_VAL_INT_PLUS_MICRO;
> }
> return -EINVAL;
> @@ -158,9 +161,9 @@ static int isl29125_write_raw(struct iio_dev *indio_dev,
> case IIO_CHAN_INFO_SCALE:
> if (val != 0)
> return -EINVAL;
> - if (val2 == 152590)
> + if (val2 == SENSING_RANGE_1)
> data->conf1 |= ISL29125_MODE_RANGE;
> - else if (val2 == 5722)
> + else if (val2 == SENSING_RANGE_0)
> data->conf1 &= ~ISL29125_MODE_RANGE;
> else
> return -EINVAL;
>