mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-03 11:35:19 +00:00
rpc: socket: Minor cleanups
- Add some debugging - Make the loop dependent only on retries - Make it explicit that connect(2) success exits the loop - Invert the error checking logic
This commit is contained in:
parent
bc451c4980
commit
f102c7146e
@ -620,6 +620,9 @@ int virNetSocketNewConnectUNIX(const char *path,
|
|||||||
char *rundir = NULL;
|
char *rundir = NULL;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
|
|
||||||
|
VIR_DEBUG("path=%s spawnDaemon=%d binary=%s", path, spawnDaemon,
|
||||||
|
NULLSTR(binary));
|
||||||
|
|
||||||
memset(&localAddr, 0, sizeof(localAddr));
|
memset(&localAddr, 0, sizeof(localAddr));
|
||||||
memset(&remoteAddr, 0, sizeof(remoteAddr));
|
memset(&remoteAddr, 0, sizeof(remoteAddr));
|
||||||
|
|
||||||
@ -680,10 +683,15 @@ int virNetSocketNewConnectUNIX(const char *path,
|
|||||||
if (remoteAddr.data.un.sun_path[0] == '@')
|
if (remoteAddr.data.un.sun_path[0] == '@')
|
||||||
remoteAddr.data.un.sun_path[0] = '\0';
|
remoteAddr.data.un.sun_path[0] = '\0';
|
||||||
|
|
||||||
while (retries &&
|
while (retries) {
|
||||||
connect(fd, &remoteAddr.data.sa, remoteAddr.len) < 0) {
|
if (connect(fd, &remoteAddr.data.sa, remoteAddr.len) == 0) {
|
||||||
if (!(spawnDaemon && (errno == ENOENT ||
|
VIR_DEBUG("connect() succeeded");
|
||||||
errno == ECONNREFUSED))) {
|
break;
|
||||||
|
}
|
||||||
|
VIR_DEBUG("connect() failed: retries=%d errno=%d", retries, errno);
|
||||||
|
|
||||||
|
if (!spawnDaemon ||
|
||||||
|
(errno != ENOENT && errno != ECONNREFUSED)) {
|
||||||
virReportSystemError(errno, _("Failed to connect socket to '%s'"),
|
virReportSystemError(errno, _("Failed to connect socket to '%s'"),
|
||||||
path);
|
path);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
Loading…
Reference in New Issue
Block a user