Hello -

This diff makes sosetopt responsible for m_free which is much simpler.
Requested by bluhm@ 

Index: kern/uipc_socket.c
===================================================================
RCS file: /cvs/src/sys/kern/uipc_socket.c,v
retrieving revision 1.176
diff -u -p -r1.176 uipc_socket.c
--- kern/uipc_socket.c  1 Feb 2017 20:59:47 -0000       1.176
+++ kern/uipc_socket.c  2 Feb 2017 00:13:23 -0000
@@ -1562,6 +1562,7 @@ sosetopt(struct socket *so, int level, i
                        error = (*so->so_proto->pr_ctloutput)(PRCO_SETOPT, so,
                            level, optname, m0);
                        NET_UNLOCK(s);
+                       m_free(m0);
                        return (error);
                }
                error = ENOPROTOOPT;
@@ -1709,6 +1710,7 @@ sosetopt(struct socket *so, int level, i
                                error = (*so->so_proto->pr_ctloutput)
                                    (PRCO_SETOPT, so, level, optname, m0);
                                NET_UNLOCK(s);
+                               m_free(m0);
                                return (error);
                        }
                        error = ENOPROTOOPT;
@@ -1741,7 +1743,8 @@ sosetopt(struct socket *so, int level, i
                        (*so->so_proto->pr_ctloutput)(PRCO_SETOPT, so,
                            level, optname, m0);
                        NET_UNLOCK(s);
-                       m = NULL;       /* freed by protocol */
+                       m_free(m0);
+                       m = NULL;
                }
        }
 bad:
