From: Xiaodong Xu Date: Sat, 22 Sep 2012 00:09:32 +0000 (+0000) Subject: pppoe: drop PPPOX_ZOMBIEs in pppoe_release X-Git-Tag: firefly_0821_release~7541^2~539 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=0ddaf88b27c6c942d3e921a2b0a7d8cae6d5be19;p=firefly-linux-kernel-4.4.55.git pppoe: drop PPPOX_ZOMBIEs in pppoe_release [ Upstream commit 2b018d57ff18e5405823e5cb59651a5b4d946d7b ] When PPPOE is running over a virtual ethernet interface (e.g., a bonding interface) and the user tries to delete the interface in case the PPPOE state is ZOMBIE, the kernel will loop forever while unregistering net_device for the reference count is not decreased to zero which should have been done with dev_put(). Signed-off-by: Xiaodong Xu Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/net/pppoe.c b/drivers/net/pppoe.c index bc9a4bb31980..11615842a57b 100644 --- a/drivers/net/pppoe.c +++ b/drivers/net/pppoe.c @@ -576,7 +576,7 @@ static int pppoe_release(struct socket *sock) po = pppox_sk(sk); - if (sk->sk_state & (PPPOX_CONNECTED | PPPOX_BOUND)) { + if (sk->sk_state & (PPPOX_CONNECTED | PPPOX_BOUND | PPPOX_ZOMBIE)) { dev_put(po->pppoe_dev); po->pppoe_dev = NULL; }