diff options
author | Johannes Berg <johannes.berg@intel.com> | 2013-08-21 10:08:02 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2013-08-22 16:24:02 -0400 |
commit | 9d47b380563174e5c15776ce6ca9bab4ee7d59e3 (patch) | |
tree | c88dbe342a7ece90aab4341cb7b8112293e86689 /net/netlink | |
parent | e75dc677ff8d06ffa61bef6fee436227ae5440c6 (diff) |
Revert "genetlink: fix family dump race"
This reverts commit 58ad436fcf49810aa006016107f494c9ac9013db.
It turns out that the change introduced a potential deadlock
by causing a locking dependency with netlink's cb_mutex. I
can't seem to find a way to resolve this without doing major
changes to the locking, so revert this.
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Acked-by: Pravin B Shelar <pshelar@nicira.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/netlink')
-rw-r--r-- | net/netlink/genetlink.c | 7 |
1 files changed, 0 insertions, 7 deletions
diff --git a/net/netlink/genetlink.c b/net/netlink/genetlink.c index f85f8a2ad6cf..512718adb0d5 100644 --- a/net/netlink/genetlink.c +++ b/net/netlink/genetlink.c | |||
@@ -789,10 +789,6 @@ static int ctrl_dumpfamily(struct sk_buff *skb, struct netlink_callback *cb) | |||
789 | struct net *net = sock_net(skb->sk); | 789 | struct net *net = sock_net(skb->sk); |
790 | int chains_to_skip = cb->args[0]; | 790 | int chains_to_skip = cb->args[0]; |
791 | int fams_to_skip = cb->args[1]; | 791 | int fams_to_skip = cb->args[1]; |
792 | bool need_locking = chains_to_skip || fams_to_skip; | ||
793 | |||
794 | if (need_locking) | ||
795 | genl_lock(); | ||
796 | 792 | ||
797 | for (i = chains_to_skip; i < GENL_FAM_TAB_SIZE; i++) { | 793 | for (i = chains_to_skip; i < GENL_FAM_TAB_SIZE; i++) { |
798 | n = 0; | 794 | n = 0; |
@@ -814,9 +810,6 @@ errout: | |||
814 | cb->args[0] = i; | 810 | cb->args[0] = i; |
815 | cb->args[1] = n; | 811 | cb->args[1] = n; |
816 | 812 | ||
817 | if (need_locking) | ||
818 | genl_unlock(); | ||
819 | |||
820 | return skb->len; | 813 | return skb->len; |
821 | } | 814 | } |
822 | 815 | ||