Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular

2018-12-28 Thread Charles Keepax
On Fri, Dec 21, 2018 at 10:55:16AM -0500, Paul Gortmaker wrote:
> [Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular] On 
> 19/12/2018 (Wed 09:17) Charles Keepax wrote:
> 
> > On Mon, Dec 17, 2018 at 03:31:28PM -0500, Paul Gortmaker wrote:
> > > -MODULE_DEVICE_TABLE(i2c, wm8400_i2c_id);
> > >  
> > >  static struct i2c_driver wm8400_i2c_driver = {
> > >   .driver = {
> > > @@ -161,7 +160,7 @@ static struct i2c_driver wm8400_i2c_driver = {
> > >  };
> > >  #endif
> > 
> > Do we not want to add suppress_bind_attrs into the i2c_driver
> > struct here?
> 
> We can add one if you/maintainers want one, but if you look at the
> original patch, this driver was using the more classic/legacy case of
> subsys_init() vs. platform_driver_register() used in other drivers.
> 
> Not adding a suppress_bind_attrs here was intentional, since I'd decided
> to put in the unbind entries for code that used platform_driver_register()
> where the author had created the .remove code, on the assumption that they
> had put some thought into the process of unbind/remove - to make it
> explicit that unbind is now disabled.
> 
> To be clear, using the subsys_init() doesn't implicitly disable unbind.
> However, there are lots of non-modular drivers out there; ones I've not
> even touched, and to start a project to add an unbind disable to them
> all is beyond the scope of the goals I've listed in the 00/18 preamble.
> 
> I'd hope maybe we can revisit the global default setting for non-modular
> code someday - to make non-modules opt-in instead of opt-out, and
> achieve better consistency from one driver to the next, without having
> to add a new .driver sub-struct to each file for the suppress entry.
> 
> I think LinusW hinted at in an earlier email in this ongoing review,
> that the default setting didn't quite make sense to him either.  But in
> any case, that is a separate discussion for another time and place.
> 
> Let me know if you explicitly want one added, otherwise I'll just leave
> the .remove + .suppress_bind_attrs pairing as described above.
> 

Nah its ok, if you are specifically not doing this one I think I
am ok with it. Just seemed out of place compared to the the
others:

Acked-by: Charles Keepax 

Thanks,
Charles


Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular

2018-12-21 Thread Paul Gortmaker
[Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular] On 
19/12/2018 (Wed 09:17) Charles Keepax wrote:

> On Mon, Dec 17, 2018 at 03:31:28PM -0500, Paul Gortmaker wrote:
> > The Kconfig currently controlling compilation of this code is:
> > 
> > drivers/mfd/Kconfig:config MFD_WM8400
> > drivers/mfd/Kconfig:bool "Wolfson Microelectronics WM8400"
> > 
> > ...meaning that it currently is not being built as a module by anyone.
> > 
> > Lets remove the modular code that is essentially orphaned, so that
> > when reading the driver there is no doubt it is builtin-only.
> > 
> > Since module_init was not in use by this code, the init ordering
> > remains unchanged with this commit.
> > 
> > A trivial function rename from wm8400_module_init to the name
> > wm8400_driver_init is also done to reduce possible confusion.
> > 
> > Also note that MODULE_DEVICE_TABLE is a no-op for non-modular code.
> > 
> > We also delete the MODULE_LICENSE tag etc. since all that information
> > is already contained at the top of the file in the comments.
> > 
> > Cc: Lee Jones 
> > Cc: Mark Brown 
> > Cc: patc...@opensource.cirrus.com
> > Signed-off-by: Paul Gortmaker 
> > Acked-by: Linus Walleij 
> > ---
> > -MODULE_DEVICE_TABLE(i2c, wm8400_i2c_id);
> >  
> >  static struct i2c_driver wm8400_i2c_driver = {
> > .driver = {
> > @@ -161,7 +160,7 @@ static struct i2c_driver wm8400_i2c_driver = {
> >  };
> >  #endif
> 
> Do we not want to add suppress_bind_attrs into the i2c_driver
> struct here?

We can add one if you/maintainers want one, but if you look at the
original patch, this driver was using the more classic/legacy case of
subsys_init() vs. platform_driver_register() used in other drivers.

Not adding a suppress_bind_attrs here was intentional, since I'd decided
to put in the unbind entries for code that used platform_driver_register()
where the author had created the .remove code, on the assumption that they
had put some thought into the process of unbind/remove - to make it
explicit that unbind is now disabled.

To be clear, using the subsys_init() doesn't implicitly disable unbind.
However, there are lots of non-modular drivers out there; ones I've not
even touched, and to start a project to add an unbind disable to them
all is beyond the scope of the goals I've listed in the 00/18 preamble.

I'd hope maybe we can revisit the global default setting for non-modular
code someday - to make non-modules opt-in instead of opt-out, and
achieve better consistency from one driver to the next, without having
to add a new .driver sub-struct to each file for the suppress entry.

I think LinusW hinted at in an earlier email in this ongoing review,
that the default setting didn't quite make sense to him either.  But in
any case, that is a separate discussion for another time and place.

Let me know if you explicitly want one added, otherwise I'll just leave
the .remove + .suppress_bind_attrs pairing as described above.

Thanks,
Paul.
--

> 
> Thanks, Charles


Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular

2018-12-19 Thread Charles Keepax
On Mon, Dec 17, 2018 at 03:31:28PM -0500, Paul Gortmaker wrote:
> The Kconfig currently controlling compilation of this code is:
> 
> drivers/mfd/Kconfig:config MFD_WM8400
> drivers/mfd/Kconfig:bool "Wolfson Microelectronics WM8400"
> 
> ...meaning that it currently is not being built as a module by anyone.
> 
> Lets remove the modular code that is essentially orphaned, so that
> when reading the driver there is no doubt it is builtin-only.
> 
> Since module_init was not in use by this code, the init ordering
> remains unchanged with this commit.
> 
> A trivial function rename from wm8400_module_init to the name
> wm8400_driver_init is also done to reduce possible confusion.
> 
> Also note that MODULE_DEVICE_TABLE is a no-op for non-modular code.
> 
> We also delete the MODULE_LICENSE tag etc. since all that information
> is already contained at the top of the file in the comments.
> 
> Cc: Lee Jones 
> Cc: Mark Brown 
> Cc: patc...@opensource.cirrus.com
> Signed-off-by: Paul Gortmaker 
> Acked-by: Linus Walleij 
> ---
> -MODULE_DEVICE_TABLE(i2c, wm8400_i2c_id);
>  
>  static struct i2c_driver wm8400_i2c_driver = {
>   .driver = {
> @@ -161,7 +160,7 @@ static struct i2c_driver wm8400_i2c_driver = {
>  };
>  #endif

Do we not want to add suppress_bind_attrs into the i2c_driver
struct here?

Thanks,
Charles


Re: [PATCH 18/18] mfd: wm8400-core: Make it explicitly non-modular

2018-12-10 Thread Charles Keepax
On Fri, Dec 07, 2018 at 03:11:05PM -0500, Paul Gortmaker wrote:
> The Kconfig currently controlling compilation of this code is:
> 
> drivers/mfd/Kconfig:config MFD_WM8400
> drivers/mfd/Kconfig:bool "Wolfson Microelectronics WM8400"
> 
> ...meaning that it currently is not being built as a module by anyone.
> 
> Lets remove the modular code that is essentially orphaned, so that
> when reading the driver there is no doubt it is builtin-only.
> 
> Since module_init was not in use by this code, the init ordering
> remains unchanged with this commit.
> 
> A trivial function rename from wm8400_module_init to the name
> wm8400_driver_init is also done to reduce possible confusion.
> 
> Also note that MODULE_DEVICE_TABLE is a no-op for non-modular code.
> 
> We also delete the MODULE_LICENSE tag etc. since all that information
> is already contained at the top of the file in the comments.
> 
> Cc: Lee Jones 
> Cc: Mark Brown 
> Cc: patc...@opensource.cirrus.com
> Acked-by: Linus Walleij 
> Signed-off-by: Paul Gortmaker 
> ---

Acked-by: Charles Keepax 

Thanks,
Charles