天天看点

当panic或者die被执行时,或者发生未定义指令时,如何被回调到

    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函数相关实现

继续阅读