Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys Dedup: merge



details:   https://anonhg.NetBSD.org/src/rev/7fd4764a091e
branches:  trunk
changeset: 359868:7fd4764a091e
user:      maxv <maxv%NetBSD.org@localhost>
date:      Tue Feb 27 14:44:10 2018 +0000

description:
Dedup: merge

        ipsec4_get_policy and ipsec6_get_policy
        ipsec4_delete_pcbpolicy and ipsec6_delete_pcbpolicy

The already-existing ipsec_get_policy() function is inlined in the new
one.

diffstat:

 sys/netinet/in_pcb.c      |    6 +-
 sys/netinet/ip_output.c   |    6 +-
 sys/netinet/sctp_pcb.c    |    6 +-
 sys/netinet6/in6_pcb.c    |    6 +-
 sys/netinet6/ip6_output.c |    6 +-
 sys/netipsec/ipsec.c      |  105 ++++++++-------------------------------------
 sys/netipsec/ipsec.h      |    6 +-
 sys/netipsec/ipsec6.h     |    4 +-
 8 files changed, 39 insertions(+), 106 deletions(-)

diffs (truncated from 332 to 300 lines):

diff -r c286df967b7a -r 7fd4764a091e sys/netinet/in_pcb.c
--- a/sys/netinet/in_pcb.c      Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netinet/in_pcb.c      Tue Feb 27 14:44:10 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: in_pcb.c,v 1.181 2018/01/01 00:51:36 christos Exp $    */
+/*     $NetBSD: in_pcb.c,v 1.182 2018/02/27 14:44:10 maxv Exp $        */
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -93,7 +93,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: in_pcb.c,v 1.181 2018/01/01 00:51:36 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: in_pcb.c,v 1.182 2018/02/27 14:44:10 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -628,7 +628,7 @@
 
 #if defined(IPSEC)
        if (ipsec_enabled)
-               ipsec4_delete_pcbpolicy(inp);
+               ipsec_delete_pcbpolicy(inp);
 #endif
        so->so_pcb = NULL;
 
diff -r c286df967b7a -r 7fd4764a091e sys/netinet/ip_output.c
--- a/sys/netinet/ip_output.c   Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netinet/ip_output.c   Tue Feb 27 14:44:10 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ip_output.c,v 1.295 2018/02/12 18:19:12 christos Exp $ */
+/*     $NetBSD: ip_output.c,v 1.296 2018/02/27 14:44:10 maxv Exp $     */
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -91,7 +91,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ip_output.c,v 1.295 2018/02/12 18:19:12 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ip_output.c,v 1.296 2018/02/27 14:44:10 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1384,7 +1384,7 @@
                        struct mbuf *m = NULL;
 
                        /* XXX this will return EINVAL as sopt is empty */
-                       error = ipsec4_get_policy(inp, sopt->sopt_data,
+                       error = ipsec_get_policy(inp, sopt->sopt_data,
                            sopt->sopt_size, &m);
                        if (error == 0)
                                error = sockopt_setmbuf(sopt, m);
diff -r c286df967b7a -r 7fd4764a091e sys/netinet/sctp_pcb.c
--- a/sys/netinet/sctp_pcb.c    Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netinet/sctp_pcb.c    Tue Feb 27 14:44:10 2018 +0000
@@ -1,5 +1,5 @@
 /* $KAME: sctp_pcb.c,v 1.39 2005/06/16 18:29:25 jinmei Exp $ */
-/* $NetBSD: sctp_pcb.c,v 1.15 2017/10/17 19:23:42 rjs Exp $ */
+/* $NetBSD: sctp_pcb.c,v 1.16 2018/02/27 14:44:10 maxv Exp $ */
 
 /*
  * Copyright (c) 2001, 2002, 2003, 2004 Cisco Systems, Inc.
@@ -33,7 +33,7 @@
  * SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sctp_pcb.c,v 1.15 2017/10/17 19:23:42 rjs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sctp_pcb.c,v 1.16 2018/02/27 14:44:10 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -2153,7 +2153,7 @@
        /* First take care of socket level things */
 #ifdef IPSEC
                if (ipsec_enabled)
-                       ipsec4_delete_pcbpolicy(ip_pcb);
+                       ipsec_delete_pcbpolicy(ip_pcb);
 #endif /*IPSEC*/
                so->so_pcb = 0;
        }
