Linux内核提供了一种很有趣的特性,也就是所谓的通知链(notifier call chain),这个特性不只是在模块的加载过程中会使用到,在内核系统的其它组件中也常常会使用到。通过通知链,模块或者其他的内核组件可以向其感兴趣的一些内核事件进行注册,当该事件发生时,这些模块或者组件当初注册的回调函数将会被调用。
内核模块机制中实现的模块通知链module_notify_list就是内核中众多通知链的一条。通知链的实现机制很简单,通过链表的形式,内核将那些注册进来的关注同类事件的节点构成一个链表,当某一特定的内核事件发生时,事件所属的内核组件负责遍历该通知链上的所有节点,调用节点上的回调函数。
通知链成员的数据结构:
53 struct notifier_block {
54 notifier_fn_t notifier_call;
55 struct notifier_block __rcu *next;
56 int priority;
57 };
其中,notifier_call为注册的回调函数,next用来构成链表,priority代表一个通知节点的优先级,越高优先级的节点就越靠近头节点,因而当有事件发生时,就越早得到通知。
内核中的一条通知链构成示意图: