mirror of
https://github.com/openvswitch/ovs
synced 2025-10-13 14:07:02 +00:00
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>
63 lines
1.3 KiB
C
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
|
|
};
|