net/netfilter/nf_conntrack_core: Fix net_conntrack_lock()
authorManfred Spraul <manfred@colorfullife.com>
Thu, 6 Jul 2017 18:45:59 +0000 (20:45 +0200)
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>
Tue, 25 Jul 2017 17:08:58 +0000 (10:08 -0700)
commit3ef0c7a730de0bae03d86c19570af764fa3c4445
tree163b6a44bc7e31525ffb39304b2136ac74651d45
parent931ab4a5ce2d93cb434dc7fc067a702117453b13
net/netfilter/nf_conntrack_core: Fix net_conntrack_lock()

As we want to remove spin_unlock_wait() and replace it with explicit
spin_lock()/spin_unlock() calls, we can use this to simplify the
locking.

In addition:
- Reading nf_conntrack_locks_all needs ACQUIRE memory ordering.
- The new code avoids the backwards loop.

Only slightly tested, I did not manage to trigger calls to
nf_conntrack_all_lock().

V2: With improved comments, to clearly show how the barriers
    pair.

Fixes: b16c29191dc8 ("netfilter: nf_conntrack: use safer way to lock all buckets")
Signed-off-by: Manfred Spraul <manfred@colorfullife.com>
Cc: <stable@vger.kernel.org>
Cc: Alan Stern <stern@rowland.harvard.edu>
Cc: Sasha Levin <sasha.levin@oracle.com>
Cc: Pablo Neira Ayuso <pablo@netfilter.org>
Cc: netfilter-devel@vger.kernel.org
Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
net/netfilter/nf_conntrack_core.c