在//include/linux/init.h中定义了模块初始化的优先级
/* * Early initcalls run before initializing SMP. * * Only for built-in code, not modules. */ #define early_initcall(fn) __define_initcall(fn, early) /* * A "pure" initcall has no dependencies on anything else, and purely * initializes variables that couldn't be statically initialized. * * This only exists for built-in code, not for modules. * Keep main.c:initcall_level_names[] in sync. */ #define pure_initcall(fn) __define_initcall(fn, 0) #define core_initcall(fn) __define_initcall(fn, 1) #define core_initcall_sync(fn) __define_initcall(fn, 1s) #define postcore_initcall(fn) __define_initcall(fn, 2) #define postcore_initcall_sync(fn) __define_initcall(fn, 2s) #define arch_initcall(fn) __define_initcall(fn, 3) #define arch_initcall_sync(fn) __define_initcall(fn, 3s) #define subsys_initcall(fn) __define_initcall(fn, 4) #define subsys_initcall_sync(fn) __define_initcall(fn, 4s) #define fs_initcall(fn) __define_initcall(fn, 5) #define fs_initcall_sync(fn) __define_initcall(fn, 5s) #define rootfs_initcall(fn) __define_initcall(fn, rootfs) #define device_initcall(fn) __define_initcall(fn, 6) #define device_initcall_sync(fn) __define_initcall(fn, 6s) #define late_initcall(fn) __define_initcall(fn, 7) #define late_initcall_sync(fn) __define_initcall(fn, 7s)
特别地
#define __initcall(fn) device_initcall(fn)
由于early_initcall无法使用,实际上优先级只有7级。
从中可以看出定义的初始化优先级顺序先后为
我们经常使用的module_init则在//include/linux/module.h中被定义为
所以module_init实际上是device_initcall。在模块初始化优先级中处于倒数第二级。
具体内核调用初始化的地方在//init/main.c中
kernel_init->kernel_init_freeable->do_basic_setup->do_initcalls
具体是如何一个一个初始化各个优先级驱动的,从网上查阅的资料看是涉及到汇编,后续学习后再用一篇博客记录一下。
这里贴上一个链接,是一篇讲得比较深的博客linux的initcall机制