mirror of
https://github.com/qemu/qemu.git
synced 2024-12-12 05:03:42 +08:00
233aa5c2d1
getaddrinfo can give us a list of addresses, but we only try to connect to the first one. If that fails we never proceed to the next one. This is common on desktop setups that often have ipv6 configured but not actually working. To fix this make inet_connect_nonblocking retry connection with a different address. callers on inet_nonblocking_connect register a callback function that will be called when connect opertion completes, in case of failure the fd will have a negative value Signed-off-by: Orit Wasserman <owasserm@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
69 lines
1.9 KiB
C
69 lines
1.9 KiB
C
/* headers to use the BSD sockets */
|
|
#ifndef QEMU_SOCKET_H
|
|
#define QEMU_SOCKET_H
|
|
|
|
#ifdef _WIN32
|
|
#include <windows.h>
|
|
#include <winsock2.h>
|
|
#include <ws2tcpip.h>
|
|
|
|
#define socket_error() WSAGetLastError()
|
|
|
|
int inet_aton(const char *cp, struct in_addr *ia);
|
|
|
|
#else
|
|
|
|
#include <sys/types.h>
|
|
#include <sys/socket.h>
|
|
#include <netinet/in.h>
|
|
#include <netinet/tcp.h>
|
|
#include <arpa/inet.h>
|
|
#include <netdb.h>
|
|
#include <sys/un.h>
|
|
|
|
#define socket_error() errno
|
|
#define closesocket(s) close(s)
|
|
|
|
#endif /* !_WIN32 */
|
|
|
|
#include "qemu-option.h"
|
|
#include "error.h"
|
|
#include "qerror.h"
|
|
|
|
/* misc helpers */
|
|
int qemu_socket(int domain, int type, int protocol);
|
|
int qemu_accept(int s, struct sockaddr *addr, socklen_t *addrlen);
|
|
int socket_set_cork(int fd, int v);
|
|
void socket_set_block(int fd);
|
|
void socket_set_nonblock(int fd);
|
|
int send_all(int fd, const void *buf, int len1);
|
|
|
|
/* callback function for nonblocking connect
|
|
* valid fd on success, negative error code on failure
|
|
*/
|
|
typedef void NonBlockingConnectHandler(int fd, void *opaque);
|
|
|
|
int inet_listen_opts(QemuOpts *opts, int port_offset, Error **errp);
|
|
int inet_listen(const char *str, char *ostr, int olen,
|
|
int socktype, int port_offset, Error **errp);
|
|
int inet_connect_opts(QemuOpts *opts, Error **errp,
|
|
NonBlockingConnectHandler *callback, void *opaque);
|
|
int inet_connect(const char *str, Error **errp);
|
|
int inet_nonblocking_connect(const char *str,
|
|
NonBlockingConnectHandler *callback,
|
|
void *opaque, Error **errp);
|
|
|
|
int inet_dgram_opts(QemuOpts *opts);
|
|
const char *inet_strfamily(int family);
|
|
|
|
int unix_listen_opts(QemuOpts *opts);
|
|
int unix_listen(const char *path, char *ostr, int olen);
|
|
int unix_connect_opts(QemuOpts *opts);
|
|
int unix_connect(const char *path);
|
|
|
|
/* 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);
|
|
|
|
#endif /* QEMU_SOCKET_H */
|