Re: [PATCH v2 2/2] iio: adc: ad7173: add AD7173 driver

From: Ceclan Dumitru-Ioan
Date: Tue Oct 03 2023 - 06:58:02 EST


On 10/3/23 13:45, Andy Shevchenko wrote:
> Subject:
> Re: [PATCH v2 2/2] iio: adc: ad7173: add AD7173 driver
> From:
> Andy Shevchenko <andy@xxxxxxxxxx>
> Date:
> 10/3/23, 13:45
>
> To:
> Ceclan Dumitru-Ioan <mitrutzceclan@xxxxxxxxx>
> CC:
> Jonathan Cameron <jic23@xxxxxxxxxx>, linus.walleij@xxxxxxxxxx, brgl@xxxxxxxx, linux-gpio@xxxxxxxxxxxxxxx, Lars-Peter Clausen <lars@xxxxxxxxxx>, Rob Herring <robh+dt@xxxxxxxxxx>, Krzysztof Kozlowski <krzysztof.kozlowski+dt@xxxxxxxxxx>, Conor Dooley <conor+dt@xxxxxxxxxx>, Michael Walle <michael@xxxxxxxx>, Arnd Bergmann <arnd@xxxxxxxx>, ChiaEn Wu <chiaen_wu@xxxxxxxxxxx>, Niklas Schnelle <schnelle@xxxxxxxxxxxxx>, Leonard Göhrs <l.goehrs@xxxxxxxxxxxxxx>, Mike Looijmans <mike.looijmans@xxxxxxxx>, Haibo Chen <haibo.chen@xxxxxxx>, Hugo Villeneuve <hvilleneuve@xxxxxxxxxxxx>, Ceclan Dumitru <dumitru.ceclan@xxxxxxxxxx>, linux-iio@xxxxxxxxxxxxxxx, devicetree@xxxxxxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx
>
>
> On Tue, Oct 03, 2023 at 01:33:36PM +0300, Ceclan Dumitru-Ioan wrote:
>> On 9/30/23 17:05, Jonathan Cameron wrote:
>>> On Thu, 28 Sep 2023 15:54:43 +0300
>>> Dumitru Ceclan <mitrutzceclan@xxxxxxxxx> wrote>> +config AD7173
>>>> + tristate "Analog Devices AD7173 driver"
>>>> + depends on SPI_MASTER
>>>> + select AD_SIGMA_DELTA
>>>> + select GPIO_REGMAP
>>> If you are selecting it, why does it have if guards in the driver.
>>> I prefer the select here, so drop this if guards.
>> From what i checked, selecting GPIO_REGMAP does not select GPIOLIB but only REGMAP.
>>
>> Also, in the thread from V1 Arnd Bergmann suggested:
>> " I think the best way to handle these is to remove both
>> the 'select' and the #ifdef in the driver and instead use
>> 'if (IS_ENABLED(CONFIG_GPIOLIB))' to handle optional gpio
>> providers in the code. "
> Why not simply to be dependent on GPIOLIB like other drivers do in this folder?

I followed the suggestion given by Arnd. The full argument:

"From a Kconfig perspective, any user-visible symbol ideally only uses
'depends on', while hidden symbols usually use 'select'.

For the GPIOLIB symbol specifically, we have a mix of both, but the
overall usage is that gpio consumers only use 'depends on',
while some of the providers use 'select'. This risks causing build
breakage from a dependency loop when combined with other symbols
that have the same problem (e.g. I2C), but it tends to work out
as long as a strong hierarchy is kept. In particular, using 'select'
from an arch/*/Kconfig platform option is generally harmless as
long as those don't depend on anything else.

The new driver is a gpio provider and at least ad4130 and
ad5592r uses 'select' here, but then again ad74115 and
ad74113 use 'depends on' and ads7950 uses neither.

I think the best way to handle these is to remove both
the 'select' and the #ifdef in the driver and instead use
'if (IS_ENABLED(CONFIG_GPIOLIB))' to handle optional gpio
providers in the code."

I do not have a lot of experience with this subject.
As such, if you consider the argument invalid, mention it and i will
change to 'depends on'.