All of lore.kernel.org
 help / color / mirror / Atom feed
From: Orit Wasserman <owasserm@redhat.com>
To: Amos Kong <akong@redhat.com>
Cc: aliguori@us.ibm.com, kvm@vger.kernel.org, quintela@redhat.com,
	jasowang@redhat.com, qemu-devel@nongnu.org, laine@redhat.com
Subject: Re: [Qemu-devel] [PATCH v2 1/9] net: introduce tcp_server_start()
Date: Mon, 05 Mar 2012 15:25:36 +0200	[thread overview]
Message-ID: <4F54BED0.3040000@redhat.com> (raw)
In-Reply-To: <20120305100320.3595.6964.stgit@dhcp-8-167.nay.redhat.com>

On 03/05/2012 12:03 PM, Amos Kong wrote:
> Introduce tcp_server_start() by moving original code in
> tcp_start_incoming_migration().
> 
> Signed-off-by: Amos Kong <akong@redhat.com>
> ---
>  net.c         |   27 +++++++++++++++++++++++++++
>  qemu_socket.h |    2 ++
>  2 files changed, 29 insertions(+), 0 deletions(-)
> 
> diff --git a/net.c b/net.c
> index c34474f..0260968 100644
> --- a/net.c
> +++ b/net.c
> @@ -99,6 +99,33 @@ static int get_str_sep(char *buf, int buf_size, const char **pp, int sep)
>      return 0;
>  }
>  
> +int tcp_server_start(const char *str, int *fd)
> +{
> +    int val, ret;
> +    struct sockaddr_in saddr;
> +
> +    if (parse_host_port(&saddr, str) < 0) {

error message would be nice 

> +        return -1;
> +    }
> +
> +    *fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> +    if (fd < 0) {
> +        perror("socket");
> +        return -1;
> +    }

this is actually net_socket_listen_init version 
tcp_start_incoming_migration returns the error -socket_error().
I prefer not to lose the errno.

I know that when calling net_socket_listen_init for some unknown reason there is an explict check for -1
" if (net_socket_listen_init(vlan, "socket", name, listen) == -1) {"
I think it is a good opportunity to change this check.

Orit
> +    socket_set_nonblock(*fd);
> +
> +    /* allow fast reuse */
> +    val = 1;
> +    setsockopt(*fd, SOL_SOCKET, SO_REUSEADDR, (const char *)&val, sizeof(val));
> +
> +    ret = bind(*fd, (struct sockaddr *)&saddr, sizeof(saddr));
> +    if (ret < 0) {
> +        closesocket(*fd);
> +    }
> +    return ret;
> +}
> +
>  int parse_host_port(struct sockaddr_in *saddr, const char *str)
>  {
>      char buf[512];
> diff --git a/qemu_socket.h b/qemu_socket.h
> index fe4cf6c..d612793 100644
> --- a/qemu_socket.h
> +++ b/qemu_socket.h
> @@ -54,6 +54,8 @@ int unix_listen(const char *path, char *ostr, int olen);
>  int unix_connect_opts(QemuOpts *opts);
>  int unix_connect(const char *path);
>  
> +int tcp_server_start(const char *str, int *fd);
> +
>  /* Old, ipv4 only bits.  Don't use for new code. */
>  int parse_host_port(struct sockaddr_in *saddr, const char *str);
>  int socket_init(void);
> 
> 


  reply	other threads:[~2012-03-05 13:26 UTC|newest]

Thread overview: 29+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-03-05 10:03 [PATCH v2 0/9] support to migrate with IPv6 address Amos Kong
2012-03-05 10:03 ` [Qemu-devel] " Amos Kong
2012-03-05 10:03 ` [PATCH v2 1/9] net: introduce tcp_server_start() Amos Kong
2012-03-05 10:03   ` [Qemu-devel] " Amos Kong
2012-03-05 13:25   ` Orit Wasserman [this message]
2012-03-05 13:49     ` Amos Kong
2012-03-05 10:03 ` [PATCH v2 2/9] net: use tcp_server_start() for tcp server creation Amos Kong
2012-03-05 10:03   ` [Qemu-devel] " Amos Kong
2012-03-05 13:27   ` Orit Wasserman
2012-03-05 13:44     ` Amos Kong
2012-03-05 13:44       ` [Qemu-devel] " Amos Kong
2012-03-05 10:03 ` [PATCH v2 3/9] net: introduce tcp_client_start() Amos Kong
2012-03-05 10:03   ` [Qemu-devel] " Amos Kong
2012-03-05 13:26   ` Orit Wasserman
2012-03-05 13:36   ` Orit Wasserman
2012-03-05 10:03 ` [PATCH v2 4/9] net: use tcp_client_start for tcp client creation Amos Kong
2012-03-05 10:03   ` [Qemu-devel] " Amos Kong
2012-03-05 13:39   ` Orit Wasserman
2012-03-05 13:39     ` [Qemu-devel] " Orit Wasserman
2012-03-05 10:03 ` [PATCH v2 5/9] net: refector tcp_*_start functions Amos Kong
2012-03-05 10:03   ` [Qemu-devel] " Amos Kong
2012-03-05 10:04 ` [PATCH v2 6/9] net: use getaddrinfo() in tcp_start_common Amos Kong
2012-03-05 10:04   ` [Qemu-devel] " Amos Kong
2012-03-05 10:04 ` [PATCH v2 7/9] net: introduce parse_host_port_info() Amos Kong
2012-03-05 10:04   ` [Qemu-devel] " Amos Kong
2012-03-05 10:04 ` [PATCH v2 8/9] net: split hostname and service by last colon Amos Kong
2012-03-05 10:04   ` [Qemu-devel] " Amos Kong
2012-03-05 10:04 ` [PATCH v2 9/9] net: support to include ipv6 address by brackets Amos Kong
2012-03-05 10:04   ` [Qemu-devel] " Amos Kong

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=4F54BED0.3040000@redhat.com \
    --to=owasserm@redhat.com \
    --cc=akong@redhat.com \
    --cc=aliguori@us.ibm.com \
    --cc=jasowang@redhat.com \
    --cc=kvm@vger.kernel.org \
    --cc=laine@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=quintela@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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.