Module Name:    src
Committed By:   stacktic
Date:           Sat Jun  1 10:10:57 UTC 2013

Modified Files:
        src/sys/rump/net/lib/libsockin: component.c sockin.c

Log Message:
Add IPv6 support


To generate a diff of this commit:
cvs rdiff -u -r1.2 -r1.3 src/sys/rump/net/lib/libsockin/component.c
cvs rdiff -u -r1.30 -r1.31 src/sys/rump/net/lib/libsockin/sockin.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/rump/net/lib/libsockin/component.c
diff -u src/sys/rump/net/lib/libsockin/component.c:1.2 src/sys/rump/net/lib/libsockin/component.c:1.3
--- src/sys/rump/net/lib/libsockin/component.c:1.2	Mon Mar  1 13:12:21 2010
+++ src/sys/rump/net/lib/libsockin/component.c	Sat Jun  1 10:10:57 2013
@@ -1,4 +1,4 @@
-/*	$NetBSD: component.c,v 1.2 2010/03/01 13:12:21 pooka Exp $	*/
+/*	$NetBSD: component.c,v 1.3 2013/06/01 10:10:57 stacktic Exp $	*/
 
 /*
  * Copyright (c) 2009 Antti Kantee.  All Rights Reserved.
@@ -28,7 +28,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: component.c,v 1.2 2010/03/01 13:12:21 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: component.c,v 1.3 2013/06/01 10:10:57 stacktic Exp $");
 
 #include <sys/param.h>
 #include <sys/domain.h>
@@ -40,6 +40,8 @@ __KERNEL_RCSID(0, "$NetBSD: component.c,
 RUMP_COMPONENT(RUMP_COMPONENT_NET)
 {
 	extern struct domain sockindomain;
+	extern struct domain sockin6domain;
 
 	DOMAINADD(sockindomain);
+	DOMAINADD(sockin6domain);
 }

Index: src/sys/rump/net/lib/libsockin/sockin.c
diff -u src/sys/rump/net/lib/libsockin/sockin.c:1.30 src/sys/rump/net/lib/libsockin/sockin.c:1.31
--- src/sys/rump/net/lib/libsockin/sockin.c:1.30	Tue Apr 30 00:12:35 2013
+++ src/sys/rump/net/lib/libsockin/sockin.c	Sat Jun  1 10:10:57 2013
@@ -1,4 +1,4 @@
-/*	$NetBSD: sockin.c,v 1.30 2013/04/30 00:12:35 pooka Exp $	*/
+/*	$NetBSD: sockin.c,v 1.31 2013/06/01 10:10:57 stacktic Exp $	*/
 
 /*
  * Copyright (c) 2008, 2009 Antti Kantee.  All Rights Reserved.
@@ -26,7 +26,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: sockin.c,v 1.30 2013/04/30 00:12:35 pooka Exp $");
+__KERNEL_RCSID(0, "$NetBSD: sockin.c,v 1.31 2013/06/01 10:10:57 stacktic Exp $");
 
 #include <sys/param.h>
 #include <sys/condvar.h>
@@ -62,6 +62,8 @@ __KERNEL_RCSID(0, "$NetBSD: sockin.c,v 1
  */
 
 DOMAIN_DEFINE(sockindomain);
+DOMAIN_DEFINE(sockin6domain);
+
 
 static void	sockin_init(void);
 static int	sockin_usrreq(struct socket *, int, struct mbuf *,
@@ -85,6 +87,23 @@ const struct protosw sockinsw[] = {
 	.pr_usrreq = sockin_usrreq,
 	.pr_ctloutput = sockin_ctloutput,
 }};
+const struct protosw sockin6sw[] = {
+{
+	.pr_type = SOCK_DGRAM,
+	.pr_domain = &sockin6domain,
+	.pr_protocol = IPPROTO_UDP,
+	.pr_flags = PR_ATOMIC|PR_ADDR,
+	.pr_usrreq = sockin_usrreq,
+	.pr_ctloutput = sockin_ctloutput,
+},
+{
+	.pr_type = SOCK_STREAM,
+	.pr_domain = &sockin6domain,
+	.pr_protocol = IPPROTO_TCP,
+	.pr_flags = PR_CONNREQUIRED|PR_WANTRCVD|PR_LISTEN|PR_ABRTACPTDIS,
+	.pr_usrreq = sockin_usrreq,
+	.pr_ctloutput = sockin_ctloutput,
+}};
 
 struct domain sockindomain = {
 	.dom_family = PF_INET,
@@ -105,6 +124,25 @@ struct domain sockindomain = {
 	.dom_rtcache = { NULL },
 	.dom_sockaddr_cmp = NULL
 };
+struct domain sockin6domain = {
+	.dom_family = PF_INET6,
+	.dom_name = "socket_inet6",
+	.dom_init = sockin_init,
+	.dom_externalize = NULL,
+	.dom_dispose = NULL,
+	.dom_protosw = sockin6sw,
+	.dom_protoswNPROTOSW = &sockin6sw[__arraycount(sockin6sw)],
+	.dom_rtattach = rt_inithead,
+	.dom_rtoffset = 32,
+	.dom_maxrtkey = sizeof(struct sockaddr_in6),
+	.dom_ifattach = NULL,
+	.dom_ifdetach = NULL,
+	.dom_ifqueues = { NULL },
+	.dom_link = { NULL },
+	.dom_mowner = MOWNER_INIT("",""),
+	.dom_rtcache = { NULL },
+	.dom_sockaddr_cmp = NULL
+};
 
 #define SO2S(so) ((intptr_t)(so->so_internal))
 #define SOCKIN_SBSIZE 65536
@@ -169,7 +207,7 @@ removesock(struct socket *so)
 static void
 sockin_process(struct socket *so)
 {
-	struct sockaddr_in from;
+	struct sockaddr_in6 from;
 	struct iovec io;
 	struct msghdr rmsg;
 	struct mbuf *m;
@@ -231,7 +269,7 @@ static void
 sockin_accept(struct socket *so)
 {
 	struct socket *nso;
-	struct sockaddr_in sin;
+	struct sockaddr_in6 sin;
 	int news, error, slen;
 
 	slen = sizeof(sin);
@@ -331,7 +369,7 @@ sockinworker(void *arg)
 		}
 		KASSERT(rv <= 0);
 	}
-	
+
 }
 
 static void
@@ -370,8 +408,9 @@ sockin_usrreq(struct socket *so, int req
 				break;
 		}
 
-		error = rumpcomp_sockin_socket(PF_INET, so->so_proto->pr_type,
-		    0, &news);
+		error = rumpcomp_sockin_socket(
+		    so->so_proto->pr_domain->dom_family,
+		    so->so_proto->pr_type, 0, &news);
 		if (error)
 			break;
 
@@ -400,12 +439,12 @@ sockin_usrreq(struct socket *so, int req
 	case PRU_BIND:
 		error = rumpcomp_sockin_bind(SO2S(so),
 		    mtod(nam, const struct sockaddr *),
-		    sizeof(struct sockaddr_in));
+		    nam->m_len);
 		break;
 
 	case PRU_CONNECT:
 		error = rumpcomp_sockin_connect(SO2S(so),
-		    mtod(nam, struct sockaddr *), sizeof(struct sockaddr_in));
+		    mtod(nam, struct sockaddr *), nam->m_len);
 		if (error == 0)
 			soisconnected(so);
 		break;

Reply via email to