public inbox for v9fs@lists.linux.dev
 help / color / mirror / Atom feed
* [PATCH] net/9p/fd: support ipv6 for trans=tcp
@ 2025-01-16 16:07 Joshua Murphy
  2025-01-16 19:46 ` asmadeus
  0 siblings, 1 reply; 3+ messages in thread
From: Joshua Murphy @ 2025-01-16 16:07 UTC (permalink / raw)
  To: ericvh, lucho, asmadeus, linux_oss; +Cc: v9fs, Joshua Murphy

Allows specifying an IPv6 address when mounting a remote 9p file system.

Signed-off-by: Joshua Murphy <joshuamurphy@posteo.net>
---
 net/9p/trans_fd.c | 50 ++++++++++++++++++++++++++++++++---------------
 1 file changed, 34 insertions(+), 16 deletions(-)

diff --git a/net/9p/trans_fd.c b/net/9p/trans_fd.c
index 196060dc6..effd0261d 100644
--- a/net/9p/trans_fd.c
+++ b/net/9p/trans_fd.c
@@ -11,6 +11,7 @@
 #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
 
 #include <linux/in.h>
+#include <linux/in6.h>
 #include <linux/module.h>
 #include <linux/net.h>
 #include <linux/ipv6.h>
@@ -971,17 +972,24 @@ static inline int valid_ipaddr4(const char *buf)
 	return 0;
 }
 
-static int p9_bind_privport(struct socket *sock)
+static int p9_bind_privport(struct socket *sock, int family)
 {
-	struct sockaddr_in cl;
+	struct sockaddr_storage stor;
+	struct sockaddr *cl = (struct sockaddr *) &stor;
 	int port, err = -EINVAL;
 
 	memset(&cl, 0, sizeof(cl));
-	cl.sin_family = AF_INET;
-	cl.sin_addr.s_addr = htonl(INADDR_ANY);
+	cl->sa_family = family;
+	if (cl->sa_family == AF_INET)
+		((struct sockaddr_in *) cl)->sin_addr.s_addr = htonl(INADDR_ANY);
+	else
+		((struct sockaddr_in6 *) cl)->sin6_addr = in6addr_any;
 	for (port = p9_ipport_resv_max; port >= p9_ipport_resv_min; port--) {
-		cl.sin_port = htons((ushort)port);
-		err = kernel_bind(sock, (struct sockaddr *)&cl, sizeof(cl));
+		if (cl->sa_family == AF_INET)
+			((struct sockaddr_in *)cl)->sin_port = htons((ushort)port);
+		else
+			((struct sockaddr_in6 *)cl)->sin6_port = htons((ushort)port);
+		err = kernel_bind(sock, cl, sizeof(cl));
 		if (err != -EADDRINUSE)
 			break;
 	}
@@ -994,24 +1002,34 @@ p9_fd_create_tcp(struct p9_client *client, const char *addr, char *args)
 {
 	int err;
 	struct socket *csocket;
-	struct sockaddr_in sin_server;
+	struct sockaddr_storage stor;
+	struct sockaddr *sin_server = (struct sockaddr *) &stor;
 	struct p9_fd_opts opts;
 
 	err = parse_opts(args, &opts);
 	if (err < 0)
 		return err;
 
-	if (addr == NULL || valid_ipaddr4(addr) < 0)
+	if (addr == NULL)
+		return -EINVAL;
+
+	if (valid_ipaddr4(addr) == 0) {
+		sin_server->sa_family = AF_INET;
+		((struct sockaddr_in *) sin_server)->sin_addr.s_addr = in_aton(addr);
+		((struct sockaddr_in *) sin_server)->sin_port = htons(opts.port);
+	}
+	else if (in6_pton(addr, -1, ((struct sockaddr_in6 *) sin_server)->sin6_addr.s6_addr, -1, NULL)) {
+		sin_server->sa_family = AF_INET6;
+		((struct sockaddr_in6 *) sin_server)->sin6_port = htons(opts.port);
+	}
+	else
 		return -EINVAL;
 
 	csocket = NULL;
 
 	client->trans_opts.tcp.port = opts.port;
 	client->trans_opts.tcp.privport = opts.privport;
-	sin_server.sin_family = AF_INET;
-	sin_server.sin_addr.s_addr = in_aton(addr);
-	sin_server.sin_port = htons(opts.port);
-	err = __sock_create(current->nsproxy->net_ns, PF_INET,
+	err = __sock_create(current->nsproxy->net_ns, sin_server->sa_family,
 			    SOCK_STREAM, IPPROTO_TCP, &csocket, 1);
 	if (err) {
 		pr_err("%s (%d): problem creating socket\n",
@@ -1020,7 +1038,7 @@ p9_fd_create_tcp(struct p9_client *client, const char *addr, char *args)
 	}
 
 	if (opts.privport) {
-		err = p9_bind_privport(csocket);
+		err = p9_bind_privport(csocket, sin_server->sa_family);
 		if (err < 0) {
 			pr_err("%s (%d): problem binding to privport\n",
 			       __func__, task_pid_nr(current));
@@ -1029,9 +1047,9 @@ p9_fd_create_tcp(struct p9_client *client, const char *addr, char *args)
 		}
 	}
 
-	err = READ_ONCE(csocket->ops)->connect(csocket,
-				    (struct sockaddr *)&sin_server,
-				    sizeof(struct sockaddr_in), 0);
+	err = READ_ONCE(csocket->ops)->connect(csocket, sin_server,
+					       sizeof(stor), 0);
+
 	if (err < 0) {
 		pr_err("%s (%d): problem connecting socket to %s\n",
 		       __func__, task_pid_nr(current), addr);
-- 
2.48.1


^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2025-01-17 17:46 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-01-16 16:07 [PATCH] net/9p/fd: support ipv6 for trans=tcp Joshua Murphy
2025-01-16 19:46 ` asmadeus
2025-01-17 17:46   ` Joshua Murphy

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox