linux内核notifier机制 linux通知链

在linux内核系统中,各个模块、子系统之间是相互独立的。Linux内核可以通过通知链机制来获取由其它模块或子系统产生的它感兴趣的某些事件。使用notifier由通知者可以传递给被通知者长整型参数与指针。在linux中有许多地方用到,比如reboot通知,cpu调频通知,网卡事件,电池低电警报等等。熟悉使用notifier有助于linux内核驱动开发。

notifier_block结构:

struct notifier_block {
     int (*notifier_call)(struct notifier_block *, unsigned long, void *);
     struct notifier_block __rcu *next;
     int priority;
};

其中,

1. notifier_call:通知链回调函数,由被通知方提供,第一个 参数notifier_block结构体指针,第二第三个参数分别是由call
chain,也就是通知链发起者传递过来的;

2. notifier_block *next:用于链接成链表的指针;

3. priority:回调函数的优先级,一般默认为0。

何时调用到notifier_call?通常在通知链register与unregister定义文件中就有notifier
call发起函数;

下面是具体应用实例:

被通知文件中:

1:在被通知链文件定义一个notifier call函数:

static int xxxx_notify(struct notifier_block *nb,
         unsigned long status, void *unused)
{
     int rc;

     if (!the_chip) {
         pr_err("not initialized\n");
         return -EINVAL;
     }

     switch (status) {
     case 0:
         pr_debug("0 received\n");
         break;
     case 1:
         pr_debug("1 received\n");

         break;
     case 2:

         break;
     default:
         pr_err("error received\n");
         break;
     }

     return 0;
};

2:定义alarm_notifier通知链,将上面定义的函数入口赋值给函数指针

notifier_call;

static struct notifier_block xxxx_notifier = {
     .notifier_call = xxxx_notify,
};

3:注册alarm_notifier通知链:

