qemu-sockets: add error propagation to inet_connect_addr
perror and fprintf can be removed because all clients can now consume Errors properly. However, we'll need to change the non-blocking connect handlers to take an Error, in order to improve error handling for migration with the TCP protocol. This is a minor degradation in error reporting for outgoing migration. However, until 1.2 this case just failed without even attempting to connect, so it is still an improvement as far as overall QoI is concerned. Reviewed-by: Luiz Capitulino <lcapitulino@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
a12fb8ad5b
commit
11663b553b
@ -216,7 +216,7 @@ typedef struct ConnectState {
|
|||||||
} ConnectState;
|
} ConnectState;
|
||||||
|
|
||||||
static int inet_connect_addr(struct addrinfo *addr, bool *in_progress,
|
static int inet_connect_addr(struct addrinfo *addr, bool *in_progress,
|
||||||
ConnectState *connect_state);
|
ConnectState *connect_state, Error **errp);
|
||||||
|
|
||||||
static void wait_for_connect(void *opaque)
|
static void wait_for_connect(void *opaque)
|
||||||
{
|
{
|
||||||
@ -246,7 +246,7 @@ static void wait_for_connect(void *opaque)
|
|||||||
if (s->current_addr) {
|
if (s->current_addr) {
|
||||||
while (s->current_addr->ai_next != NULL && s->fd < 0) {
|
while (s->current_addr->ai_next != NULL && s->fd < 0) {
|
||||||
s->current_addr = s->current_addr->ai_next;
|
s->current_addr = s->current_addr->ai_next;
|
||||||
s->fd = inet_connect_addr(s->current_addr, &in_progress, s);
|
s->fd = inet_connect_addr(s->current_addr, &in_progress, s, NULL);
|
||||||
/* connect in progress */
|
/* connect in progress */
|
||||||
if (in_progress) {
|
if (in_progress) {
|
||||||
return;
|
return;
|
||||||
@ -263,7 +263,7 @@ static void wait_for_connect(void *opaque)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static int inet_connect_addr(struct addrinfo *addr, bool *in_progress,
|
static int inet_connect_addr(struct addrinfo *addr, bool *in_progress,
|
||||||
ConnectState *connect_state)
|
ConnectState *connect_state, Error **errp)
|
||||||
{
|
{
|
||||||
int sock, rc;
|
int sock, rc;
|
||||||
|
|
||||||
@ -271,8 +271,7 @@ static int inet_connect_addr(struct addrinfo *addr, bool *in_progress,
|
|||||||
|
|
||||||
sock = qemu_socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
|
sock = qemu_socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
|
||||||
if (sock < 0) {
|
if (sock < 0) {
|
||||||
fprintf(stderr, "%s: socket(%s): %s\n", __func__,
|
error_set_errno(errp, errno, QERR_SOCKET_CREATE_FAILED);
|
||||||
inet_strfamily(addr->ai_family), strerror(errno));
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
qemu_setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on));
|
qemu_setsockopt(sock, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on));
|
||||||
@ -293,6 +292,7 @@ static int inet_connect_addr(struct addrinfo *addr, bool *in_progress,
|
|||||||
connect_state);
|
connect_state);
|
||||||
*in_progress = true;
|
*in_progress = true;
|
||||||
} else if (rc < 0) {
|
} else if (rc < 0) {
|
||||||
|
error_set_errno(errp, errno, QERR_SOCKET_CONNECT_FAILED);
|
||||||
closesocket(sock);
|
closesocket(sock);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -375,7 +375,7 @@ int inet_connect_opts(QemuOpts *opts, Error **errp,
|
|||||||
if (connect_state != NULL) {
|
if (connect_state != NULL) {
|
||||||
connect_state->current_addr = e;
|
connect_state->current_addr = e;
|
||||||
}
|
}
|
||||||
sock = inet_connect_addr(e, &in_progress, connect_state);
|
sock = inet_connect_addr(e, &in_progress, connect_state, errp);
|
||||||
if (in_progress) {
|
if (in_progress) {
|
||||||
return sock;
|
return sock;
|
||||||
} else if (sock >= 0) {
|
} else if (sock >= 0) {
|
||||||
@ -386,9 +386,6 @@ int inet_connect_opts(QemuOpts *opts, Error **errp,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (sock < 0) {
|
|
||||||
error_set(errp, QERR_SOCKET_CONNECT_FAILED);
|
|
||||||
}
|
|
||||||
g_free(connect_state);
|
g_free(connect_state);
|
||||||
freeaddrinfo(res);
|
freeaddrinfo(res);
|
||||||
return sock;
|
return sock;
|
||||||
|
Loading…
Reference in New Issue
Block a user