linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] cris: don't use module_init for non-modular core eeprom.c code
@ 2015-06-14 21:05 Paul Gortmaker
  2015-06-15  7:35 ` Jesper Nilsson
  0 siblings, 1 reply; 3+ messages in thread
From: Paul Gortmaker @ 2015-06-14 21:05 UTC (permalink / raw)
  To: linux-kernel
  Cc: Paul Gortmaker, Mikael Starvik, Jesper Nilsson, linux-cris-kernel

The eeprom.c code is compiled based on the Kconfig setting
ETRAX_I2C_EEPROM, which is bool.  So the code is either built in
or absent.  It will never be modular, so using module_init as an
alias for __initcall is rather misleading.

Fix this up now, so that we can relocate module_init from
init.h into module.h in the future.  If we don't do this, we'd
have to add module.h to obviously non-modular code, and that
would be a worse thing.

Direct use of __initcall is discouraged, vs prioritized ones.
Use of device_initcall is consistent with what __initcall
maps onto, and hence does not change the init order, making the
impact of this change zero.   Should someone with real hardware
for boot testing want to change it later to arch_initcall or
something different, they can do that at a later date.

Cc: Mikael Starvik <starvik@axis.com>
Cc: Jesper Nilsson <jesper.nilsson@axis.com>
Cc: linux-cris-kernel@axis.com
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
---

[To be appended to the content originally sent as:
   "Replace module_init with device_initcall in non modules"
   https://lkml.kernel.org/r/1432860493-23831-1-git-send-email-paul.gortmaker@windriver.com
]

 arch/cris/arch-v10/drivers/eeprom.c | 3 +--
 1 file changed, 1 insertion(+), 2 deletions(-)

diff --git a/arch/cris/arch-v10/drivers/eeprom.c b/arch/cris/arch-v10/drivers/eeprom.c
index 5047a33043bd..f679a19dfeb8 100644
--- a/arch/cris/arch-v10/drivers/eeprom.c
+++ b/arch/cris/arch-v10/drivers/eeprom.c
@@ -848,5 +848,4 @@ static void eeprom_disable_write_protect(void)
     /* Write protect disabled */
   }
 }
-
-module_init(eeprom_init);
+device_initcall(eeprom_init);
-- 
2.2.1


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* Re: [PATCH] cris: don't use module_init for non-modular core eeprom.c code
  2015-06-14 21:05 [PATCH] cris: don't use module_init for non-modular core eeprom.c code Paul Gortmaker
@ 2015-06-15  7:35 ` Jesper Nilsson
  2015-06-15 13:44   ` Paul Gortmaker
  0 siblings, 1 reply; 3+ messages in thread
From: Jesper Nilsson @ 2015-06-15  7:35 UTC (permalink / raw)
  To: Paul Gortmaker
  Cc: linux-kernel, Mikael Starvik, Jesper Nilsson, linux-cris-kernel

On Sun, Jun 14, 2015 at 05:05:21PM -0400, Paul Gortmaker wrote:
> The eeprom.c code is compiled based on the Kconfig setting
> ETRAX_I2C_EEPROM, which is bool.  So the code is either built in
> or absent.  It will never be modular, so using module_init as an
> alias for __initcall is rather misleading.
> 
> Fix this up now, so that we can relocate module_init from
> init.h into module.h in the future.  If we don't do this, we'd
> have to add module.h to obviously non-modular code, and that
> would be a worse thing.
> 
> Direct use of __initcall is discouraged, vs prioritized ones.
> Use of device_initcall is consistent with what __initcall
> maps onto, and hence does not change the init order, making the
> impact of this change zero.   Should someone with real hardware
> for boot testing want to change it later to arch_initcall or
> something different, they can do that at a later date.
> 
> Cc: Mikael Starvik <starvik@axis.com>

Looks good, I'll take it in the CRIS-tree.

> Cc: linux-cris-kernel@axis.com
> Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>

/^JN - Jesper Nilsson
-- 
               Jesper Nilsson -- jesper.nilsson@axis.com

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH] cris: don't use module_init for non-modular core eeprom.c code
  2015-06-15  7:35 ` Jesper Nilsson
@ 2015-06-15 13:44   ` Paul Gortmaker
  0 siblings, 0 replies; 3+ messages in thread
From: Paul Gortmaker @ 2015-06-15 13:44 UTC (permalink / raw)
  To: Jesper Nilsson
  Cc: linux-kernel, Mikael Starvik, Jesper Nilsson, linux-cris-kernel

On 15-06-15 03:35 AM, Jesper Nilsson wrote:
> On Sun, Jun 14, 2015 at 05:05:21PM -0400, Paul Gortmaker wrote:
>> The eeprom.c code is compiled based on the Kconfig setting
>> ETRAX_I2C_EEPROM, which is bool.  So the code is either built in
>> or absent.  It will never be modular, so using module_init as an
>> alias for __initcall is rather misleading.
>>
>> Fix this up now, so that we can relocate module_init from
>> init.h into module.h in the future.  If we don't do this, we'd
>> have to add module.h to obviously non-modular code, and that
>> would be a worse thing.
>>
>> Direct use of __initcall is discouraged, vs prioritized ones.
>> Use of device_initcall is consistent with what __initcall
>> maps onto, and hence does not change the init order, making the
>> impact of this change zero.   Should someone with real hardware
>> for boot testing want to change it later to arch_initcall or
>> something different, they can do that at a later date.
>>
>> Cc: Mikael Starvik <starvik@axis.com>
> 
> Looks good, I'll take it in the CRIS-tree.

That is fine if you want, but I need to keep a copy here in this
series (as per the part of the msg you snipped) ; otherwise I'll
introduce a bisect fail into the commit history if my tree gets
merged ahead of the cris tree.

Thanks,
Paul.
--

> 
>> Cc: linux-cris-kernel@axis.com
>> Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
> 
> /^JN - Jesper Nilsson
> 

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2015-06-15 13:47 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-06-14 21:05 [PATCH] cris: don't use module_init for non-modular core eeprom.c code Paul Gortmaker
2015-06-15  7:35 ` Jesper Nilsson
2015-06-15 13:44   ` Paul Gortmaker

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).