aboutsummaryrefslogtreecommitdiffstats
path: root/net/openvswitch/datapath.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/openvswitch/datapath.c')
-rw-r--r--net/openvswitch/datapath.c36
1 files changed, 16 insertions, 20 deletions
diff --git a/net/openvswitch/datapath.c b/net/openvswitch/datapath.c
index 49ee37b83a29..d406503e01b6 100644
--- a/net/openvswitch/datapath.c
+++ b/net/openvswitch/datapath.c
@@ -71,6 +71,13 @@ static int ovs_net_id __read_mostly;
71static void rehash_flow_table(struct work_struct *work); 71static void rehash_flow_table(struct work_struct *work);
72static DECLARE_DELAYED_WORK(rehash_flow_wq, rehash_flow_table); 72static DECLARE_DELAYED_WORK(rehash_flow_wq, rehash_flow_table);
73 73
74static void ovs_notify(struct sk_buff *skb, struct genl_info *info,
75 struct genl_multicast_group *grp)
76{
77 genl_notify(skb, genl_info_net(info), info->snd_portid,
78 grp->id, info->nlhdr, GFP_KERNEL);
79}
80
74/** 81/**
75 * DOC: Locking: 82 * DOC: Locking:
76 * 83 *
@@ -1061,9 +1068,7 @@ static int ovs_flow_cmd_new_or_set(struct sk_buff *skb, struct genl_info *info)
1061 } 1068 }
1062 1069
1063 if (!IS_ERR(reply)) 1070 if (!IS_ERR(reply))
1064 genl_notify(reply, genl_info_net(info), info->snd_portid, 1071 ovs_notify(reply, info, &ovs_dp_flow_multicast_group);
1065 ovs_dp_flow_multicast_group.id, info->nlhdr,
1066 GFP_KERNEL);
1067 else 1072 else
1068 netlink_set_err(sock_net(skb->sk)->genl_sock, 0, 1073 netlink_set_err(sock_net(skb->sk)->genl_sock, 0,
1069 ovs_dp_flow_multicast_group.id, PTR_ERR(reply)); 1074 ovs_dp_flow_multicast_group.id, PTR_ERR(reply));
@@ -1150,8 +1155,7 @@ static int ovs_flow_cmd_del(struct sk_buff *skb, struct genl_info *info)
1150 1155
1151 ovs_flow_deferred_free(flow); 1156 ovs_flow_deferred_free(flow);
1152 1157
1153 genl_notify(reply, genl_info_net(info), info->snd_portid, 1158 ovs_notify(reply, info, &ovs_dp_flow_multicast_group);
1154 ovs_dp_flow_multicast_group.id, info->nlhdr, GFP_KERNEL);
1155 return 0; 1159 return 0;
1156} 1160}
1157 1161
@@ -1383,9 +1387,7 @@ static int ovs_dp_cmd_new(struct sk_buff *skb, struct genl_info *info)
1383 list_add_tail(&dp->list_node, &ovs_net->dps); 1387 list_add_tail(&dp->list_node, &ovs_net->dps);
1384 rtnl_unlock(); 1388 rtnl_unlock();
1385 1389
1386 genl_notify(reply, genl_info_net(info), info->snd_portid, 1390 ovs_notify(reply, info, &ovs_dp_datapath_multicast_group);
1387 ovs_dp_datapath_multicast_group.id, info->nlhdr,
1388 GFP_KERNEL);
1389 return 0; 1391 return 0;
1390 1392
1391err_destroy_local_port: 1393err_destroy_local_port:
@@ -1453,9 +1455,7 @@ static int ovs_dp_cmd_del(struct sk_buff *skb, struct genl_info *info)
1453 1455
1454 __dp_destroy(dp); 1456 __dp_destroy(dp);
1455 1457
1456 genl_notify(reply, genl_info_net(info), info->snd_portid, 1458 ovs_notify(reply, info, &ovs_dp_datapath_multicast_group);
1457 ovs_dp_datapath_multicast_group.id, info->nlhdr,
1458 GFP_KERNEL);
1459 1459
1460 return 0; 1460 return 0;
1461} 1461}
@@ -1479,9 +1479,7 @@ static int ovs_dp_cmd_set(struct sk_buff *skb, struct genl_info *info)
1479 return 0; 1479 return 0;
1480 } 1480 }
1481 1481
1482 genl_notify(reply, genl_info_net(info), info->snd_portid, 1482 ovs_notify(reply, info, &ovs_dp_datapath_multicast_group);
1483 ovs_dp_datapath_multicast_group.id, info->nlhdr,
1484 GFP_KERNEL);
1485 1483
1486 return 0; 1484 return 0;
1487} 1485}
@@ -1727,8 +1725,8 @@ static int ovs_vport_cmd_new(struct sk_buff *skb, struct genl_info *info)
1727 ovs_dp_detach_port(vport); 1725 ovs_dp_detach_port(vport);
1728 goto exit_unlock; 1726 goto exit_unlock;
1729 } 1727 }
1730 genl_notify(reply, genl_info_net(info), info->snd_portid, 1728
1731 ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL); 1729 ovs_notify(reply, info, &ovs_dp_vport_multicast_group);
1732 1730
1733exit_unlock: 1731exit_unlock:
1734 rtnl_unlock(); 1732 rtnl_unlock();
@@ -1769,8 +1767,7 @@ static int ovs_vport_cmd_set(struct sk_buff *skb, struct genl_info *info)
1769 goto exit_unlock; 1767 goto exit_unlock;
1770 } 1768 }
1771 1769
1772 genl_notify(reply, genl_info_net(info), info->snd_portid, 1770 ovs_notify(reply, info, &ovs_dp_vport_multicast_group);
1773 ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
1774 1771
1775exit_unlock: 1772exit_unlock:
1776 rtnl_unlock(); 1773 rtnl_unlock();
@@ -1804,8 +1801,7 @@ static int ovs_vport_cmd_del(struct sk_buff *skb, struct genl_info *info)
1804 err = 0; 1801 err = 0;
1805 ovs_dp_detach_port(vport); 1802 ovs_dp_detach_port(vport);
1806 1803
1807 genl_notify(reply, genl_info_net(info), info->snd_portid, 1804 ovs_notify(reply, info, &ovs_dp_vport_multicast_group);
1808 ovs_dp_vport_multicast_group.id, info->nlhdr, GFP_KERNEL);
1809 1805
1810exit_unlock: 1806exit_unlock:
1811 rtnl_unlock(); 1807 rtnl_unlock();