]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
vsock/test: Introduce vsock_connect_fd()
authorMichal Luczaj <mhal@rbox.co>
Tue, 28 Jan 2025 13:15:30 +0000 (14:15 +0100)
committerJakub Kicinski <kuba@kernel.org>
Thu, 30 Jan 2025 02:50:37 +0000 (18:50 -0800)
Distill timeout-guarded vsock_connect_fd(). Adapt callers.

Suggested-by: Stefano Garzarella <sgarzare@redhat.com>
Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
Signed-off-by: Michal Luczaj <mhal@rbox.co>
Link: https://patch.msgid.link/20250128-vsock-transport-vs-autobind-v3-4-1cf57065b770@rbox.co
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
tools/testing/vsock/util.c
tools/testing/vsock/util.h

index 6e36f9371532cfc75dd14131b84bf8393ca0952b..de25892f865f07672da0886be8bd1a429ade8b05 100644 (file)
@@ -120,27 +120,33 @@ int vsock_bind(unsigned int cid, unsigned int port, int type)
        return fd;
 }
 
-/* Bind to <bind_port>, connect to <cid, port> and return the file descriptor. */
-int vsock_bind_connect(unsigned int cid, unsigned int port, unsigned int bind_port, int type)
+int vsock_connect_fd(int fd, unsigned int cid, unsigned int port)
 {
-       struct sockaddr_vm sa_server = {
+       struct sockaddr_vm sa = {
                .svm_family = AF_VSOCK,
                .svm_cid = cid,
                .svm_port = port,
        };
-
-       int client_fd, ret;
-
-       client_fd = vsock_bind(VMADDR_CID_ANY, bind_port, type);
+       int ret;
 
        timeout_begin(TIMEOUT);
        do {
-               ret = connect(client_fd, (struct sockaddr *)&sa_server, sizeof(sa_server));
+               ret = connect(fd, (struct sockaddr *)&sa, sizeof(sa));
                timeout_check("connect");
        } while (ret < 0 && errno == EINTR);
        timeout_end();
 
-       if (ret < 0) {
+       return ret;
+}
+
+/* Bind to <bind_port>, connect to <cid, port> and return the file descriptor. */
+int vsock_bind_connect(unsigned int cid, unsigned int port, unsigned int bind_port, int type)
+{
+       int client_fd;
+
+       client_fd = vsock_bind(VMADDR_CID_ANY, bind_port, type);
+
+       if (vsock_connect_fd(client_fd, cid, port)) {
                perror("connect");
                exit(EXIT_FAILURE);
        }
@@ -151,17 +157,6 @@ int vsock_bind_connect(unsigned int cid, unsigned int port, unsigned int bind_po
 /* Connect to <cid, port> and return the file descriptor. */
 int vsock_connect(unsigned int cid, unsigned int port, int type)
 {
-       union {
-               struct sockaddr sa;
-               struct sockaddr_vm svm;
-       } addr = {
-               .svm = {
-                       .svm_family = AF_VSOCK,
-                       .svm_port = port,
-                       .svm_cid = cid,
-               },
-       };
-       int ret;
        int fd;
 
        control_expectln("LISTENING");
@@ -172,20 +167,14 @@ int vsock_connect(unsigned int cid, unsigned int port, int type)
                exit(EXIT_FAILURE);
        }
 
-       timeout_begin(TIMEOUT);
-       do {
-               ret = connect(fd, &addr.sa, sizeof(addr.svm));
-               timeout_check("connect");
-       } while (ret < 0 && errno == EINTR);
-       timeout_end();
-
-       if (ret < 0) {
+       if (vsock_connect_fd(fd, cid, port)) {
                int old_errno = errno;
 
                close(fd);
                fd = -1;
                errno = old_errno;
        }
+
        return fd;
 }
 
index 077842905bc3e7a4bbd22caba4b7bde976de2718..d1f765ce3eeeed8f738630846bb47c4f3f6f946f 100644 (file)
@@ -39,6 +39,7 @@ struct test_case {
 void init_signals(void);
 unsigned int parse_cid(const char *str);
 unsigned int parse_port(const char *str);
+int vsock_connect_fd(int fd, unsigned int cid, unsigned int port);
 int vsock_connect(unsigned int cid, unsigned int port, int type);
 int vsock_accept(unsigned int cid, unsigned int port,
                 struct sockaddr_vm *clientaddrp, int type);