Se guardi la definizione delle nuove funzioni:
/* Each module must use one module_init(). */
#define module_init(initfn) \
static inline initcall_t __inittest(void) \
{ return initfn; } \
int init_module(void) __attribute__((alias(#initfn)));
/* This is only required if you want to be unloadable. */
#define module_exit(exitfn) \
static inline exitcall_t __exittest(void) \
{ return exitfn; } \
void cleanup_module(void) __attribute__((alias(#exitfn)));
Vedrai che garantisce che sia incluso il boilerplate giusto in modo che queste funzioni speciali possano essere trattate correttamente dal compilatore. È quello che fa l'API interna di Linux, si evolve se ci sono modi migliori per risolvere il problema.
Qual è il vantaggio di [module_init] nel kernel 2.6
module_init
anche uscito in 2.4, attenzione.
Aggiunge il boilerplate necessario per inizializzare il modulo ed eseguire la funzione entry quando il file del modulo viene compilato nel kernel anziché come modulo.