Re: [PATCH v4 3/4] iio: vcnl4000: Add sampling frequency support for VCNL4010/20.
From: Jonathan Cameron
Date:  Sat Apr 25 2020 - 11:52:37 EST
On Tue, 21 Apr 2020 15:22:11 +0300
Andy Shevchenko <andy.shevchenko@xxxxxxxxx> wrote:
> On Tue, Apr 21, 2020 at 10:56 AM Mathieu Othacehe <m.othacehe@xxxxxxxxx> wrote:
> >
> > Add sampling frequency support for proximity data on VCNL4010 and VCNL4020
> > chips.  
> 
> Couple of nitpicks below.
> 
> ...
> 
> > +static const int vcnl4010_prox_sampling_frequency[][2] = {
> > +       {1, 950000},
> > +       {3, 906250},
> > +       {7, 812500},
> > +       {16, 625000},
> > +       {31, 250000},
> > +       {62, 500000},
> > +       {125, 0},  
> 
> > +       {250, 0}  
> 
> Leave comma here, potentially helpful if it will be extended.
Hi Andy,
Doesn't particularly matter either way, but given this is a list of the values
supported by the device, very unlikely it will be extended.
Games like trying to share the first part of a longer array between
multiple device types might occur, but those are usually really ugly.
Jonathan
> 
> > +};  
> 
> ...
> 
> > +static int vcnl4010_write_proxy_samp_freq(struct vcnl4000_data *data, int val,
> > +                                         int val2)
> > +{
> > +       int i;
> > +       const int len = ARRAY_SIZE(vcnl4010_prox_sampling_frequency);
> > +
> > +       for (i = 0; i < len; i++) {
> > +               if (val <= vcnl4010_prox_sampling_frequency[i][0])
> > +                       break;
> > +       }
> > +
> > +       if (i == len)
> > +               return -EINVAL;  
> 
> I would refactor this
> 
>   unsigned int i = ARRAY_SIZE(vcnl4010_prox_sampling_frequency);
> 
>   do {
>     if (val > vcnl4010_prox_sampling_frequency[i][0])
>       break;
>   } while (--i);
> 
> You won't need to go full array to return error in this case.
> 
> > +       return i2c_smbus_write_byte_data(data->client, VCNL4010_PROX_RATE, i);
> > +}  
>