sctp: walk the list of asoc safely
In sctp_sendmesg(), when walking the list of endpoint associations, the
association can be dropped from the list, making the list corrupt.
Properly handle this by using list_for_each_entry_safe()
Fixes: 4910280503
("sctp: add support for snd flag SCTP_SENDALL process in sendmsg")
Reported-by: Secunia Research <vuln@secunia.com>
Tested-by: Secunia Research <vuln@secunia.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Acked-by: Neil Horman <nhorman@tuxdriver.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
34dbba5d2d
commit
ba59fb0273
|
@ -2027,7 +2027,7 @@ static int sctp_sendmsg(struct sock *sk, struct msghdr *msg, size_t msg_len)
|
|||
struct sctp_endpoint *ep = sctp_sk(sk)->ep;
|
||||
struct sctp_transport *transport = NULL;
|
||||
struct sctp_sndrcvinfo _sinfo, *sinfo;
|
||||
struct sctp_association *asoc;
|
||||
struct sctp_association *asoc, *tmp;
|
||||
struct sctp_cmsgs cmsgs;
|
||||
union sctp_addr *daddr;
|
||||
bool new = false;
|
||||
|
@ -2053,7 +2053,7 @@ static int sctp_sendmsg(struct sock *sk, struct msghdr *msg, size_t msg_len)
|
|||
|
||||
/* SCTP_SENDALL process */
|
||||
if ((sflags & SCTP_SENDALL) && sctp_style(sk, UDP)) {
|
||||
list_for_each_entry(asoc, &ep->asocs, asocs) {
|
||||
list_for_each_entry_safe(asoc, tmp, &ep->asocs, asocs) {
|
||||
err = sctp_sendmsg_check_sflags(asoc, sflags, msg,
|
||||
msg_len);
|
||||
if (err == 0)
|
||||
|
|
Loading…
Reference in New Issue