mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-03-20 06:50:22 +03:00
qemu: process: split out shmem startup warning
Now we can return early and save some indentation
This commit is contained in:
parent
a02a859be4
commit
55079d6998
@ -4497,6 +4497,56 @@ qemuProcessMakeDir(virQEMUDriverPtr driver,
|
||||
}
|
||||
|
||||
|
||||
static void
|
||||
qemuProcessStartWarnShmem(virDomainObjPtr vm)
|
||||
{
|
||||
size_t i;
|
||||
bool check_shmem = false;
|
||||
bool shmem = vm->def->nshmems;
|
||||
|
||||
/*
|
||||
* For vhost-user to work, the domain has to have some type of
|
||||
* shared memory configured. We're not the proper ones to judge
|
||||
* whether shared hugepages or shm are enough and will be in the
|
||||
* future, so we'll just warn in case neither is configured.
|
||||
* Moreover failing would give the false illusion that libvirt is
|
||||
* really checking that everything works before running the domain
|
||||
* and not only we are unable to do that, but it's also not our
|
||||
* aim to do so.
|
||||
*/
|
||||
for (i = 0; i < vm->def->nnets; i++) {
|
||||
if (virDomainNetGetActualType(vm->def->nets[i]) ==
|
||||
VIR_DOMAIN_NET_TYPE_VHOSTUSER) {
|
||||
check_shmem = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (!check_shmem)
|
||||
return;
|
||||
|
||||
/*
|
||||
* This check is by no means complete. We merely check
|
||||
* whether there are *some* hugepages enabled and *some* NUMA
|
||||
* nodes with shared memory access.
|
||||
*/
|
||||
if (!shmem && vm->def->mem.nhugepages) {
|
||||
for (i = 0; i < virDomainNumaGetNodeCount(vm->def->numa); i++) {
|
||||
if (virDomainNumaGetNodeMemoryAccessMode(vm->def->numa, i) ==
|
||||
VIR_NUMA_MEM_ACCESS_SHARED) {
|
||||
shmem = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!shmem) {
|
||||
VIR_WARN("Detected vhost-user interface without any shared memory, "
|
||||
"the interface might not be operational");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* qemuProcessStartValidate:
|
||||
* @vm: domain object
|
||||
@ -4517,9 +4567,6 @@ qemuProcessStartValidate(virQEMUDriverPtr driver,
|
||||
bool snapshot,
|
||||
unsigned int flags)
|
||||
{
|
||||
bool check_shmem = false;
|
||||
size_t i;
|
||||
|
||||
if (!(flags & VIR_QEMU_PROCESS_START_PRETEND)) {
|
||||
if (vm->def->virtType == VIR_DOMAIN_VIRT_KVM) {
|
||||
VIR_DEBUG("Checking for KVM availability");
|
||||
@ -4559,47 +4606,7 @@ qemuProcessStartValidate(virQEMUDriverPtr driver,
|
||||
|
||||
VIR_DEBUG("Checking for any possible (non-fatal) issues");
|
||||
|
||||
/*
|
||||
* For vhost-user to work, the domain has to have some type of
|
||||
* shared memory configured. We're not the proper ones to judge
|
||||
* whether shared hugepages or shm are enough and will be in the
|
||||
* future, so we'll just warn in case neither is configured.
|
||||
* Moreover failing would give the false illusion that libvirt is
|
||||
* really checking that everything works before running the domain
|
||||
* and not only we are unable to do that, but it's also not our
|
||||
* aim to do so.
|
||||
*/
|
||||
for (i = 0; i < vm->def->nnets; i++) {
|
||||
if (virDomainNetGetActualType(vm->def->nets[i]) ==
|
||||
VIR_DOMAIN_NET_TYPE_VHOSTUSER) {
|
||||
check_shmem = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (check_shmem) {
|
||||
bool shmem = vm->def->nshmems;
|
||||
|
||||
/*
|
||||
* This check is by no means complete. We merely check
|
||||
* whether there are *some* hugepages enabled and *some* NUMA
|
||||
* nodes with shared memory access.
|
||||
*/
|
||||
if (!shmem && vm->def->mem.nhugepages) {
|
||||
for (i = 0; i < virDomainNumaGetNodeCount(vm->def->numa); i++) {
|
||||
if (virDomainNumaGetNodeMemoryAccessMode(vm->def->numa, i) ==
|
||||
VIR_NUMA_MEM_ACCESS_SHARED) {
|
||||
shmem = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!shmem) {
|
||||
VIR_WARN("Detected vhost-user interface without any shared memory, "
|
||||
"the interface might not be operational");
|
||||
}
|
||||
}
|
||||
qemuProcessStartWarnShmem(vm);
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user