Re: [PATCH] tipc: fix stall during bclink wakeup procedure

From: David Miller
Date: Wed Sep 02 2015 - 19:27:25 EST


From: Kolmakov Dmitriy <kolmakov.dmitriy@xxxxxxxxxx>
Date: Wed, 2 Sep 2015 15:33:00 +0000

> If an attempt to wake up users of broadcast link is made when there
> is no enough place in send queue than it may hang up inside the
> tipc_sk_rcv() function since the loop breaks only after the wake up
> queue becomes empty. This can lead to complete CPU stall with the
> following message generated by RCU:

I don't understand how it can loop forever.

It should either successfully deliver each packet to the socket,
or respond with a TIPC_ERR_OVERLOAD.

In both cases, the SKB is dequeued from the queue and forward
progress is made.

If there really is a problem somewhere in here, then two things:

1) You need to describe exactly the sequence of tests and conditions
that lead to the endless loop in this code, because I cannot see
it.

2) I suspect the fix is more likely to be appropriate in tipc_sk_rcv()
or similar, rather than creating a dummy queue to workaround it's
behavior.

Thanks.
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/