diff -r c286df967b7a -r 7fd4764a091e sys/netinet6/in6_pcb.c
--- a/sys/netinet6/in6_pcb.c    Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netinet6/in6_pcb.c    Tue Feb 27 14:44:10 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: in6_pcb.c,v 1.164 2018/02/08 09:05:20 dholland Exp $   */
+/*     $NetBSD: in6_pcb.c,v 1.165 2018/02/27 14:44:10 maxv Exp $       */
 /*     $KAME: in6_pcb.c,v 1.84 2001/02/08 18:02:08 itojun Exp $        */
 
 /*
@@ -62,7 +62,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: in6_pcb.c,v 1.164 2018/02/08 09:05:20 dholland Exp $");
+__KERNEL_RCSID(0, "$NetBSD: in6_pcb.c,v 1.165 2018/02/27 14:44:10 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -628,7 +628,7 @@
 
 #if defined(IPSEC)
        if (ipsec_enabled)
-               ipsec6_delete_pcbpolicy(in6p);
+               ipsec_delete_pcbpolicy(in6p);
 #endif
        so->so_pcb = NULL;
 
diff -r c286df967b7a -r 7fd4764a091e sys/netinet6/ip6_output.c
--- a/sys/netinet6/ip6_output.c Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netinet6/ip6_output.c Tue Feb 27 14:44:10 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ip6_output.c,v 1.201 2018/02/12 12:52:12 maxv Exp $    */
+/*     $NetBSD: ip6_output.c,v 1.202 2018/02/27 14:44:10 maxv Exp $    */
 /*     $KAME: ip6_output.c,v 1.172 2001/03/25 09:55:56 itojun Exp $    */
 
 /*
@@ -62,7 +62,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ip6_output.c,v 1.201 2018/02/12 12:52:12 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ip6_output.c,v 1.202 2018/02/27 14:44:10 maxv Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1980,7 +1980,7 @@
                                 * XXX: this will return EINVAL as sopt is
                                 * empty
                                 */
-                               error = ipsec6_get_policy(in6p, sopt->sopt_data,
+                               error = ipsec_get_policy(in6p, sopt->sopt_data,
                                    sopt->sopt_size, &m);
                                if (!error)
                                        error = sockopt_setmbuf(sopt, m);
diff -r c286df967b7a -r 7fd4764a091e sys/netipsec/ipsec.c
--- a/sys/netipsec/ipsec.c      Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netipsec/ipsec.c      Tue Feb 27 14:44:10 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ipsec.c,v 1.143 2018/02/27 13:36:21 maxv Exp $ */
+/* $NetBSD: ipsec.c,v 1.144 2018/02/27 14:44:10 maxv Exp $ */
 /* $FreeBSD: src/sys/netipsec/ipsec.c,v 1.2.2.2 2003/07/01 01:38:13 sam Exp $ */
 /* $KAME: ipsec.c,v 1.103 2001/05/24 07:14:18 sakane Exp $ */
 
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ipsec.c,v 1.143 2018/02/27 13:36:21 maxv Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ipsec.c,v 1.144 2018/02/27 14:44:10 maxv Exp $");
 
 /*
  * IPsec controller part.
@@ -187,7 +187,6 @@
 #endif
 static int ipsec_set_policy(struct secpolicy **, int, const void *, size_t,
     kauth_cred_t);
-static int ipsec_get_policy(struct secpolicy *, struct mbuf **);
 static void ipsec_destroy_policy(struct secpolicy *);
 static int ipsec_sp_reject(const struct secpolicy *, const struct mbuf *);
 static void vshiftl(unsigned char *, int, int);
@@ -1331,28 +1330,6 @@
        return 0;
 }
 
-static int
-ipsec_get_policy(struct secpolicy *policy, struct mbuf **mp)
-{
-
-       /* sanity check. */
-       if (policy == NULL || mp == NULL)
-               return EINVAL;
-
-       *mp = key_sp2msg(policy, M_NOWAIT);
-       if (!*mp) {
-               IPSECLOG(LOG_DEBUG, "No more memory.\n");
-               return ENOBUFS;
-       }
-
-       (*mp)->m_type = MT_DATA;
-       if (KEYDEBUG_ON(KEYDEBUG_IPSEC_DUMP)) {
-               kdebug_mbuf(__func__, *mp);
-       }
-
-       return 0;
-}
-
 int
 ipsec4_set_policy(struct inpcb *inp, int optname, const void *request,
     size_t len, kauth_cred_t cred)
