- struct net_bridge_port *p = dev->br_port;
- if (event == NETDEV_UNREGISTER && p) {
- struct datapath *dp = p->dp;
- mutex_lock(&dp->mutex);
- dp_del_port(p, NULL);
- mutex_unlock(&dp->mutex);
+ 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)) {
+ struct sk_buff *reply;
+
+ reply = ovs_vport_cmd_build_info(vport, 0, 0,
+ OVS_VPORT_CMD_DEL);
+ dp_detach_port(vport);
+ if (IS_ERR(reply)) {
+ netlink_set_err(INIT_NET_GENL_SOCK, 0,
+ dp_vport_multicast_group.id,
+ PTR_ERR(reply));
+ break;
+ }
+
+ genl_notify(reply, dev_net(dev), 0,
+ dp_vport_multicast_group.id, NULL,
+ GFP_KERNEL);
+ }
+ break;
+
+ case NETDEV_CHANGENAME:
+ if (vport->port_no != OVSP_LOCAL) {
+ dp_sysfs_del_if(vport);
+ dp_sysfs_add_if(vport);
+ }
+ break;