blob: b6bb90ec7ec415ccd25a00b2b4b6a404c3cd9b8b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
/*
* Distributed under the terms of the GNU GPL version 2.
* Copyright (c) 2007, 2008, 2009, 2010 Nicira Networks.
*
* Significant portions of this file may be copied from parts of the Linux
* kernel, by Linus Torvalds and others.
*/
/* Handle changes to managed devices */
#include <linux/netdevice.h>
#include "datapath.h"
#include "vport-internal_dev.h"
#include "vport-netdev.h"
static int dp_device_event(struct notifier_block *unused, unsigned long event,
void *ptr)
{
struct net_device *dev = ptr;
struct vport *vport;
struct dp_port *p;
struct datapath *dp;
if (is_internal_dev(dev))
vport = internal_dev_get_vport(dev);
else
vport = netdev_get_vport(dev);
if (!vport)
return NOTIFY_DONE;
p = vport_get_dp_port(vport);
if (!p)
return NOTIFY_DONE;
dp = p->dp;
switch (event) {
case NETDEV_UNREGISTER:
mutex_lock(&dp->mutex);
dp_detach_port(p, 1);
mutex_unlock(&dp->mutex);
break;
case NETDEV_CHANGENAME:
if (p->port_no != ODPP_LOCAL) {
mutex_lock(&dp->mutex);
dp_sysfs_del_if(p);
dp_sysfs_add_if(p);
mutex_unlock(&dp->mutex);
}
break;
case NETDEV_CHANGEMTU:
if (!is_internal_dev(dev))
set_internal_devs_mtu(dp);
break;
}
return NOTIFY_DONE;
}
struct notifier_block dp_device_notifier = {
.notifier_call = dp_device_event
};
|