Re: [PATCH] checkpatch: avoid default n

From: Miles Chen
Date: Thu Jul 04 2019 - 01:48:37 EST


On Wed, 2019-07-03 at 08:37 -0700, Joe Perches wrote:
> On Wed, 2019-07-03 at 17:03 +0800, Yingjoe Chen wrote:
> > On Wed, 2019-07-03 at 01:42 -0700, Joe Perches wrote:
> > > On Wed, 2019-07-03 at 16:30 +0800, Miles Chen wrote:
> > > > This change reports a warning when "default n" is used.
> > > >
> > > > I have seen several "remove default n" patches, so I think
> > > > it might be helpful to add this test in checkpatch.
> > > > DEFAULT_VALUE_STYLE
> > > > tested:
> > > > WARNING: 'default n' is the default value, no need to write it explicitly.
> > > > + default n
> > >
> > > I don't think this is reasonable as there are
> > > several uses like:
> > >
> > > default y
> > > default n if <foo>
> > >
> > > For instance:
> > >
> > > arch/alpha/Kconfig-config ALPHA_WTINT
> > > arch/alpha/Kconfig- bool "Use WTINT" if ALPHA_SRM || ALPHA_GENERIC
> > > arch/alpha/Kconfig- default y if ALPHA_QEMU
> > > arch/alpha/Kconfig: default n if ALPHA_EV5 || ALPHA_EV56 || (ALPHA_EV4 && !ALPHA_LCA)
> > > arch/alpha/Kconfig: default n if !ALPHA_SRM && !ALPHA_GENERIC
> >
> > Hi,
> >
> >
> > I've sent similar patch in 2016, my version won't complain about these.
> >
> > https://lkml.org/lkml/2016/4/22/580
>
> Hi again.
>
> https://lore.kernel.org/lkml/1461259011.1918.23.camel@xxxxxxxxxxx/
>
> I would prefer a generic solution that also handles the
> quoted use.
>
> $ git grep -P 'default\s*\"[ynm]"' -- '*/Kconfig*'
> arch/mips/Kconfig: default "y"
> arch/mips/Kconfig: default "y"
> arch/mips/Kconfig: default "y"
> arch/mips/Kconfig: default "y"
> arch/mips/cavium-octeon/Kconfig: default "n"
> arch/mips/cavium-octeon/Kconfig: default "y"
> arch/mips/cavium-octeon/Kconfig: default "y"
> arch/mips/cavium-octeon/Kconfig: default "y"
> arch/mips/cavium-octeon/Kconfig: default "y"
> arch/mips/cavium-octeon/Kconfig: default "y"
> arch/mips/cavium-octeon/Kconfig: default "y"
> arch/powerpc/Kconfig: default "y" if PPC_POWERNV
> arch/powerpc/Kconfig: default "y" if PPC_POWERNV
> arch/powerpc/Kconfig: default "n"
> drivers/auxdisplay/Kconfig: default "n"
> drivers/crypto/Kconfig: default "m"
> drivers/rapidio/devices/Kconfig: default "n"
>
> or maybe 2 separate patches.
>
> And the "default y" case and probably the
> "default \!?EXPERT" is or should be generally
> discouraged. Especially for drivers.
>
> https://lore.kernel.org/lkml/CAHk-=wiZ24JuVehJ5sEC0UG1Gk2nvB363wO02RRsR1oEht6R9Q@xxxxxxxxxxxxxx/
>
>
Thanks for your comment, I'll send another patch for these cases:
1. default "[ynm]"
2. default \!?EXPERT
3. default n$