mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-02-22 11:22:23 +00:00
Fix failure to detect missing cgroup partitions
Change bbe97ae968eba60b71e0066d49f9fc909966d9d6 caused the QEMU driver to ignore ENOENT errors from cgroups, in order to cope with missing /proc/cgroups. This is not good though because many other things can cause ENOENT and should not be ignored. The callers expect to see ENXIO when cgroups are not present, so adjust the code to report that errno when /proc/cgroups is missing Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
parent
7bebd88871
commit
c2cf5f1c2a
@ -456,8 +456,7 @@ int qemuInitCgroup(virQEMUDriverPtr driver,
|
||||
if (rc != 0) {
|
||||
if (rc == -ENXIO ||
|
||||
rc == -EPERM ||
|
||||
rc == -EACCES ||
|
||||
rc == -ENOENT) { /* No cgroups mounts == success */
|
||||
rc == -EACCES) { /* No cgroups mounts == success */
|
||||
VIR_DEBUG("No cgroups present/configured/accessible, ignoring error");
|
||||
goto done;
|
||||
}
|
||||
|
@ -1110,8 +1110,13 @@ static int virCgroupPartitionNeedsEscaping(const char *path)
|
||||
path[0] == '.')
|
||||
return 1;
|
||||
|
||||
if (!(fp = fopen("/proc/cgroups", "r")))
|
||||
if (!(fp = fopen("/proc/cgroups", "r"))) {
|
||||
/* The API contract is that we return ENXIO
|
||||
* if cgroups are not available on a host */
|
||||
if (errno == ENOENT)
|
||||
errno = ENXIO;
|
||||
return -errno;
|
||||
}
|
||||
|
||||
/*
|
||||
* Data looks like this:
|
||||
|
Loading…
x
Reference in New Issue
Block a user