probe函数里面:

     {
     -----
     rc = xxxx_register_notifier(&alarm_notifier);
     if (rc) {
         pr_err("unable to register alarm notifier rc=%d\n", rc);
         return rc;
     ------
     }

通知文件中:

1:定义notifier register函数,提供给被通知链调用:

int xxxx_register_notifier(struct notifier_block *nb)
{
     -------
     rc = srcu_notifier_chain_register(&chip->irq_notifier_list, nb);
     -------
     return rc;
}
EXPORT_SYMBOL(xxxx_register_notifier);

2:notifier call发起的地方,这里是在中断的queue work里面调用

srcu_notifier_call_chain(),其被内核定义在

notifier.c,注意后面的2个参数会传递给回调函数。

static void xxxx_isr_work(struct work_struct *work)
{
     struct xxxx_chip *chip
         = container_of(work, struct xxxx_chip, irq_work);
     int status;

     if (!chip)
         return;

     status = xxxx_status_read();

     srcu_notifier_call_chain(&chip->irq_notifier_list,
                         status, NULL);

}

时间: 2024-12-18 07:05:15

linux内核notifier机制 linux通知链的相关文章

linux kernel notifier chain(事件通知链)

Linux内核中各个子系统相互依赖,当其中某个子系统状态发生改变时,就必须使用一定的机制告知使用其服务的其他子系统,以便其他子系统采取相应的措施.为满足这样的需求,内核实现了事件通知链机制(notification chain). struct notifier_block { int (*notifier_call)(struct notifier_block *, unsigned long, void *); struct notifier_block *next; int priorit

Linux内核同步机制--转发自蜗窝科技

Linux内核同步机制之(一):原子操作 http://www.wowotech.net/linux_kenrel/atomic.html 一.源由 我们的程序逻辑经常遇到这样的操作序列: 1.读一个位于memory中的变量的值到寄存器中 2.修改该变量的值(也就是修改寄存器中的值) 3.将寄存器中的数值写回memory中的变量值 如果这个操作序列是串行化的操作(在一个thread中串行执行),那么一切OK,然而,世界总是不能如你所愿.在多CPU体系结构中,运行在两个CPU上的两个内核控制路径同

[内核同步]浅析Linux内核同步机制

转自:http://blog.csdn.net/fzubbsc/article/details/37736683?utm_source=tuicool&utm_medium=referral 很早之前就接触过同步这个概念了,但是一直都很模糊,没有深入地学习了解过,近期有时间了,就花时间研习了一下<linux内核标准教程>和<深入linux设备驱动程序内核机制>这两本书的相关章节.趁刚看完,就把相关的内容总结一下.为了弄清楚什么事同步机制,必须要弄明白以下三个问题: 什么是互

Linux内核同步机制

http://blog.csdn.net/bullbat/article/details/7376424 Linux内核同步控制方法有很多,信号量.锁.原子量.RCU等等,不同的实现方法应用于不同的环境来提高操作系统效率.首先,看看我们最熟悉的两种机制——信号量.锁. 一.信号量 首先还是看看内核中是怎么实现的,内核中用struct semaphore数据结构表示信号量(<linux/semphone.h>中): [cpp] view plaincopyprint? struct semaph

Linux内核OOM机制的详细分析(转)

Linux 内核 有个机制叫OOM killer(Out-Of-Memory killer),该机制会监控那些占用内存过大,尤其是瞬间很快消耗大量内存的进程,为了 防止内存耗尽而内核会把该进程杀掉.典型的情况是:某天一台机器突然ssh远程登录不了,但能ping通,说明不是网络的故障,原因是sshd进程被 OOM killer杀掉了(多次遇到这样的假死状况).重启机器后查看系统日志/var/log/messages会发现 Out of Memory: Kill process 1865(sshd)

Linux内核抢占机制 - 实现

本文首发于 http://oliveryang.net,转载时请包含原文或者作者网站链接. 本文主要围绕 Linux 内核调度器 Preemption 的相关实现进行讨论.其中涉及的一般操作系统和 x86 处理器和硬件概念,可能也适用于其它操作系统. 1. Scheduler Overview Linux 调度器的实现实际上主要做了两部分事情, 任务上下文切换 在 Preemption Overview 里,我们对任务上下文切换做了简单介绍.可以看到,任务上下文切换有两个层次的实现:公共层和处理

浅析Linux内核同步机制

很早之前就接触过同步这个概念了,但是一直都很模糊,没有深入地学习了解过,近期有时间了,就花时间研习了一下<linux内核标准教程>和<深入linux设备驱动程序内核机制>这两本书的相关章节.趁刚看完,就把相关的内容总结一下.为了弄清楚什么事同步机制,必须要弄明白以下三个问题: 什么是互斥与同步? 为什么需要同步机制? Linux内核提供哪些方法用于实现互斥与同步的机制? 1.什么是互斥与同步?(通俗理解) 互斥与同步机制是计算机系统中,用于控制进程对某些特定资源的访问的机制. 同步

linux 内核Lockup机制浅析

概念说明 Linux内核Lockup就是linux内核占用CPU不放,Lockup分为两种:soft lockup 和 hard lockup. soft lockup是指CPU被内核代码占据,以至于无法执行其它进程.检测soft lockup的原理是给每个CPU分配一个定时执行的内核线程[watchdog/x], 如果该线程在设定的期限内没有得到执行的话就意味着发生了soft lockup,[watchdog/x]是SCHED_FIFO实时进程,优先级为最高的99,拥有优先运行的特权. har

Linux内核同步机制之completion【转】

Linux内核同步机制之completion 内核编程中常见的一种模式是,在当前线程之外初始化某个活动,然后等待该活动的结束.这个活动可能是,创建一个新的内核线程或者新的用户空间进程.对一个已有进程的某个请求,或者某种类型的硬件动作,等等.在这种情况下,我们可以使用信号量来同步这两个任务.然而,内核中提供了另外一种机制--completion接口.Completion是一种轻量级的机制,他允许一个线程告诉另一个线程某个工作已经完成. 结构与初始化 Completion在内核中的实现基于等待队列(