forked from rrcarlosr/Jetpack
36 lines
1011 B
Diff
36 lines
1011 B
Diff
From 79a40ff30174cfed8f1c4448407c547edba4088a Mon Sep 17 00:00:00 2001
|
|
From: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
|
|
Date: Thu, 21 Sep 2017 14:42:04 +0200
|
|
Subject: [PATCH 346/352] net: use trylock in icmp_sk
|
|
|
|
The locking path can be recursive (same as for sk->sk_lock.slock) and
|
|
therefore we need a trylock version for the locallock, too.
|
|
|
|
Cc: stable-rt@vger.kernel.org
|
|
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
|
|
Signed-off-by: Steven Rostedt (VMware) <rostedt@goodmis.org>
|
|
---
|
|
net/ipv4/icmp.c | 6 +++++-
|
|
1 file changed, 5 insertions(+), 1 deletion(-)
|
|
|
|
diff --git a/net/ipv4/icmp.c b/net/ipv4/icmp.c
|
|
index 68953e5..5f3f49f 100644
|
|
--- a/net/ipv4/icmp.c
|
|
+++ b/net/ipv4/icmp.c
|
|
@@ -219,7 +219,11 @@ static inline struct sock *icmp_xmit_lock(struct net *net)
|
|
|
|
local_bh_disable();
|
|
|
|
- local_lock(icmp_sk_lock);
|
|
+ if (!local_trylock(icmp_sk_lock)) {
|
|
+ local_bh_enable();
|
|
+ return NULL;
|
|
+ }
|
|
+
|
|
sk = icmp_sk(net);
|
|
|
|
if (unlikely(!spin_trylock(&sk->sk_lock.slock))) {
|
|
--
|
|
2.7.4
|
|
|