From: David Gibson <david@gibson.dropbear.id.au>
To: Laurent Vivier <lvivier@redhat.com>
Cc: qemu-devel@nongnu.org, "Jason Wang" <jasowang@redhat.com>,
"Greg Kurz" <groug@kaod.org>, "Thomas Huth" <thuth@redhat.com>,
"Eric Blake" <eblake@redhat.com>,
"Dr. David Alan Gilbert" <dgilbert@redhat.com>,
"Paolo Bonzini" <pbonzini@redhat.com>,
"Daniel P. Berrangé" <berrange@redhat.com>,
"Markus Armbruster" <armbru@redhat.com>,
"Stefano Brivio" <sbrivio@redhat.com>
Subject: Re: [PATCH v9 05/16] qapi: net: add stream and dgram netdevs
Date: Thu, 6 Oct 2022 11:37:50 +1100 [thread overview]
Message-ID: <Yz4jXvlVQMn0f8S1@yekko> (raw)
In-Reply-To: <bb04fbf9-f72c-31a5-a017-e519a701302d@redhat.com>
[-- Attachment #1: Type: text/plain, Size: 4101 bytes --]
On Wed, Oct 05, 2022 at 12:08:27PM +0200, Laurent Vivier wrote:
> On 9/28/22 07:55, David Gibson wrote:
> > > +static int net_stream_server_init(NetClientState *peer,
> > > + const char *model,
> > > + const char *name,
> > > + SocketAddress *addr,
> > > + Error **errp)
> > > +{
> > > + NetClientState *nc;
> > > + NetStreamState *s;
> > > + int fd, ret;
> > > +
> > > + switch (addr->type) {
> > > + case SOCKET_ADDRESS_TYPE_INET: {
> > > + struct sockaddr_in saddr_in;
> > > +
> > > + if (convert_host_port(&saddr_in, addr->u.inet.host, addr->u.inet.port,
> > > + errp) < 0) {
> > > + return -1;
> > > + }
> > > +
> > > + fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> > > + if (fd < 0) {
> > > + error_setg_errno(errp, errno, "can't create stream socket");
> > > + return -1;
> > > + }
> > > + qemu_socket_set_nonblock(fd);
> > > +
> > > + socket_set_fast_reuse(fd);
> > > +
> > > + ret = bind(fd, (struct sockaddr *)&saddr_in, sizeof(saddr_in));
> > > + if (ret < 0) {
> > > + error_setg_errno(errp, errno, "can't bind ip=%s to socket",
> > > + inet_ntoa(saddr_in.sin_addr));
> > > + closesocket(fd);
> > > + return -1;
> > > + }
> > > + break;
> > > + }
> > > + case SOCKET_ADDRESS_TYPE_FD:
> > > + fd = monitor_fd_param(monitor_cur(), addr->u.fd.str, errp);
> > > + if (fd == -1) {
> > > + return -1;
> > > + }
> > > + ret = qemu_socket_try_set_nonblock(fd);
> > > + if (ret < 0) {
> > > + error_setg_errno(errp, -ret, "%s: Can't use file descriptor %d",
> > > + name, fd);
> > > + return -1;
> > > + }
> > > + break;
> > > + default:
> > > + error_setg(errp, "only support inet or fd type");
> > > + return -1;
> > > + }
> > > +
> > > + ret = listen(fd, 0);
> > Does this make sense for a passed in fd? If someone passes a "server"
> > fd, are they likely to be passing a socket on which bind() but not
> > listen() has been called? Or one on which both bind() and listen()
> > have been called?
> >
>
> Original code in net/socket.c doesn't manage server case with fd.
>
> So I have checked what is done for QIO (all this code is overwritten by
> patch introducing QIO anyway):
>
> At the end of the series, we use qio_channel_socket_listen_async() in
> net_stream_server_init(), that in the end calls socket_listen().
>
> With SOCKET_ADDRESS_TYPE_FD we does the listen() (without bind()) with the following comment:
>
> case SOCKET_ADDRESS_TYPE_FD:
> fd = socket_get_fd(addr->u.fd.str, errp);
> if (fd < 0) {
> return -1;
> }
>
> /*
> * If the socket is not yet in the listen state, then transition it to
> * the listen state now.
> *
> * If it's already listening then this updates the backlog value as
> * requested.
> *
> * If this socket cannot listen because it's already in another state
> * (e.g. unbound or connected) then we'll catch the error here.
> */
> if (listen(fd, num) != 0) {
> error_setg_errno(errp, errno, "Failed to listen on fd socket");
> closesocket(fd);
> return -1;
> }
> break;
>
> So I think we should keep the listen() in our case too.
Ok, that makes sense to me. Or at least, if it's not correct we
should fix it later for all the places at the same time in the qio
code.
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
next prev parent reply other threads:[~2022-10-06 2:49 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-09-26 19:50 [PATCH v9 00/16] qapi: net: add unix socket type support to netdev backend Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 01/16] net: introduce convert_host_port() Laurent Vivier
2022-09-28 4:55 ` David Gibson
2022-09-26 19:50 ` [PATCH v9 02/16] net: remove the @errp argument of net_client_inits() Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 03/16] net: simplify net_client_parse() error management Laurent Vivier
2022-09-28 4:56 ` David Gibson
2022-09-26 19:50 ` [PATCH v9 04/16] qapi: net: introduce a way to bypass qemu_opts_parse_noisily() Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 05/16] qapi: net: add stream and dgram netdevs Laurent Vivier
2022-09-27 9:18 ` Markus Armbruster
2022-09-28 5:55 ` David Gibson
2022-10-05 10:08 ` Laurent Vivier
2022-10-06 0:37 ` David Gibson [this message]
2022-09-26 19:50 ` [PATCH v9 06/16] net: socket: Don't ignore EINVAL on netdev socket connection Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 07/16] net: stream: " Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 08/16] net: stream: add unix socket Laurent Vivier
2022-09-28 6:12 ` David Gibson
2022-10-05 13:38 ` Laurent Vivier
2022-10-06 0:39 ` David Gibson
2022-09-26 19:50 ` [PATCH v9 09/16] net: dgram: make dgram_dst generic Laurent Vivier
2022-09-28 6:17 ` David Gibson
2022-09-26 19:50 ` [PATCH v9 10/16] net: dgram: move mcast specific code from net_socket_fd_init_dgram() Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 11/16] net: dgram: add unix socket Laurent Vivier
2022-09-28 6:22 ` David Gibson
2022-09-26 19:50 ` [PATCH v9 12/16] qemu-sockets: move and rename SocketAddress_to_str() Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 13/16] qemu-sockets: update socket_uri() and socket_parse() to be consistent Laurent Vivier
2022-09-28 6:23 ` David Gibson
2022-09-26 19:50 ` [PATCH v9 14/16] net: stream: move to QIO to enable additional parameters Laurent Vivier
2022-09-26 19:50 ` [PATCH v9 15/16] tests/qtest: netdev: test stream and dgram backends Laurent Vivier
2022-09-27 10:01 ` Thomas Huth
2022-09-26 19:50 ` [PATCH v9 16/16] net: stream: add QAPI events to report connection state 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=Yz4jXvlVQMn0f8S1@yekko \
--to=david@gibson.dropbear.id.au \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=dgilbert@redhat.com \
--cc=eblake@redhat.com \
--cc=groug@kaod.org \
--cc=jasowang@redhat.com \
--cc=lvivier@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=sbrivio@redhat.com \
--cc=thuth@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).