OSDN Git Service

sctp: call iov_iter_revert() after sending ABORT
authorXin Long <lucien.xin@gmail.com>
Sun, 3 Mar 2019 08:50:26 +0000 (16:50 +0800)
committerDavid S. Miller <davem@davemloft.net>
Mon, 4 Mar 2019 18:58:54 +0000 (10:58 -0800)
The user msg is also copied to the abort packet when doing SCTP_ABORT in
sctp_sendmsg_check_sflags(). When SCTP_SENDALL is set, iov_iter_revert()
should have been called for sending abort on the next asoc with copying
this msg. Otherwise, memcpy_from_msg() in sctp_make_abort_user() will
fail and return error.

Fixes: 4910280503f3 ("sctp: add support for snd flag SCTP_SENDALL process in sendmsg")
Reported-by: Ying Xu <yinxu@redhat.com>
Signed-off-by: Xin Long <lucien.xin@gmail.com>
Acked-by: Neil Horman <nhorman@tuxdriver.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/sctp/socket.c

index a78e55a..533207d 100644 (file)
@@ -1866,6 +1866,7 @@ static int sctp_sendmsg_check_sflags(struct sctp_association *asoc,
 
                pr_debug("%s: aborting association:%p\n", __func__, asoc);
                sctp_primitive_ABORT(net, asoc, chunk);
+               iov_iter_revert(&msg->msg_iter, msg_len);
 
                return 0;
        }