Index: net/rtsock.c
===================================================================
RCS file: /cvs/src/sys/net/rtsock.c,v
retrieving revision 1.222
diff -u -p -r1.222 rtsock.c
--- net/rtsock.c        1 Feb 2017 20:59:47 -0000       1.222
+++ net/rtsock.c        2 Feb 2017 00:13:23 -0000
@@ -240,12 +240,8 @@ route_ctloutput(int op, struct socket *s
        int error = 0;
        unsigned int tid;
 
-       if (level != AF_ROUTE) {
-               error = EINVAL;
-               if (op == PRCO_SETOPT && m)
-                       m_free(m);
-               return (error);
-       }
+       if (level != AF_ROUTE)
+               return EINVAL;
 
        switch (op) {
        case PRCO_SETOPT:
@@ -271,7 +267,6 @@ route_ctloutput(int op, struct socket *s
                        error = ENOPROTOOPT;
                        break;
                }
-               m_free(m);
                break;
        case PRCO_GETOPT:
                switch (optname) {
Index: netinet/ip_mroute.c
===================================================================
RCS file: /cvs/src/sys/netinet/ip_mroute.c,v
retrieving revision 1.108
diff -u -p -r1.108 ip_mroute.c
--- netinet/ip_mroute.c 1 Feb 2017 20:59:47 -0000       1.108
+++ netinet/ip_mroute.c 2 Feb 2017 00:13:23 -0000
@@ -209,7 +209,6 @@ ip_mrouter_set(struct socket *so, int op
                        break;
                }
 
-       m_free(m);
        return (error);
 }
 
Index: netinet/ip_output.c
===================================================================
RCS file: /cvs/src/sys/netinet/ip_output.c,v
retrieving revision 1.335
diff -u -p -r1.335 ip_output.c
--- netinet/ip_output.c 1 Feb 2017 20:59:47 -0000       1.335
+++ netinet/ip_output.c 2 Feb 2017 00:13:23 -0000
@@ -853,11 +853,10 @@ ip_ctloutput(int op, struct socket *so, 
        int error = 0;
        u_int rtid = 0;
 
-       if (level != IPPROTO_IP) {
-               error = EINVAL;
-               if (op == PRCO_SETOPT)
-                       (void) m_free(m);
-       } else switch (op) {
+       if (level != IPPROTO_IP)
+               return EINVAL;
+       
+       switch (op) {
        case PRCO_SETOPT:
                switch (optname) {
                case IP_OPTIONS:
@@ -1073,7 +1072,6 @@ ip_ctloutput(int op, struct socket *so, 
                        error = ENOPROTOOPT;
                        break;
                }
-               m_free(m);
                break;
 
        case PRCO_GETOPT:
@@ -1235,12 +1233,11 @@ ip_pcbopts(struct mbuf **pcbopt, struct 
 
        /* turn off any old options */
        m_free(*pcbopt);
-       *pcbopt = 0;
+       *pcbopt = NULL;
        if (m == NULL || m->m_len == 0) {
                /*
                 * Only turning off any previous options.
                 */
-               m_free(m);
                return (0);
        }
 
@@ -1316,7 +1313,6 @@ ip_pcbopts(struct mbuf **pcbopt, struct 
        return (0);
 
 bad:
-       (void)m_free(m);
        return (EINVAL);
 }
 
Index: netinet/raw_ip.c
===================================================================
RCS file: /cvs/src/sys/netinet/raw_ip.c,v
retrieving revision 1.95
diff -u -p -r1.95 raw_ip.c
--- netinet/raw_ip.c    1 Feb 2017 20:59:47 -0000       1.95
+++ netinet/raw_ip.c    2 Feb 2017 00:13:23 -0000
@@ -305,11 +305,8 @@ rip_ctloutput(int op, struct socket *so,
        int error = 0;
        int dir;
 
-       if (level != IPPROTO_IP) {
-               if (op == PRCO_SETOPT)
-                       (void) m_free(m);
-               return (EINVAL);
-       }
+       if (level != IPPROTO_IP)
+               return EINVAL;
 
        switch (optname) {
 
@@ -322,7 +319,6 @@ rip_ctloutput(int op, struct socket *so,
                                inp->inp_flags |= INP_HDRINCL;
                        else
                                inp->inp_flags &= ~INP_HDRINCL;
-                       m_free(m);
                } else {
                        m->m_len = sizeof(int);
                        *mtod(m, int *) = inp->inp_flags & INP_HDRINCL;
@@ -344,7 +340,6 @@ rip_ctloutput(int op, struct socket *so,
                                inp->inp_divertfl = dir;
                        else 
                                error = EINVAL;
-
                        break;
 
                case PRCO_GETOPT:
@@ -357,8 +352,6 @@ rip_ctloutput(int op, struct socket *so,
                        break;
                }
 
-               if (op == PRCO_SETOPT)
-                       (void)m_free(m);
                return (error);
 
        case MRT_INIT:
@@ -385,8 +378,6 @@ rip_ctloutput(int op, struct socket *so,
                }
                return (error);
 #else
-               if (op == PRCO_SETOPT)
-                       m_free(m);
                return (EOPNOTSUPP);
 #endif
        }
Index: netinet/tcp_usrreq.c
===================================================================
RCS file: /cvs/src/sys/netinet/tcp_usrreq.c,v
retrieving revision 1.143
diff -u -p -r1.143 tcp_usrreq.c
--- netinet/tcp_usrreq.c        1 Feb 2017 20:59:47 -0000       1.143
+++ netinet/tcp_usrreq.c        2 Feb 2017 00:13:23 -0000
@@ -457,11 +457,9 @@ tcp_ctloutput(int op, struct socket *so,
        int i;
 
        inp = sotoinpcb(so);
-       if (inp == NULL) {
-               if (op == PRCO_SETOPT)
-                       (void) m_free(m);
-               return (ECONNRESET);
-       }
+       if (inp == NULL)
+               return ECONNRESET;
+
        if (level != IPPROTO_TCP) {
                switch (so->so_proto->pr_domain->dom_family) {
 #ifdef INET6
@@ -481,10 +479,8 @@ tcp_ctloutput(int op, struct socket *so,
        tp = intotcpcb(inp);
 
        switch (op) {
-
        case PRCO_SETOPT:
                switch (optname) {
-
                case TCP_NODELAY:
                        if (m == NULL || m->m_len < sizeof (int))
                                error = EINVAL;
@@ -567,7 +563,6 @@ tcp_ctloutput(int op, struct socket *so,
                        error = ENOPROTOOPT;
                        break;
                }
-               m_free(m);
                break;
 
        case PRCO_GETOPT:
Index: netinet6/icmp6.c
===================================================================
RCS file: /cvs/src/sys/netinet6/icmp6.c,v
retrieving revision 1.198
diff -u -p -r1.198 icmp6.c
--- netinet6/icmp6.c    1 Feb 2017 20:59:47 -0000       1.198
+++ netinet6/icmp6.c    2 Feb 2017 00:13:23 -0000
@@ -1807,11 +1807,8 @@ icmp6_ctloutput(int op, struct socket *s
        int error = 0;
        struct inpcb *in6p = sotoinpcb(so);
 
-       if (level != IPPROTO_ICMPV6) {
-               if (op == PRCO_SETOPT)
-                       (void)m_free(m);
+       if (level != IPPROTO_ICMPV6)
                return EINVAL;
-       }
 
        switch (op) {
        case PRCO_SETOPT:
@@ -1839,7 +1836,6 @@ icmp6_ctloutput(int op, struct socket *s
                        error = ENOPROTOOPT;
                        break;
                }
-               m_freem(m);
                break;
 
        case PRCO_GETOPT:
Index: netinet6/ip6_output.c
===================================================================
RCS file: /cvs/src/sys/netinet6/ip6_output.c,v
retrieving revision 1.223
diff -u -p -r1.223 ip6_output.c
--- netinet6/ip6_output.c       1 Feb 2017 20:59:47 -0000       1.223
+++ netinet6/ip6_output.c       2 Feb 2017 00:13:23 -0000
@@ -1390,7 +1390,6 @@ do { \
                                error = ENOPROTOOPT;
                                break;
                        }
-                       m_free(m);
                        break;
 
                case PRCO_GETOPT:
@@ -1591,11 +1590,8 @@ do { \
                        }
                        break;
                }
-       } else {
+       } else
                error = EINVAL;
-               if (op == PRCO_SETOPT)
-                       (void)m_free(m);
-       }
        return (error);
 }
 
@@ -1607,11 +1603,8 @@ ip6_raw_ctloutput(int op, struct socket 
        const int icmp6off = offsetof(struct icmp6_hdr, icmp6_cksum);
        struct inpcb *inp = sotoinpcb(so);
 
-       if (level != IPPROTO_IPV6) {
-               if (op == PRCO_SETOPT)
-                       (void)m_free(m);
+       if (level != IPPROTO_IPV6)
                return (EINVAL);
-       }
 
        switch (optname) {
        case IPV6_CHECKSUM:
@@ -1660,9 +1653,6 @@ ip6_raw_ctloutput(int op, struct socket 
                error = ENOPROTOOPT;
                break;
        }
-
-       if (op == PRCO_SETOPT)
-               (void)m_free(m);
 
        return (error);
 }
Index: netinet6/raw_ip6.c
===================================================================
RCS file: /cvs/src/sys/netinet6/raw_ip6.c,v
retrieving revision 1.104
diff -u -p -r1.104 raw_ip6.c
--- netinet6/raw_ip6.c  1 Feb 2017 20:59:47 -0000       1.104
+++ netinet6/raw_ip6.c  2 Feb 2017 00:13:23 -0000
@@ -511,8 +511,6 @@ rip6_ctloutput(int op, struct socket *so
                                break;
                        }
 
-                       if (op == PRCO_SETOPT)
-                               (void)m_free(m);
                        return (error);
 
 #ifdef MROUTING
@@ -522,10 +520,9 @@ rip6_ctloutput(int op, struct socket *so
                case MRT6_DEL_MIF:
                case MRT6_ADD_MFC:
                case MRT6_DEL_MFC:
-                       if (op == PRCO_SETOPT) {
+                       if (op == PRCO_SETOPT)
                                error = ip6_mrouter_set(optname, so, m);
-                               m_free(m);
-                       } else if (op == PRCO_GETOPT)
+                       else if (op == PRCO_GETOPT)
                                error = ip6_mrouter_get(optname, so, m);
                        else
                                error = EINVAL;
@@ -545,8 +542,6 @@ rip6_ctloutput(int op, struct socket *so
                return (icmp6_ctloutput(op, so, level, optname, m));
 
        default:
-               if (op == PRCO_SETOPT)
-                       m_free(m);
                return EINVAL;
        }
 }

Reply via email to