@@ -1390,7 +1367,7 @@
 }
 
 int
-ipsec4_get_policy(struct inpcb *inp, const void *request, size_t len,
+ipsec_get_policy(void *inp, const void *request, size_t len,
     struct mbuf **mp)
 {
        struct inpcb_hdr *inph = (struct inpcb_hdr *)inp;
@@ -1419,11 +1396,26 @@
                return EINVAL;
        }
 
-       return ipsec_get_policy(policy, mp);
+       /* sanity check. */
+       if (policy == NULL || mp == NULL)
+               return EINVAL;
+
+       *mp = key_sp2msg(policy, M_NOWAIT);
+       if (!*mp) {
+               IPSECLOG(LOG_DEBUG, "No more memory.\n");
+               return ENOBUFS;
+       }
+
+       (*mp)->m_type = MT_DATA;
+       if (KEYDEBUG_ON(KEYDEBUG_IPSEC_DUMP)) {
+               kdebug_mbuf(__func__, *mp);
+       }
+
+       return 0;
 }
 
 int
-ipsec4_delete_pcbpolicy(struct inpcb *inp)
+ipsec_delete_pcbpolicy(void *inp)
 {
        struct inpcb_hdr *inph = (struct inpcb_hdr *)inp;
 
@@ -1480,63 +1472,6 @@
 
        return ipsec_set_policy(policy, optname, request, len, cred);
 }
-
-int
-ipsec6_get_policy(struct in6pcb *in6p, const void *request, size_t len,
-    struct mbuf **mp)
-{
-       struct inpcb_hdr *inph = (struct inpcb_hdr *)in6p;
-       const struct sadb_x_policy *xpl;
-       struct secpolicy *policy;
-
-       /* sanity check. */
-       if (inph == NULL || request == NULL || mp == NULL)
-               return EINVAL;
-       KASSERT(inph->inph_sp != NULL);
-       if (len < sizeof(*xpl))
-               return EINVAL;
-       xpl = (const struct sadb_x_policy *)request;
-
-       /* select direction */
-       switch (xpl->sadb_x_policy_dir) {
-       case IPSEC_DIR_INBOUND:
-               policy = inph->inph_sp->sp_in;
-               break;
-       case IPSEC_DIR_OUTBOUND:
-               policy = inph->inph_sp->sp_out;
-               break;
-       default:
-               IPSECLOG(LOG_ERR, "invalid direction=%u\n",
-                   xpl->sadb_x_policy_dir);
-               return EINVAL;
-       }
-
-       return ipsec_get_policy(policy, mp);
-}
-
-int
-ipsec6_delete_pcbpolicy(struct in6pcb *in6p)
-{
-       struct inpcb_hdr *inph = (struct inpcb_hdr *)in6p;
-
-       KASSERT(inph != NULL);
-
-       if (inph->inph_sp == NULL)
-               return 0;
-
-       if (inph->inph_sp->sp_in != NULL)
-               ipsec_destroy_policy(inph->inph_sp->sp_in);
-
-       if (inph->inph_sp->sp_out != NULL)
-               ipsec_destroy_policy(inph->inph_sp->sp_out);
-
-       ipsec_invalpcbcache(inph->inph_sp, IPSEC_DIR_ANY);
-
-       ipsec_delpcbpolicy(inph->inph_sp);
-       inph->inph_sp = NULL;
-
-       return 0;
-}
 #endif
 
 /*
diff -r c286df967b7a -r 7fd4764a091e sys/netipsec/ipsec.h
--- a/sys/netipsec/ipsec.h      Tue Feb 27 14:28:01 2018 +0000
+++ b/sys/netipsec/ipsec.h      Tue Feb 27 14:44:10 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ipsec.h,v 1.69 2018/02/26 09:04:29 maxv Exp $  */
+/*     $NetBSD: ipsec.h,v 1.70 2018/02/27 14:44:10 maxv Exp $  */
 /*     $FreeBSD: /usr/local/www/cvsroot/FreeBSD/src/sys/netipsec/ipsec.h,v 1.2.4.2 2004/02/14 22:23:23 bms Exp $       */



Home | Main Index | Thread Index | Old Index