]> git.baikalelectronics.ru Git - kernel.git/commit
sctp: deny peeloff operation on asocs with threads sleeping on it
authorMarcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Thu, 23 Feb 2017 12:31:18 +0000 (09:31 -0300)
committerDavid S. Miller <davem@davemloft.net>
Fri, 24 Feb 2017 16:10:38 +0000 (11:10 -0500)
commit03a0be62ca02971d25c632175eae6194e7c4d3f8
tree5ac5995348e86b899e6fc634c81fc0f1dce54c37
parent4589f43e3b6027883cf28dae8b2669f3c88f1bcb
sctp: deny peeloff operation on asocs with threads sleeping on it

commit fe5c5b13a7d2 ("sctp: avoid BUG_ON on sctp_wait_for_sndbuf")
attempted to avoid a BUG_ON call when the association being used for a
sendmsg() is blocked waiting for more sndbuf and another thread did a
peeloff operation on such asoc, moving it to another socket.

As Ben Hutchings noticed, then in such case it would return without
locking back the socket and would cause two unlocks in a row.

Further analysis also revealed that it could allow a double free if the
application managed to peeloff the asoc that is created during the
sendmsg call, because then sctp_sendmsg() would try to free the asoc
that was created only for that call.

This patch takes another approach. It will deny the peeloff operation
if there is a thread sleeping on the asoc, so this situation doesn't
exist anymore. This avoids the issues described above and also honors
the syscalls that are already being handled (it can be multiple sendmsg
calls).

Joint work with Xin Long.

Fixes: fe5c5b13a7d2 ("sctp: avoid BUG_ON on sctp_wait_for_sndbuf")
Cc: Alexander Popov <alex.popov@linux.com>
Cc: Ben Hutchings <ben@decadent.org.uk>
Signed-off-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: Xin Long <lucien.xin@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sctp/socket.c