spi: core and gpio expanders use subsys_init
Make the SPI external GPIO expander drivers register themselves at subsys_initcall() time when they're statically linked, and make the SPI core do its driver model initialization earlier so that's safe. SOC-integrated GPIOs are available starting very early -- often before initcalls start to run, or earily in arch_initcall() at latest -- so this improves consistency, letting more subsystems rely on GPIOs being usable by their own subsys_initcall() code. Signed-off-by: David Brownell <dbrownell@users.sourceforge.net> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
committed by
Linus Torvalds
parent
2bec19feab
commit
673c0c0038
@ -325,13 +325,15 @@ static int __init max7301_init(void)
|
|||||||
{
|
{
|
||||||
return spi_register_driver(&max7301_driver);
|
return spi_register_driver(&max7301_driver);
|
||||||
}
|
}
|
||||||
|
/* register after spi postcore initcall and before
|
||||||
|
* subsys initcalls that may rely on these GPIOs
|
||||||
|
*/
|
||||||
|
subsys_initcall(max7301_init);
|
||||||
|
|
||||||
static void __exit max7301_exit(void)
|
static void __exit max7301_exit(void)
|
||||||
{
|
{
|
||||||
spi_unregister_driver(&max7301_driver);
|
spi_unregister_driver(&max7301_driver);
|
||||||
}
|
}
|
||||||
|
|
||||||
module_init(max7301_init);
|
|
||||||
module_exit(max7301_exit);
|
module_exit(max7301_exit);
|
||||||
|
|
||||||
MODULE_AUTHOR("Juergen Beisert");
|
MODULE_AUTHOR("Juergen Beisert");
|
||||||
|
@ -419,7 +419,10 @@ static int __init mcp23s08_init(void)
|
|||||||
{
|
{
|
||||||
return spi_register_driver(&mcp23s08_driver);
|
return spi_register_driver(&mcp23s08_driver);
|
||||||
}
|
}
|
||||||
module_init(mcp23s08_init);
|
/* register after spi postcore initcall and before
|
||||||
|
* subsys initcalls that may rely on these GPIOs
|
||||||
|
*/
|
||||||
|
subsys_initcall(mcp23s08_init);
|
||||||
|
|
||||||
static void __exit mcp23s08_exit(void)
|
static void __exit mcp23s08_exit(void)
|
||||||
{
|
{
|
||||||
|
@ -738,5 +738,5 @@ err0:
|
|||||||
* driver registration) _could_ be dynamically linked (modular) ... costs
|
* driver registration) _could_ be dynamically linked (modular) ... costs
|
||||||
* include needing to have boardinfo data structures be much more public.
|
* include needing to have boardinfo data structures be much more public.
|
||||||
*/
|
*/
|
||||||
subsys_initcall(spi_init);
|
postcore_initcall(spi_init);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user