qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
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



  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).