2
0
mirror of https://github.com/openvswitch/ovs synced 2025-10-13 14:07:02 +00:00
Files
openvswitch/datapath/dp_notify.c
Ben Pfaff 7237e4f4b6 datapath: Merge vport "attach" into "create" and "detach" into "destroy".
These steps are sequentially in lockstep, so we might as well combine them.

This expands the region over which the vport_lock is held.  I didn't
carefully verify that this was OK.

This also eliminates the synchronize_rcu() call from destruction of tunnel
vports, since they didn't appear to me to need it.

It should be possible to eliminate the synchronize_rcu() from the netdev,
patch, and internal_dev vports, but this commit does not do that.

Signed-off-by: Ben Pfaff <blp@nicira.com>
Acked-by: Jesse Gross <jesse@nicira.com>
2010-12-03 15:44:51 -08:00

63 lines
1.3 KiB
C

/*
* 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 datapath *dp;
if (is_internal_dev(dev))
vport = internal_dev_get_vport(dev);
else
vport = netdev_get_vport(dev);
if (!vport)
return NOTIFY_DONE;
dp = vport->dp;
switch (event) {
case NETDEV_UNREGISTER:
if (!is_internal_dev(dev)) {
mutex_lock(&dp->mutex);
dp_detach_port(vport);
mutex_unlock(&dp->mutex);
}
break;
case NETDEV_CHANGENAME:
if (vport->port_no != ODPP_LOCAL) {
mutex_lock(&dp->mutex);
dp_sysfs_del_if(vport);
dp_sysfs_add_if(vport);
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
};