[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v3 3/9] net: introduce tcp_client_start()
From: |
Amos Kong |
Subject: |
[Qemu-devel] [PATCH v3 3/9] net: introduce tcp_client_start() |
Date: |
Wed, 07 Mar 2012 06:48:03 +0800 |
User-agent: |
StGit/0.15 |
Introduce tcp_client_start() by moving original code in
tcp_start_outgoing_migration().
Signed-off-by: Amos Kong <address@hidden>
---
net.c | 41 +++++++++++++++++++++++++++++++++++++++++
qemu_socket.h | 1 +
2 files changed, 42 insertions(+), 0 deletions(-)
diff --git a/net.c b/net.c
index e90ff23..9afb0d1 100644
--- a/net.c
+++ b/net.c
@@ -127,6 +127,47 @@ 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;
+
+ *fd = -1;
+ if (parse_host_port(&saddr, str) < 0) {
+ error_report("invalid host/port combination: %s", str);
+ 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 ret;
+ }
+ } 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);
- [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), (continued)
- [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Amos Kong, 2012/03/06
- Re: [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Orit Wasserman, 2012/03/14
- Re: [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Paolo Bonzini, 2012/03/14
- Re: [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Amos Kong, 2012/03/14
- Re: [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Paolo Bonzini, 2012/03/14
- Re: [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Orit Wasserman, 2012/03/14
- Re: [Qemu-devel] [PATCH v3 1/9] net: introduce tcp_server_start(), Kevin Wolf, 2012/03/14
[Qemu-devel] [PATCH v3 3/9] net: introduce tcp_client_start(),
Amos Kong <=
Re: [Qemu-devel] [PATCH v3 3/9] net: introduce tcp_client_start(), Orit Wasserman, 2012/03/14
[Qemu-devel] [PATCH v3 4/9] net: use tcp_client_start for tcp client creation, Amos Kong, 2012/03/06
[Qemu-devel] [PATCH v3 6/9] net: use getaddrinfo() in tcp_start_common, Amos Kong, 2012/03/06
[Qemu-devel] [PATCH v3 7/9] net: introduce parse_host_port_info(), Amos Kong, 2012/03/06
[Qemu-devel] [PATCH v3 5/9] net: refector tcp_*_start functions, Amos Kong, 2012/03/06
[Qemu-devel] [PATCH v3 8/9] net: split hostname and service by last colon, Amos Kong, 2012/03/06