[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <kyiugvciavdrxb5y6gtuegmvla5tbohlqrrq7terl6xmpykmjo@tnw7fg6dkfdh>
Date: Mon, 20 Jan 2025 11:06:29 +0100
From: Stefano Garzarella <sgarzare@...hat.com>
To: Michal Luczaj <mhal@...x.co>
Cc: "David S. Miller" <davem@...emloft.net>,
Eric Dumazet <edumazet@...gle.com>, Jakub Kicinski <kuba@...nel.org>,
Paolo Abeni <pabeni@...hat.com>, Simon Horman <horms@...nel.org>,
George Zhang <georgezhang@...are.com>, Dmitry Torokhov <dtor@...are.com>, Andy King <acking@...are.com>,
netdev@...r.kernel.org
Subject: Re: [PATCH net 3/5] vsock/test: Introduce vsock_bind()
On Fri, Jan 17, 2025 at 10:59:43PM +0100, Michal Luczaj wrote:
>Add a helper for socket()+bind(). Adapt callers.
>
>Signed-off-by: Michal Luczaj <mhal@...x.co>
>---
> tools/testing/vsock/util.c | 56 +++++++++++++++++-----------------------
> tools/testing/vsock/util.h | 1 +
> tools/testing/vsock/vsock_test.c | 17 +-----------
> 3 files changed, 25 insertions(+), 49 deletions(-)
Reviewed-by: Stefano Garzarella <sgarzare@...hat.com>
>
>diff --git a/tools/testing/vsock/util.c b/tools/testing/vsock/util.c
>index 34e9dac0a105f8aeb8c9af379b080d5ce8cb2782..31ee1767c8b73c05cfd219c3d520a677df6e66a6 100644
>--- a/tools/testing/vsock/util.c
>+++ b/tools/testing/vsock/util.c
>@@ -96,33 +96,42 @@ void vsock_wait_remote_close(int fd)
> close(epollfd);
> }
>
>-/* 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_bind(unsigned int cid, unsigned int port, int type)
> {
>- struct sockaddr_vm sa_client = {
>- .svm_family = AF_VSOCK,
>- .svm_cid = VMADDR_CID_ANY,
>- .svm_port = bind_port,
>- };
>- struct sockaddr_vm sa_server = {
>+ struct sockaddr_vm sa = {
> .svm_family = AF_VSOCK,
> .svm_cid = cid,
> .svm_port = port,
> };
>+ int fd;
>
>- int client_fd, ret;
>-
>- client_fd = socket(AF_VSOCK, type, 0);
>- if (client_fd < 0) {
>+ fd = socket(AF_VSOCK, type, 0);
>+ if (fd < 0) {
> perror("socket");
> exit(EXIT_FAILURE);
> }
>
>- if (bind(client_fd, (struct sockaddr *)&sa_client, sizeof(sa_client))) {
>+ if (bind(fd, (struct sockaddr *)&sa, sizeof(sa))) {
> perror("bind");
> exit(EXIT_FAILURE);
> }
>
>+ 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)
>+{
>+ struct sockaddr_vm sa_server = {
>+ .svm_family = AF_VSOCK,
>+ .svm_cid = cid,
>+ .svm_port = port,
>+ };
>+
>+ int client_fd, ret;
>+
>+ client_fd = vsock_bind(VMADDR_CID_ANY, bind_port, type);
>+
> timeout_begin(TIMEOUT);
> do {
> ret = connect(client_fd, (struct sockaddr *)&sa_server, sizeof(sa_server));
>@@ -192,28 +201,9 @@ int vsock_seqpacket_connect(unsigned int cid, unsigned int port)
> /* Listen on <cid, port> and return the file descriptor. */
> static int vsock_listen(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 fd;
>
>- fd = socket(AF_VSOCK, type, 0);
>- if (fd < 0) {
>- perror("socket");
>- exit(EXIT_FAILURE);
>- }
>-
>- if (bind(fd, &addr.sa, sizeof(addr.svm)) < 0) {
>- perror("bind");
>- exit(EXIT_FAILURE);
>- }
>+ fd = vsock_bind(cid, port, type);
>
> if (listen(fd, 1) < 0) {
> perror("listen");
>diff --git a/tools/testing/vsock/util.h b/tools/testing/vsock/util.h
>index ba84d296d8b71e1bcba2abdad337e07aac45e75e..7736594a15d29449d98bd1e9e19c3acd1a623443 100644
>--- a/tools/testing/vsock/util.h
>+++ b/tools/testing/vsock/util.h
>@@ -43,6 +43,7 @@ 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);
> int vsock_stream_connect(unsigned int cid, unsigned int port);
>+int vsock_bind(unsigned int cid, unsigned int port, int type);
> int vsock_bind_connect(unsigned int cid, unsigned int port,
> unsigned int bind_port, int type);
> int vsock_seqpacket_connect(unsigned int cid, unsigned int port);
>diff --git a/tools/testing/vsock/vsock_test.c b/tools/testing/vsock/vsock_test.c
>index 48f17641ca504316d1199926149c9bd62eb2921d..28a5083bbfd600cf84a1a85cec2f272ce6912dd3 100644
>--- a/tools/testing/vsock/vsock_test.c
>+++ b/tools/testing/vsock/vsock_test.c
>@@ -108,24 +108,9 @@ static void test_stream_bind_only_client(const struct test_opts *opts)
>
> static void test_stream_bind_only_server(const struct test_opts *opts)
> {
>- union {
>- struct sockaddr sa;
>- struct sockaddr_vm svm;
>- } addr = {
>- .svm = {
>- .svm_family = AF_VSOCK,
>- .svm_port = opts->peer_port,
>- .svm_cid = VMADDR_CID_ANY,
>- },
>- };
> int fd;
>
>- fd = socket(AF_VSOCK, SOCK_STREAM, 0);
>-
>- if (bind(fd, &addr.sa, sizeof(addr.svm)) < 0) {
>- perror("bind");
>- exit(EXIT_FAILURE);
>- }
>+ fd = vsock_bind(VMADDR_CID_ANY, opts->peer_port, SOCK_STREAM);
>
> /* Notify the client that the server is ready */
> control_writeln("BIND");
>
>--
>2.47.1
>
Powered by blists - more mailing lists