Hi Wolfram,
On Tuesday, 10 July 2018 15:07:47 EEST Wolfram Sang wrote:
> >> +static inline int sccb_read_byte(struct i2c_client *client, u8 addr)
> >> +{
> >> + int ret;
> >> + union i2c_smbus_data data;
> >> +
> >> + i2c_lock_bus(client->adapter, I2C_LOCK_SEGMENT);
> >> +
> >> + ret = __i2c_smbus_xfer(client->adapter, client->addr, client->flags,
> >> + I2C_SMBUS_WRITE, addr, I2C_SMBUS_BYTE, NULL);
> >> + if (ret < 0)
> >> + goto out;
> >> +
> >> + ret = __i2c_smbus_xfer(client->adapter, client->addr, client->flags,
> >> + I2C_SMBUS_READ, 0, I2C_SMBUS_BYTE, &data);
> >> +out:
> >> + i2c_unlock_bus(client->adapter, I2C_LOCK_SEGMENT);
> >> +
> >> + return ret < 0 ? ret : data.byte;
> >> +}
> >
> > I think I mentioned in a previous review of this patch that the function
> > is too big to be a static inline. It should instead be moved to a .c file.
>
> Can be argued.
Especially if sccb_read_byte() is called in multiple places in a driver, not
just once in a read helper, as you've advised for patch 2/2 in this series :-)
> I assume just removing the 'inline' won't do it for you?
Just removing the inline keyword will create many instances of the function,
even when not used. I think it will also cause the compiler to emit warnings
for unused functions. I don't think that's a good idea.
> I'd be fine with that, there are not many SCCB useres out there...
>
> But if you insist on drivers/i2c/i2c-sccb.c, then it should be a
> seperate module, I'd think?
Given how small the functions are, I wouldn't request that, as it would
introduce another Kconfig symbol, but I'm not opposed to such a new module
either.
--
Regards,
Laurent Pinchart