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: [PATCH v2 4/9] net: use tcp_client_start for tcp client creation
Date: Mon, 05 Mar 2012 15:39:37 +0200 [thread overview]
Message-ID: <4F54C219.2060703@redhat.com> (raw)
In-Reply-To: <20120305100347.3595.17996.stgit@dhcp-8-167.nay.redhat.com>
On 03/05/2012 12:03 PM, Amos Kong wrote:
> Use tcp_client_start() in those two functions:
> tcp_start_outgoing_migration()
> net_socket_connect_init()
>
> Signed-off-by: Amos Kong <akong@redhat.com>
> ---
> migration-tcp.c | 41 +++++++++++++----------------------------
> net/socket.c | 41 +++++++++++------------------------------
> 2 files changed, 24 insertions(+), 58 deletions(-)
>
> diff --git a/migration-tcp.c b/migration-tcp.c
> index ecadd10..4f89bff 100644
> --- a/migration-tcp.c
> +++ b/migration-tcp.c
> @@ -81,43 +81,28 @@ static void tcp_wait_for_connect(void *opaque)
>
> int tcp_start_outgoing_migration(MigrationState *s, const char *host_port)
> {
> - struct sockaddr_in addr;
> int ret;
> -
> - ret = parse_host_port(&addr, host_port);
> - if (ret < 0) {
> - return ret;
> - }
> + int fd;
>
> s->get_error = socket_errno;
> s->write = socket_write;
> s->close = tcp_close;
>
> - s->fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> - if (s->fd == -1) {
> - DPRINTF("Unable to open socket");
> - return -socket_error();
> - }
> -
> - socket_set_nonblock(s->fd);
> -
> - do {
> - ret = connect(s->fd, (struct sockaddr *)&addr, sizeof(addr));
> - if (ret == -1) {
> - ret = -socket_error();
> - }
> - if (ret == -EINPROGRESS || ret == -EWOULDBLOCK) {
> - qemu_set_fd_handler2(s->fd, NULL, NULL, tcp_wait_for_connect, s);
> - return 0;
> - }
> - } while (ret == -EINTR);
> -
> - if (ret < 0) {
> + ret = tcp_client_start(host_port, &fd);
> + s->fd = fd;
you don't need fd you can pass s->fd to the function.
Orit
> + if (ret == -EINPROGRESS || ret == -EWOULDBLOCK) {
> + DPRINTF("connect in progress");
> + qemu_set_fd_handler2(s->fd, NULL, NULL, tcp_wait_for_connect, s);
> + } else if (ret < 0) {
> DPRINTF("connect failed\n");
> - migrate_fd_error(s);
> + if (ret != -EINVAL) {
> + migrate_fd_error(s);
> + }
> return ret;
> + } else {
> + migrate_fd_connect(s);
> }
> - migrate_fd_connect(s);
> +
> return 0;
> }
>
> diff --git a/net/socket.c b/net/socket.c
> index 5feb3d2..b7cd8ec 100644
> --- a/net/socket.c
> +++ b/net/socket.c
> @@ -434,41 +434,22 @@ static int net_socket_connect_init(VLANState *vlan,
> const char *host_str)
> {
> NetSocketState *s;
> - int fd, connected, ret, err;
> + int fd, connected, ret;
> struct sockaddr_in saddr;
>
> - if (parse_host_port(&saddr, host_str) < 0)
> - return -1;
> -
> - fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> - if (fd < 0) {
> - perror("socket");
> - return -1;
> - }
> - socket_set_nonblock(fd);
> -
> - connected = 0;
> - for(;;) {
> - ret = connect(fd, (struct sockaddr *)&saddr, sizeof(saddr));
> - if (ret < 0) {
> - err = socket_error();
> - if (err == EINTR || err == EWOULDBLOCK) {
> - } else if (err == EINPROGRESS) {
> - break;
> + ret = tcp_client_start(host_str, &fd);
> + if (ret == -EINPROGRESS || ret == -EWOULDBLOCK) {
> + connected = 0;
> #ifdef _WIN32
> - } else if (err == WSAEALREADY || err == WSAEINVAL) {
> - break;
> + } else if (ret == -WSAEALREADY || ret == -WSAEINVAL) {
> + connected = 0;
> #endif
> - } else {
> - perror("connect");
> - closesocket(fd);
> - return -1;
> - }
> - } else {
> - connected = 1;
> - break;
> - }
> + } else if (ret < 0) {
> + return -1;
> + } else {
> + connected = 1;
> }
> +
> s = net_socket_fd_init(vlan, model, name, fd, connected);
> if (!s)
> return -1;
>
>
WARNING: multiple messages have this Message-ID (diff)
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 4/9] net: use tcp_client_start for tcp client creation
Date: Mon, 05 Mar 2012 15:39:37 +0200 [thread overview]
Message-ID: <4F54C219.2060703@redhat.com> (raw)
In-Reply-To: <20120305100347.3595.17996.stgit@dhcp-8-167.nay.redhat.com>
On 03/05/2012 12:03 PM, Amos Kong wrote:
> Use tcp_client_start() in those two functions:
> tcp_start_outgoing_migration()
> net_socket_connect_init()
>
> Signed-off-by: Amos Kong <akong@redhat.com>
> ---
> migration-tcp.c | 41 +++++++++++++----------------------------
> net/socket.c | 41 +++++++++++------------------------------
> 2 files changed, 24 insertions(+), 58 deletions(-)
>
> diff --git a/migration-tcp.c b/migration-tcp.c
> index ecadd10..4f89bff 100644
> --- a/migration-tcp.c
> +++ b/migration-tcp.c
> @@ -81,43 +81,28 @@ static void tcp_wait_for_connect(void *opaque)
>
> int tcp_start_outgoing_migration(MigrationState *s, const char *host_port)
> {
> - struct sockaddr_in addr;
> int ret;
> -
> - ret = parse_host_port(&addr, host_port);
> - if (ret < 0) {
> - return ret;
> - }
> + int fd;
>
> s->get_error = socket_errno;
> s->write = socket_write;
> s->close = tcp_close;
>
> - s->fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> - if (s->fd == -1) {
> - DPRINTF("Unable to open socket");
> - return -socket_error();
> - }
> -
> - socket_set_nonblock(s->fd);
> -
> - do {
> - ret = connect(s->fd, (struct sockaddr *)&addr, sizeof(addr));
> - if (ret == -1) {
> - ret = -socket_error();
> - }
> - if (ret == -EINPROGRESS || ret == -EWOULDBLOCK) {
> - qemu_set_fd_handler2(s->fd, NULL, NULL, tcp_wait_for_connect, s);
> - return 0;
> - }
> - } while (ret == -EINTR);
> -
> - if (ret < 0) {
> + ret = tcp_client_start(host_port, &fd);
> + s->fd = fd;
you don't need fd you can pass s->fd to the function.
Orit
> + if (ret == -EINPROGRESS || ret == -EWOULDBLOCK) {
> + DPRINTF("connect in progress");
> + qemu_set_fd_handler2(s->fd, NULL, NULL, tcp_wait_for_connect, s);
> + } else if (ret < 0) {
> DPRINTF("connect failed\n");
> - migrate_fd_error(s);
> + if (ret != -EINVAL) {
> + migrate_fd_error(s);
> + }
> return ret;
> + } else {
> + migrate_fd_connect(s);
> }
> - migrate_fd_connect(s);
> +
> return 0;
> }
>
> diff --git a/net/socket.c b/net/socket.c
> index 5feb3d2..b7cd8ec 100644
> --- a/net/socket.c
> +++ b/net/socket.c
> @@ -434,41 +434,22 @@ static int net_socket_connect_init(VLANState *vlan,
> const char *host_str)
> {
> NetSocketState *s;
> - int fd, connected, ret, err;
> + int fd, connected, ret;
> struct sockaddr_in saddr;
>
> - if (parse_host_port(&saddr, host_str) < 0)
> - return -1;
> -
> - fd = qemu_socket(PF_INET, SOCK_STREAM, 0);
> - if (fd < 0) {
> - perror("socket");
> - return -1;
> - }
> - socket_set_nonblock(fd);
> -
> - connected = 0;
> - for(;;) {
> - ret = connect(fd, (struct sockaddr *)&saddr, sizeof(saddr));
> - if (ret < 0) {
> - err = socket_error();
> - if (err == EINTR || err == EWOULDBLOCK) {
> - } else if (err == EINPROGRESS) {
> - break;
> + ret = tcp_client_start(host_str, &fd);
> + if (ret == -EINPROGRESS || ret == -EWOULDBLOCK) {
> + connected = 0;
> #ifdef _WIN32
> - } else if (err == WSAEALREADY || err == WSAEINVAL) {
> - break;
> + } else if (ret == -WSAEALREADY || ret == -WSAEINVAL) {
> + connected = 0;
> #endif
> - } else {
> - perror("connect");
> - closesocket(fd);
> - return -1;
> - }
> - } else {
> - connected = 1;
> - break;
> - }
> + } else if (ret < 0) {
> + return -1;
> + } else {
> + connected = 1;
> }
> +
> s = net_socket_fd_init(vlan, model, name, fd, connected);
> if (!s)
> return -1;
>
>
next prev parent reply other threads:[~2012-03-05 13:39 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
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 [this message]
2012-03-05 13:39 ` 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=4F54C219.2060703@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.