Commit 82e52ffa authored by Xin Long's avatar Xin Long Committed by Jiri Slaby

sctp: listen on the sock only when it's state is listening or closed

[ Upstream commit 34b2789f ]

Now sctp doesn't check sock's state before listening on it. It could
even cause changing a sock with any state to become a listening sock
when doing sctp_listen.

This patch is to fix it by checking sock's state in sctp_listen, so
that it will listen on the sock with right state.
Reported-by: default avatarAndrey Konovalov <andreyknvl@google.com>
Tested-by: default avatarAndrey Konovalov <andreyknvl@google.com>
Signed-off-by: default avatarXin Long <lucien.xin@gmail.com>
Acked-by: default avatarMarcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 3101698f
...@@ -6169,6 +6169,9 @@ int sctp_inet_listen(struct socket *sock, int backlog) ...@@ -6169,6 +6169,9 @@ int sctp_inet_listen(struct socket *sock, int backlog)
if (sock->state != SS_UNCONNECTED) if (sock->state != SS_UNCONNECTED)
goto out; goto out;
if (!sctp_sstate(sk, LISTENING) && !sctp_sstate(sk, CLOSED))
goto out;
/* If backlog is zero, disable listening. */ /* If backlog is zero, disable listening. */
if (!backlog) { if (!backlog) {
if (sctp_sstate(sk, CLOSED)) if (sctp_sstate(sk, CLOSED))
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment