mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 23:20:05 +00:00
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: 4910280503f3 ("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…
x
Reference in New Issue
Block a user