Blame view
net/core/netevent.c
2.03 KB
792d1932e
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
/* * Network event notifiers * * Authors: * Tom Tucker <tom@opengridcomputing.com> * Steve Wise <swise@opengridcomputing.com> * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version * 2 of the License, or (at your option) any later version. * * Fixes: */ #include <linux/rtnetlink.h> #include <linux/notifier.h> |
94b83419e
|
18 |
#include <net/netevent.h> |
792d1932e
|
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
static ATOMIC_NOTIFIER_HEAD(netevent_notif_chain); /** * register_netevent_notifier - register a netevent notifier block * @nb: notifier * * Register a notifier to be called when a netevent occurs. * The notifier passed is linked into the kernel structures and must * not be reused until it has been unregistered. A negative errno code * is returned on a failure. */ int register_netevent_notifier(struct notifier_block *nb) { int err; err = atomic_notifier_chain_register(&netevent_notif_chain, nb); return err; } |
9e34a5b51
|
38 |
EXPORT_SYMBOL_GPL(register_netevent_notifier); |
792d1932e
|
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
/** * netevent_unregister_notifier - unregister a netevent notifier block * @nb: notifier * * Unregister a notifier previously registered by * register_neigh_notifier(). The notifier is unlinked into the * kernel structures and may then be reused. A negative errno code * is returned on a failure. */ int unregister_netevent_notifier(struct notifier_block *nb) { return atomic_notifier_chain_unregister(&netevent_notif_chain, nb); } |
9e34a5b51
|
54 |
EXPORT_SYMBOL_GPL(unregister_netevent_notifier); |
792d1932e
|
55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
/** * call_netevent_notifiers - call all netevent notifier blocks * @val: value passed unmodified to notifier function * @v: pointer passed unmodified to notifier function * * Call all neighbour notifier blocks. Parameters and return value * are as for notifier_call_chain(). */ int call_netevent_notifiers(unsigned long val, void *v) { return atomic_notifier_call_chain(&netevent_notif_chain, val, v); } |
792d1932e
|
69 |
EXPORT_SYMBOL_GPL(call_netevent_notifiers); |