From: Laurent Vivier <lvivier@redhat.com>
To: "Dr. David Alan Gilbert" <dgilbert@redhat.com>
Cc: qemu-devel@nongnu.org, "Eric Blake" <eblake@redhat.com>,
"Daniel P. Berrangé" <berrange@redhat.com>,
"Markus Armbruster" <armbru@redhat.com>,
"Paolo Bonzini" <pbonzini@redhat.com>,
"Jason Wang" <jasowang@redhat.com>,
"Stefano Brivio" <sbrivio@redhat.com>
Subject: Re: [PATCH v5 07/12] net: stream: add unix socket
Date: Fri, 1 Jul 2022 11:20:38 +0200 [thread overview]
Message-ID: <aaefd067-6d82-e125-6285-86b2c38e6706@redhat.com> (raw)
In-Reply-To: <Yr1swVqjE2mMoFZe@work-vm>
On 30/06/2022 11:28, Dr. David Alan Gilbert wrote:
> * Laurent Vivier (lvivier@redhat.com) wrote:
>> Signed-off-by: Laurent Vivier <lvivier@redhat.com>
>> Reviewed-by: Stefano Brivio <sbrivio@redhat.com>
>> ---
>> net/stream.c | 106 +++++++++++++++++++++++++++++++++++++++++++++---
>> qemu-options.hx | 1 +
>> 2 files changed, 102 insertions(+), 5 deletions(-)
>>
>> diff --git a/net/stream.c b/net/stream.c
>> index e8afbaca50b6..1a2bc237707e 100644
>> --- a/net/stream.c
>> +++ b/net/stream.c
>> @@ -235,7 +235,7 @@ static NetStreamState *net_stream_fd_init_stream(NetClientState *peer,
>> static void net_stream_accept(void *opaque)
>> {
>> NetStreamState *s = opaque;
>> - struct sockaddr_in saddr;
>> + struct sockaddr_storage saddr;
>> socklen_t len;
>> int fd;
>>
>> @@ -253,9 +253,27 @@ static void net_stream_accept(void *opaque)
>> s->fd = fd;
>> s->nc.link_down = false;
>> net_stream_connect(s);
>> - snprintf(s->nc.info_str, sizeof(s->nc.info_str),
>> - "connection from %s:%d",
>> - inet_ntoa(saddr.sin_addr), ntohs(saddr.sin_port));
>> + switch (saddr.ss_family) {
>> + case AF_INET: {
>> + struct sockaddr_in *saddr_in = (struct sockaddr_in *)&saddr;
>> +
>> + snprintf(s->nc.info_str, sizeof(s->nc.info_str),
>> + "connection from %s:%d",
>> + inet_ntoa(saddr_in->sin_addr), ntohs(saddr_in->sin_port));
>> + break;
>> + }
>> + case AF_UNIX: {
>> + struct sockaddr_un saddr_un;
>> +
>> + len = sizeof(saddr_un);
>> + getsockname(s->listen_fd, (struct sockaddr *)&saddr_un, &len);
>> + snprintf(s->nc.info_str, sizeof(s->nc.info_str),
>> + "connect from %s", saddr_un.sun_path);
>> + break;
>> + }
>> + default:
>> + g_assert_not_reached();
>> + }
>> }
>>
>> static int net_stream_server_init(NetClientState *peer,
>> @@ -295,6 +313,42 @@ static int net_stream_server_init(NetClientState *peer,
>> }
>> break;
>> }
>> + case SOCKET_ADDRESS_TYPE_UNIX: {
>> + struct sockaddr_un saddr_un;
>> +
>> + ret = unlink(addr->u.q_unix.path);
>> + if (ret < 0 && errno != ENOENT) {
>> + error_setg_errno(errp, errno, "failed to unlink socket %s",
>> + addr->u.q_unix.path);
>> + return -1;
>> + }
>> +
>> + saddr_un.sun_family = PF_UNIX;
>> + ret = snprintf(saddr_un.sun_path, sizeof(saddr_un.sun_path), "%s",
>> + addr->u.q_unix.path);
>> + if (ret < 0 || ret >= sizeof(saddr_un.sun_path)) {
>> + error_setg(errp, "UNIX socket path '%s' is too long",
>> + addr->u.q_unix.path);
>> + error_append_hint(errp, "Path must be less than %zu bytes\n",
>> + sizeof(saddr_un.sun_path));
>
> return here?
>> +
>> + fd = qemu_socket(PF_UNIX, SOCK_STREAM, 0);
>> + if (fd < 0) {
>> + error_setg_errno(errp, errno, "can't create stream socket");
>> + return -1;
>> + }
>> + qemu_socket_set_nonblock(fd);
>> +
>> + ret = bind(fd, (struct sockaddr *)&saddr_un, sizeof(saddr_un));
>> + if (ret < 0) {
>> + error_setg_errno(errp, errno, "can't create socket with path: %s",
>> + saddr_un.sun_path);
>> + closesocket(fd);
>> + return -1;
>> + }
>> + break;
>> + }
>> case SOCKET_ADDRESS_TYPE_FD:
>> fd = monitor_fd_param(monitor_cur(), addr->u.fd.str, errp);
>> if (fd == -1) {
>> @@ -380,6 +434,48 @@ static int net_stream_client_init(NetClientState *peer,
>> ntohs(saddr_in.sin_port));
>> break;
>> }
>> + case SOCKET_ADDRESS_TYPE_UNIX: {
>> + struct sockaddr_un saddr_un;
>> +
>> + saddr_un.sun_family = PF_UNIX;
>> + ret = snprintf(saddr_un.sun_path, sizeof(saddr_un.sun_path), "%s",
>> + addr->u.q_unix.path);
>> + if (ret < 0 || ret >= sizeof(saddr_un.sun_path)) {
>> + error_setg(errp, "UNIX socket path '%s' is too long",
>> + addr->u.q_unix.path);
>> + error_append_hint(errp, "Path must be less than %zu bytes\n",
>> + sizeof(saddr_un.sun_path));
>
> and here
>
> (Can you not do a lot of this just by calling util/qemu-sockets.c
> unix_connect?)
Thank you for your comments.
In fact, in the last patch, I replace all this code by QIO functions.
I keep all the intermediate patches to be sure I don't break anything from the original
behaviour of -netdev socket and to ease debugging by allowing to bisect between the
different steps in the change.
Thanks,
Laurent
next prev parent reply other threads:[~2022-07-01 9:22 UTC|newest]
Thread overview: 22+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-06-27 15:47 [PATCH v5 00/12] qapi: net: add unix socket type support to netdev backend Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 01/12] net: introduce convert_host_port() Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 02/12] net: remove the @errp argument of net_client_inits() Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 03/12] net: simplify net_client_parse() error management Laurent Vivier
2022-06-29 10:50 ` Markus Armbruster
2022-06-27 15:47 ` [PATCH v5 04/12] qapi: net: introduce a way to bypass qemu_opts_parse_noisily() Laurent Vivier
2022-06-29 13:21 ` Markus Armbruster
2022-06-27 15:47 ` [PATCH v5 05/12] qapi: net: add stream and dgram netdevs Laurent Vivier
2022-06-29 11:20 ` Markus Armbruster
2022-06-30 15:09 ` Laurent Vivier
2022-06-29 13:49 ` Markus Armbruster
2022-06-27 15:47 ` [PATCH v5 06/12] net: stream: Don't ignore EINVAL on netdev socket connection Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 07/12] net: stream: add unix socket Laurent Vivier
2022-06-30 9:28 ` Dr. David Alan Gilbert
2022-07-01 9:20 ` Laurent Vivier [this message]
2022-07-04 5:12 ` Markus Armbruster
2022-06-27 15:47 ` [PATCH v5 08/12] net: dgram: make dgram_dst generic Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 09/12] net: dgram: move mcast specific code from net_socket_fd_init_dgram() Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 10/12] net: dgram: add unix socket Laurent Vivier
2022-06-27 15:47 ` [PATCH v5 11/12] qemu-sockets: introduce socket_uri() Laurent Vivier
2022-06-30 9:35 ` Dr. David Alan Gilbert
2022-06-27 15:47 ` [PATCH v5 12/12] net: stream: move to QIO Laurent Vivier
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aaefd067-6d82-e125-6285-86b2c38e6706@redhat.com \
--to=lvivier@redhat.com \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=dgilbert@redhat.com \
--cc=eblake@redhat.com \
--cc=jasowang@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=sbrivio@redhat.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).