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 3/9] net: introduce tcp_client_start()
Date: Mon, 05 Mar 2012 15:26:12 +0200	[thread overview]
Message-ID: <4F54BEF4.1080704@redhat.com> (raw)
In-Reply-To: <20120305100338.3595.19978.stgit@dhcp-8-167.nay.redhat.com>

On 03/05/2012 12:03 PM, Amos Kong wrote:
> Introduce tcp_client_start() by moving original code in
> tcp_start_outgoing_migration().
> 
> Signed-off-by: Amos Kong <akong@redhat.com>
> ---
>  net.c         |   39 +++++++++++++++++++++++++++++++++++++++
>  qemu_socket.h |    1 +
>  2 files changed, 40 insertions(+), 0 deletions(-)
> 
> diff --git a/net.c b/net.c
> index 0260968..5c20e22 100644
> --- a/net.c
> +++ b/net.c
> @@ -126,6 +126,45 @@ int tcp_server_start(const char *str, int *fd)
>      return ret;
>  }
>  
> +int tcp_client_start(const char *str, int *fd)
> +{
> +    struct sockaddr_in saddr;
> +    int ret;
> +
> +    if (parse_host_port(&saddr, str) < 0) {
> +        return -EINVAL;
> +    }
> +
> +    *fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> +    if (fd < 0) {
> +        perror("socket");
> +        return -1;
> +    }
> +    socket_set_nonblock(*fd);
> +
> +    for (;;) {
> +        ret = connect(*fd, (struct sockaddr *)&saddr, sizeof(saddr));
> +        if (ret < 0) {
> +            ret = -socket_error();
> +            if (ret == -EINPROGRESS) {
> +                break;
> +#ifdef _WIN32
> +            } else if (ret == -WSAEALREADY || ret == -WSAEINVAL) {
> +                break;
> +#endif
> +            } else if (ret != -EINTR && ret != -EWOULDBLOCK) {
> +                perror("connect");
> +                closesocket(*fd);
> +                return -1;

I think it should be: return ret (otherwise you lose the error code).
And you need it.

Orit
> +            }
> +        } else {
> +            break;
> +        }
> +    }
> +
> +    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 d612793..9246578 100644
> --- a/qemu_socket.h
> +++ b/qemu_socket.h
> @@ -55,6 +55,7 @@ int unix_connect_opts(QemuOpts *opts);
>  int unix_connect(const char *path);
>  
>  int tcp_server_start(const char *str, int *fd);
> +int tcp_client_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);
> 
> 


  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
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 [this message]
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=4F54BEF4.1080704@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.