summary refs log tree commit diff
path: root/vsock.c
diff options
context:
space:
mode:
authorAlyssa Ross <hi@alyssa.is>2020-08-28 11:57:29 +0000
committerAlyssa Ross <hi@alyssa.is>2020-09-10 17:58:43 +0000
commitec8e077dee523f657f1445098def879f9559d66e (patch)
tree31727fd6ca372463879c3a850a5b8ffc6ac56b57 /vsock.c
downloaducspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.tar
ucspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.tar.gz
ucspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.tar.bz2
ucspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.tar.lz
ucspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.tar.xz
ucspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.tar.zst
ucspi-vsock-ec8e077dee523f657f1445098def879f9559d66e.zip
Initial commit
Diffstat (limited to 'vsock.c')
-rw-r--r--vsock.c72
1 files changed, 72 insertions, 0 deletions
diff --git a/vsock.c b/vsock.c
new file mode 100644
index 0000000..3bcd8b3
--- /dev/null
+++ b/vsock.c
@@ -0,0 +1,72 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+// SPDX-FileCopyrightText: 2020 Alyssa Ross <hi@alyssa.is>
+
+#define _GNU_SOURCE
+
+#include "vsock.h"
+
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+
+#include <linux/vm_sockets.h>
+
+static void fill_sockaddr(struct sockaddr_vm *addr, uint32_t cid, uint32_t port)
+{
+	addr->svm_family = AF_VSOCK;
+	addr->svm_cid = cid;
+	addr->svm_port = port;
+}
+
+int vsock_bind(int fd, uint32_t cid, uint32_t port)
+{
+	struct sockaddr_vm addr = { 0 };
+	fill_sockaddr(&addr, cid, port);
+
+	if (bind(fd, (struct sockaddr *)&addr, sizeof addr) == -1)
+		return -1;
+
+	return 0;
+}
+
+int vsock_accept(int sockfd, uint32_t *cid, uint32_t *port)
+{
+	struct sockaddr_vm addr = { 0 };
+	socklen_t addr_size = sizeof addr;
+
+	if (accept(sockfd, (struct sockaddr *)&addr, &addr_size) == -1)
+		return -1;
+
+	*cid = addr.svm_cid;
+	*port = addr.svm_port;
+
+	return 0;
+}
+
+int vsock_connect(int fd, uint32_t cid, uint32_t port)
+{
+	struct sockaddr_vm addr = { 0 };
+	fill_sockaddr(&addr, cid, port);
+	return connect(fd, (struct sockaddr *)&addr, sizeof addr);
+}
+
+int vsock_open(uint32_t cid, uint32_t port)
+{
+	int fd = socket(AF_VSOCK, SOCK_STREAM, 0);
+	if (fd == -1)
+		return -1;
+
+	return vsock_connect(fd, cid, port);
+}
+
+int vsock_get_port(int fd, uint32_t *port)
+{
+	struct sockaddr_vm addr;
+	socklen_t addrlen = sizeof addr;
+
+	if (getsockname(fd, (struct sockaddr *)&addr, &addrlen) == -1)
+		return -1;
+
+	*port = addr.svm_port;
+
+	return 0;
+}