Commit 348a1cd8 authored by Willem de Bruijn's avatar Willem de Bruijn Committed by Greg Kroah-Hartman

sock_diag: do not broadcast raw socket destruction

[ Upstream commit 9a0fee2b ]

Diag intends to broadcast tcp_sk and udp_sk socket destruction.
Testing sk->sk_protocol for IPPROTO_TCP/IPPROTO_UDP alone is not
sufficient for this. Raw sockets can have the same type.

Add a test for sk->sk_type.

Fixes: eb4cb008 ("sock_diag: define destruction multicast groups")
Signed-off-by: default avatarWillem de Bruijn <willemb@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 688feac4
...@@ -35,6 +35,9 @@ enum sknetlink_groups sock_diag_destroy_group(const struct sock *sk) ...@@ -35,6 +35,9 @@ enum sknetlink_groups sock_diag_destroy_group(const struct sock *sk)
{ {
switch (sk->sk_family) { switch (sk->sk_family) {
case AF_INET: case AF_INET:
if (sk->sk_type == SOCK_RAW)
return SKNLGRP_NONE;
switch (sk->sk_protocol) { switch (sk->sk_protocol) {
case IPPROTO_TCP: case IPPROTO_TCP:
return SKNLGRP_INET_TCP_DESTROY; return SKNLGRP_INET_TCP_DESTROY;
...@@ -44,6 +47,9 @@ enum sknetlink_groups sock_diag_destroy_group(const struct sock *sk) ...@@ -44,6 +47,9 @@ enum sknetlink_groups sock_diag_destroy_group(const struct sock *sk)
return SKNLGRP_NONE; return SKNLGRP_NONE;
} }
case AF_INET6: case AF_INET6:
if (sk->sk_type == SOCK_RAW)
return SKNLGRP_NONE;
switch (sk->sk_protocol) { switch (sk->sk_protocol) {
case IPPROTO_TCP: case IPPROTO_TCP:
return SKNLGRP_INET6_TCP_DESTROY; return SKNLGRP_INET6_TCP_DESTROY;
......
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