模块API之register_module_notifier
2017-11-14 08:59
1871 查看
int register_module_notifier(struct notifier_block *nb)
函数用于注册需要知道当前模块的状态,然后触发一个回调函数
使用的例子如下:
static __init int jump_label_init_module(void)
{
return register_module_notifier(&jump_label_module_nb);
}
注册的回调函数如下:
static struct notifier_block jump_label_module_nb = {
.notifier_call = jump_label_module_notify,
.priority = 1, /* higher than tracepoints */
};
其源码分享如下:
int register_module_notifier(struct notifier_block *nb)
{
return blocking_notifier_chain_register(&module_notify_list, nb);
}
可见就是注册了一个通用的通知链,那在什么时候触发这个通知链呢?
这个通知链定义如下:
static BLOCKING_NOTIFIER_HEAD(module_notify_list);
会出删除模块的时候调用,通知链的参数是MODULE_STATE_GOING
SYSCALL_DEFINE2(delete_module, const char __user *, name_user,
unsigned int, flags)
{
blocking_notifier_call_chain(&module_notify_list,
MODULE_STATE_GOING, mod);
}
会在模块初始化的时候调用通知链,参数是MODULE_STATE_LIVE
static noinline int do_init_module(struct module *mod)
{
/* Now it's a first class citizen! */
mod->state = MODULE_STATE_LIVE;
blocking_notifier_call_chain(&module_notify_list,
MODULE_STATE_LIVE, mod);
}
总而言之,针对模块的每个状态
enum module_state {
MODULE_STATE_LIVE,
/* Normal state. */
MODULE_STATE_COMING,
/* Full formed, running module_init. */
MODULE_STATE_GOING,
/* Going away. */
MODULE_STATE_UNFORMED,
/* Still setting it up. */
};
都会发出一次通知链
函数用于注册需要知道当前模块的状态,然后触发一个回调函数
使用的例子如下:
static __init int jump_label_init_module(void)
{
return register_module_notifier(&jump_label_module_nb);
}
注册的回调函数如下:
static struct notifier_block jump_label_module_nb = {
.notifier_call = jump_label_module_notify,
.priority = 1, /* higher than tracepoints */
};
其源码分享如下:
int register_module_notifier(struct notifier_block *nb)
{
return blocking_notifier_chain_register(&module_notify_list, nb);
}
可见就是注册了一个通用的通知链,那在什么时候触发这个通知链呢?
这个通知链定义如下:
static BLOCKING_NOTIFIER_HEAD(module_notify_list);
会出删除模块的时候调用,通知链的参数是MODULE_STATE_GOING
SYSCALL_DEFINE2(delete_module, const char __user *, name_user,
unsigned int, flags)
{
blocking_notifier_call_chain(&module_notify_list,
MODULE_STATE_GOING, mod);
}
会在模块初始化的时候调用通知链,参数是MODULE_STATE_LIVE
static noinline int do_init_module(struct module *mod)
{
/* Now it's a first class citizen! */
mod->state = MODULE_STATE_LIVE;
blocking_notifier_call_chain(&module_notify_list,
MODULE_STATE_LIVE, mod);
}
总而言之,针对模块的每个状态
enum module_state {
MODULE_STATE_LIVE,
/* Normal state. */
MODULE_STATE_COMING,
/* Full formed, running module_init. */
MODULE_STATE_GOING,
/* Going away. */
MODULE_STATE_UNFORMED,
/* Still setting it up. */
};
都会发出一次通知链
相关文章推荐
- 模块API之module_put/__module_get
- 模块API之module_refcount
- intel dpdk api interrupt module 中断模块介绍
- Springboot整合dubbo构建maven多模块项目(三) - 把server分为api(服务接口定义)和server(服务实现)两个子module
- intel dpdk api memory manage module (内存管理模块)
- 模块API之module_get_kallsym
- 模块API之ref_module
- 模块API之find_module
- 模块API之lookup_module_symbol_name
- 模块API之__module_text_address
- 模块API之lookup_module_symbol_attrs
- 进程调度API之preempt_notifier_register/preempt_notifier_unregister
- 模块API之__module_address
- 模块API之module_is_live
- 模块API之try_module_get
- 模块API之module_address_lookup
- intel dpdk api interrupt module 中断模块介绍
- 【精选】Nginx模块Lua-Nginx-Module学习笔记(一)Nginx Lua API 接口详解
- apache 模块开发提示错误Cant locate api module
- SIP模块版本错误问题:the sip module implements API v??? but XXX module requires API v???