compat_ip{,v6}_setsockopt(): enumerate MCAST_... options explicitly
authorAl Viro <viro@zeniv.linux.org.uk>
Sun, 10 May 2020 01:16:36 +0000 (21:16 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Thu, 21 May 2020 00:31:26 +0000 (20:31 -0400)
We want to check if optname is among the MCAST_... ones; do that as
an explicit switch.

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
net/ipv4/ip_sockglue.c
net/ipv6/ipv6_sockglue.c

index 8206047..3c2c6cd 100644 (file)
@@ -1272,9 +1272,17 @@ int compat_ip_setsockopt(struct sock *sk, int level, int optname,
        if (level != SOL_IP)
                return -ENOPROTOOPT;
 
-       if (optname >= MCAST_JOIN_GROUP && optname <= MCAST_MSFILTER)
+       switch (optname) {
+       case MCAST_JOIN_GROUP:
+       case MCAST_LEAVE_GROUP:
+       case MCAST_JOIN_SOURCE_GROUP:
+       case MCAST_LEAVE_SOURCE_GROUP:
+       case MCAST_BLOCK_SOURCE:
+       case MCAST_UNBLOCK_SOURCE:
+       case MCAST_MSFILTER:
                return compat_mc_setsockopt(sk, level, optname, optval, optlen,
                        ip_setsockopt);
+       }
 
        err = do_ip_setsockopt(sk, level, optname, optval, optlen);
 #ifdef CONFIG_NETFILTER
index a0e50cc..96e3f60 100644 (file)
@@ -973,9 +973,17 @@ int compat_ipv6_setsockopt(struct sock *sk, int level, int optname,
        if (level != SOL_IPV6)
                return -ENOPROTOOPT;
 
-       if (optname >= MCAST_JOIN_GROUP && optname <= MCAST_MSFILTER)
+       switch (optname) {
+       case MCAST_JOIN_GROUP:
+       case MCAST_LEAVE_GROUP:
+       case MCAST_JOIN_SOURCE_GROUP:
+       case MCAST_LEAVE_SOURCE_GROUP:
+       case MCAST_BLOCK_SOURCE:
+       case MCAST_UNBLOCK_SOURCE:
+       case MCAST_MSFILTER:
                return compat_mc_setsockopt(sk, level, optname, optval, optlen,
                        ipv6_setsockopt);
+       }
 
        err = do_ipv6_setsockopt(sk, level, optname, optval, optlen);
 #ifdef CONFIG_NETFILTER