Commit dc182470 authored by Eric Dumazet's avatar Eric Dumazet Committed by Luis Henriques

ipv6: sctp: implement sctp_v6_destroy_sock()

commit 602dd62d upstream.

Dmitry Vyukov reported a memory leak using IPV6 SCTP sockets.

We need to call inet6_destroy_sock() to properly release
inet6 specific fields.
Reported-by: default avatarDmitry Vyukov <dvyukov@google.com>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Acked-by: default avatarDaniel Borkmann <daniel@iogearbox.net>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarLuis Henriques <luis.henriques@canonical.com>
parent 883fab64
...@@ -7179,6 +7179,13 @@ struct proto sctp_prot = { ...@@ -7179,6 +7179,13 @@ struct proto sctp_prot = {
#if IS_ENABLED(CONFIG_IPV6) #if IS_ENABLED(CONFIG_IPV6)
#include <net/transp_v6.h>
static void sctp_v6_destroy_sock(struct sock *sk)
{
sctp_destroy_sock(sk);
inet6_destroy_sock(sk);
}
struct proto sctpv6_prot = { struct proto sctpv6_prot = {
.name = "SCTPv6", .name = "SCTPv6",
.owner = THIS_MODULE, .owner = THIS_MODULE,
...@@ -7188,7 +7195,7 @@ struct proto sctpv6_prot = { ...@@ -7188,7 +7195,7 @@ struct proto sctpv6_prot = {
.accept = sctp_accept, .accept = sctp_accept,
.ioctl = sctp_ioctl, .ioctl = sctp_ioctl,
.init = sctp_init_sock, .init = sctp_init_sock,
.destroy = sctp_destroy_sock, .destroy = sctp_v6_destroy_sock,
.shutdown = sctp_shutdown, .shutdown = sctp_shutdown,
.setsockopt = sctp_setsockopt, .setsockopt = sctp_setsockopt,
.getsockopt = sctp_getsockopt, .getsockopt = sctp_getsockopt,
......
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