mirror of https://gitee.com/openkylin/libvirt.git
util: change virFile*Pid functions to return < 0 on failure
Although most functions in libvirt return 0 on success and < 0 on failure, there are a few functions lingering around that return errno (a positive value) on failure, and sometimes code calling those functions incorrectly assumes the <0 standard. I noticed one of these the other day when auditing networkStartDhcpDaemon after Guido Gunther found a place where success was improperly returned on failure (that patch has been acked and is pending a push). The problem was that it expected the return value from virFileReadPid to be < 0 on failure, but it was actually positive (it was also neglected to set the return code in this case, similar to the bug found by Guido). This all led to the fact that *all* of the virFile*Pid functions in util.c are returning errno on failure. This patch remedies that problem by changing them all to return -errno on failure, and makes any necessary changes to callers of the functions. (In the meantime, I also properly set the return code on failure of virFileReadPid in networkStartDhcpDaemon).
This commit is contained in:
parent
85a954cebb
commit
d6354c1696
|
@ -947,8 +947,8 @@ int main(int argc, char *argv[])
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
if (pid > 0) {
|
if (pid > 0) {
|
||||||
if ((rc = virFileWritePid(LXC_STATE_DIR, name, pid)) != 0) {
|
if ((rc = virFileWritePid(LXC_STATE_DIR, name, pid)) < 0) {
|
||||||
virReportSystemError(rc,
|
virReportSystemError(-rc,
|
||||||
_("Unable to write pid file '%s/%s.pid'"),
|
_("Unable to write pid file '%s/%s.pid'"),
|
||||||
LXC_STATE_DIR, name);
|
LXC_STATE_DIR, name);
|
||||||
_exit(1);
|
_exit(1);
|
||||||
|
@ -996,5 +996,5 @@ cleanup:
|
||||||
unlink(sockpath);
|
unlink(sockpath);
|
||||||
VIR_FREE(sockpath);
|
VIR_FREE(sockpath);
|
||||||
|
|
||||||
return rc;
|
return rc ? EXIT_FAILURE : EXIT_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1612,8 +1612,8 @@ static int lxcVmStart(virConnectPtr conn,
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
/* And get its pid */
|
/* And get its pid */
|
||||||
if ((r = virFileReadPid(driver->stateDir, vm->def->name, &vm->pid)) != 0) {
|
if ((r = virFileReadPid(driver->stateDir, vm->def->name, &vm->pid)) < 0) {
|
||||||
virReportSystemError(r,
|
virReportSystemError(-r,
|
||||||
_("Failed to read pid file %s/%s.pid"),
|
_("Failed to read pid file %s/%s.pid"),
|
||||||
driver->stateDir, vm->def->name);
|
driver->stateDir, vm->def->name);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
|
@ -758,8 +758,9 @@ networkStartDhcpDaemon(virNetworkObjPtr network)
|
||||||
* pid
|
* pid
|
||||||
*/
|
*/
|
||||||
|
|
||||||
if (virFileReadPid(NETWORK_PID_DIR, network->def->name,
|
ret = virFileReadPid(NETWORK_PID_DIR, network->def->name,
|
||||||
&network->dnsmasqPid) < 0)
|
&network->dnsmasqPid);
|
||||||
|
if (ret < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
|
@ -2754,7 +2754,7 @@ int qemuProcessStart(virConnectPtr conn,
|
||||||
|
|
||||||
/* wait for qemu process to show up */
|
/* wait for qemu process to show up */
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
if (virFileReadPidPath(priv->pidfile, &vm->pid)) {
|
if (virFileReadPidPath(priv->pidfile, &vm->pid) < 0) {
|
||||||
qemuReportError(VIR_ERR_INTERNAL_ERROR,
|
qemuReportError(VIR_ERR_INTERNAL_ERROR,
|
||||||
_("Domain %s didn't show up"), vm->def->name);
|
_("Domain %s didn't show up"), vm->def->name);
|
||||||
ret = -1;
|
ret = -1;
|
||||||
|
|
|
@ -493,7 +493,7 @@ virExecWithHook(const char *const*argv,
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pid > 0) {
|
if (pid > 0) {
|
||||||
if (pidfile && virFileWritePidPath(pidfile,pid)) {
|
if (pidfile && (virFileWritePidPath(pidfile,pid) < 0)) {
|
||||||
kill(pid, SIGTERM);
|
kill(pid, SIGTERM);
|
||||||
usleep(500*1000);
|
usleep(500*1000);
|
||||||
kill(pid, SIGTERM);
|
kill(pid, SIGTERM);
|
||||||
|
|
|
@ -1165,17 +1165,17 @@ int virFileWritePid(const char *dir,
|
||||||
char *pidfile = NULL;
|
char *pidfile = NULL;
|
||||||
|
|
||||||
if (name == NULL || dir == NULL) {
|
if (name == NULL || dir == NULL) {
|
||||||
rc = EINVAL;
|
rc = -EINVAL;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virFileMakePath(dir) < 0) {
|
if (virFileMakePath(dir) < 0) {
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(pidfile = virFilePid(dir, name))) {
|
if (!(pidfile = virFilePid(dir, name))) {
|
||||||
rc = ENOMEM;
|
rc = -ENOMEM;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1196,18 +1196,18 @@ int virFileWritePidPath(const char *pidfile,
|
||||||
if ((fd = open(pidfile,
|
if ((fd = open(pidfile,
|
||||||
O_WRONLY | O_CREAT | O_TRUNC,
|
O_WRONLY | O_CREAT | O_TRUNC,
|
||||||
S_IRUSR | S_IWUSR)) < 0) {
|
S_IRUSR | S_IWUSR)) < 0) {
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(file = VIR_FDOPEN(fd, "w"))) {
|
if (!(file = VIR_FDOPEN(fd, "w"))) {
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
VIR_FORCE_CLOSE(fd);
|
VIR_FORCE_CLOSE(fd);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fprintf(file, "%d", pid) < 0) {
|
if (fprintf(file, "%d", pid) < 0) {
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1215,7 +1215,7 @@ int virFileWritePidPath(const char *pidfile,
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
if (VIR_FCLOSE(file) < 0)
|
if (VIR_FCLOSE(file) < 0)
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
@ -1230,18 +1230,18 @@ int virFileReadPidPath(const char *path,
|
||||||
*pid = 0;
|
*pid = 0;
|
||||||
|
|
||||||
if (!(file = fopen(path, "r"))) {
|
if (!(file = fopen(path, "r"))) {
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fscanf(file, "%d", pid) != 1) {
|
if (fscanf(file, "%d", pid) != 1) {
|
||||||
rc = EINVAL;
|
rc = -EINVAL;
|
||||||
VIR_FORCE_FCLOSE(file);
|
VIR_FORCE_FCLOSE(file);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (VIR_FCLOSE(file) < 0) {
|
if (VIR_FCLOSE(file) < 0) {
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1261,12 +1261,12 @@ int virFileReadPid(const char *dir,
|
||||||
*pid = 0;
|
*pid = 0;
|
||||||
|
|
||||||
if (name == NULL || dir == NULL) {
|
if (name == NULL || dir == NULL) {
|
||||||
rc = EINVAL;
|
rc = -EINVAL;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(pidfile = virFilePid(dir, name))) {
|
if (!(pidfile = virFilePid(dir, name))) {
|
||||||
rc = ENOMEM;
|
rc = -ENOMEM;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1284,17 +1284,17 @@ int virFileDeletePid(const char *dir,
|
||||||
char *pidfile = NULL;
|
char *pidfile = NULL;
|
||||||
|
|
||||||
if (name == NULL || dir == NULL) {
|
if (name == NULL || dir == NULL) {
|
||||||
rc = EINVAL;
|
rc = -EINVAL;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(pidfile = virFilePid(dir, name))) {
|
if (!(pidfile = virFilePid(dir, name))) {
|
||||||
rc = ENOMEM;
|
rc = -ENOMEM;
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (unlink(pidfile) < 0 && errno != ENOENT)
|
if (unlink(pidfile) < 0 && errno != ENOENT)
|
||||||
rc = errno;
|
rc = -errno;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
VIR_FREE(pidfile);
|
VIR_FREE(pidfile);
|
||||||
|
|
|
@ -230,7 +230,7 @@ static int test4(const void *unused ATTRIBUTE_UNUSED)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virFileReadPid(abs_builddir, "commandhelper", &pid) != 0) {
|
if (virFileReadPid(abs_builddir, "commandhelper", &pid) < 0) {
|
||||||
printf("cannot read pidfile\n");
|
printf("cannot read pidfile\n");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
@ -686,7 +686,7 @@ static int test18(const void *unused ATTRIBUTE_UNUSED)
|
||||||
}
|
}
|
||||||
alarm(0);
|
alarm(0);
|
||||||
|
|
||||||
if (virFileReadPid(abs_builddir, "commandhelper", &pid) != 0) {
|
if (virFileReadPid(abs_builddir, "commandhelper", &pid) < 0) {
|
||||||
printf("cannot read pidfile\n");
|
printf("cannot read pidfile\n");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue