Source-Changes-HG archive

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

[src/trunk]: src/sys Do sctp_connectx() handling using ioctl() for IPv6 as well.



details:   https://anonhg.NetBSD.org/src/rev/63d00383371c
branches:  trunk
changeset: 971551:63d00383371c
user:      rjs <rjs%NetBSD.org@localhost>
date:      Mon Apr 27 19:21:43 2020 +0000

description:
Do sctp_connectx() handling using ioctl() for IPv6 as well.

diffstat:

 sys/netinet/sctp_usrreq.c   |   6 +++---
 sys/netinet/sctp_var.h      |   4 +++-
 sys/netinet6/sctp6_usrreq.c |  34 ++++++++++++++++++++++------------
 3 files changed, 28 insertions(+), 16 deletions(-)

diffs (107 lines):

diff -r 1f9a9f19cbb3 -r 63d00383371c sys/netinet/sctp_usrreq.c
--- a/sys/netinet/sctp_usrreq.c Mon Apr 27 18:08:25 2020 +0000
+++ b/sys/netinet/sctp_usrreq.c Mon Apr 27 19:21:43 2020 +0000
@@ -1,5 +1,5 @@
 /*     $KAME: sctp_usrreq.c,v 1.50 2005/06/16 20:45:29 jinmei Exp $    */
-/*     $NetBSD: sctp_usrreq.c,v 1.19 2019/06/25 15:33:56 rjs Exp $     */
+/*     $NetBSD: sctp_usrreq.c,v 1.20 2020/04/27 19:21:43 rjs 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_usrreq.c,v 1.19 2019/06/25 15:33:56 rjs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sctp_usrreq.c,v 1.20 2020/04/27 19:21:43 rjs Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1143,7 +1143,7 @@
        return (cnt);
 }
 
-static int
+int
 sctp_do_connect_x(struct socket *so, struct sctp_connectx_addrs *sca,
     struct lwp *l, int delay)
 {
diff -r 1f9a9f19cbb3 -r 63d00383371c sys/netinet/sctp_var.h
--- a/sys/netinet/sctp_var.h    Mon Apr 27 18:08:25 2020 +0000
+++ b/sys/netinet/sctp_var.h    Mon Apr 27 19:21:43 2020 +0000
@@ -1,5 +1,5 @@
 /*     $KAME: sctp_var.h,v 1.24 2005/03/06 16:04:19 itojun Exp $       */
-/*     $NetBSD: sctp_var.h,v 1.3 2018/09/14 05:09:51 maxv Exp $ */
+/*     $NetBSD: sctp_var.h,v 1.4 2020/04/27 19:21:43 rjs Exp $ */
 
 /*
  * Copyright (c) 2001, 2002, 2003, 2004 Cisco Systems, Inc.
@@ -161,6 +161,8 @@
 
 int sctp_bindx(struct socket *, int, struct sockaddr_storage *,
        int, int, struct lwp *);
+int sctp_do_connect_x(struct socket *, struct sctp_connectx_addrs *,
+       struct lwp *, int);
 
 /* can't use sctp_assoc_t here */
 int sctp_peeloff(struct socket *, struct socket *, int, vaddr_t, int *);
diff -r 1f9a9f19cbb3 -r 63d00383371c sys/netinet6/sctp6_usrreq.c
--- a/sys/netinet6/sctp6_usrreq.c       Mon Apr 27 18:08:25 2020 +0000
+++ b/sys/netinet6/sctp6_usrreq.c       Mon Apr 27 19:21:43 2020 +0000
@@ -1,5 +1,5 @@
 /* $KAME: sctp6_usrreq.c,v 1.38 2005/08/24 08:08:56 suz Exp $ */
-/* $NetBSD: sctp6_usrreq.c,v 1.20 2019/06/25 15:33:56 rjs Exp $ */
+/* $NetBSD: sctp6_usrreq.c,v 1.21 2020/04/27 19:21:43 rjs Exp $ */
 
 /*
  * Copyright (c) 2001, 2002, 2003, 2004 Cisco Systems, Inc.
@@ -33,7 +33,7 @@
  * SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sctp6_usrreq.c,v 1.20 2019/06/25 15:33:56 rjs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sctp6_usrreq.c,v 1.21 2020/04/27 19:21:43 rjs Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -1244,20 +1244,30 @@
        int error = 0;
        int family;
 
-       family = so->so_proto->pr_domain->dom_family;
-       switch (family) {
+       if (cmd == SIOCCONNECTX) {
+               solock(so);
+               error = sctp_do_connect_x(so, nam, curlwp, 0);
+               sounlock(so);
+       } else if (cmd == SIOCCONNECTXDEL) {
+               solock(so);
+               error = sctp_do_connect_x(so, nam, curlwp, 1);
+               sounlock(so);
+       } else {
+               family = so->so_proto->pr_domain->dom_family;
+               switch (family) {
 #ifdef INET
-       case PF_INET:
-               error = in_control(so, cmd, nam, ifp);
-               break;
+               case PF_INET:
+                       error = in_control(so, cmd, nam, ifp);
+                       break;
 #endif
 #ifdef INET6
-       case PF_INET6:
-               error = in6_control(so, cmd, nam, ifp);
-               break;
+               case PF_INET6:
+                       error = in6_control(so, cmd, nam, ifp);
+                       break;
 #endif
-       default:
-               error = EAFNOSUPPORT;
+               default:
+                       error = EAFNOSUPPORT;
+               }
        }
        return (error);
 }



Home | Main Index | Thread Index | Old Index