Re: [PATCH v2] i2c: i801: fix unused-function warning

From: Jean Delvare
Date: Tue May 15 2018 - 04:16:15 EST


Hi Andy,

On Mon, 14 May 2018 20:18:37 +0300, Andy Shevchenko wrote:
> On Mon, May 14, 2018 at 12:33 PM, Anders Roxell
> <anders.roxell@xxxxxxxxxx> wrote:
> > With CONFIG_PM, we get a harmless build warning:
> > drivers/i2c/busses/i2c-i801.c:1723:12: warning: âi801_resumeâ defined but not used [-Wunused-function]
> > static int i801_resume(struct device *dev)
> > ^~~~~~~~~~~
> > drivers/i2c/busses/i2c-i801.c:1714:12: warning: âi801_suspendâ defined but not used [-Wunused-function]
> > static int i801_suspend(struct device *dev)
> > ^~~~~~~~~~~~
>
> > -#ifdef CONFIG_PM
> > +#ifdef CONFIG_PM_SLEEP
> > static int i801_suspend(struct device *dev)
>
> The better pattern is to get rid of ugly ifdef and supply
> __maybe_unused annotation to each function in question.

That was Anders' first proposal, but it was declined by the driver
maintainer (me.) See:

https://marc.info/?l=linux-kernel&m=152588526520326&w=2

__maybe_unused is just a way to prevent the compiler from doing its
job. If it's really what you want, you might as well build with
-Wno-unused, instead of crippling the code with yet another annotation.

I can't see how building unused code only to discard it later can be
better than a proper #ifdef which will only build the code when we
actually need it.

Maybe there are cases where __maybe_unused is actually needed, but in
my opinion that should be the last resort option. That's not the case
here.

--
Jean Delvare
SUSE L3 Support