Panic是Linux kernel提供的一种复位机制,内核开发者在开发过程中,可以在异常流程中主动调用。
另外,还有一部分模块或者子系统,希望系统在panic时,能主动通知一下本模块,以便做一些复位前的准备动作,相应的kernel也提供了该机制,就是让大家注册回调。每次panic在执行过程中,会遍历注册的回调函数并回调之。
实现机制:
1、在panic.c代码中,有一个链表的定义,
ATOMIC_NOTIFIER_HEAD(panic_notifier_list);
EXPORT_SYMBOL(panic_notifier_list);
该链表存储各个模块注册的panic回调函数,以便panic在发生时回调对应回调函数。
2、有了链表头,那么注册就简单了。
1)首先定义自己的回调函数
int my_panic_ notify(struct notifier_block *nb,
unsigned long event, void *buf)
{
………
return 0;
}
static struct notifier_block my_panic_block = {
.notifier_call = my_panic_ notify,
.priority = INT_MAX,
};
然后,在合适的地方,注册到panic链表中(通常是在本模块初始化)
………….
atomic_notifier_chain_register(&panic_notifier_list, & my_panic_block);
…………
3、注册完成后,当系统中有调用panic函数时,panic在执行过程中就会回调注册的函数。
…………..
atomic_notifier_call_chain(&panic_notifier_list, 0, buf);
…………….
附:同样,在die函数被调用时,也有类似的机制,不做详细介绍,大家可以看一下register_die_notifier/ unregister_die_notifier的相关实现。
未定义指令异常,参考register_undef_hook函数相关实现