POWER hosts does not implement CPU virtualization extensions like
x86 or s390x. Instead, all bare-metal POWER hosts are considered
to be virtualization ready.
For POWER, the validation is done by checking if the virtualization
module kvm_hv is loaded in the host. If not, we should warn the
user about it.
Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
virHostMsgPass();
return 0;
}
+
+
+bool virHostKernelModuleIsLoaded(const char *module)
+{
+ FILE *fp;
+ bool ret = false;
+
+ if (!(fp = fopen("/proc/modules", "r")))
+ return false;
+
+ do {
+ char line[1024];
+
+ if (!fgets(line, sizeof(line), fp))
+ break;
+
+ if (STRPREFIX(line, module)) {
+ ret = true;
+ break;
+ }
+
+ } while (1);
+
+ VIR_FORCE_FCLOSE(fp);
+
+ return ret;
+}
int virHostValidateIOMMU(const char *hvname,
virHostValidateLevel level);
+
+bool virHostKernelModuleIsLoaded(const char *module);
if (virBitmapIsBitSet(flags, VIR_HOST_VALIDATE_CPU_FLAG_SIE))
hasHwVirt = true;
break;
+ case VIR_ARCH_PPC64:
+ case VIR_ARCH_PPC64LE:
+ hasVirtFlag = true;
+ hasHwVirt = true;
+ break;
default:
hasHwVirt = false;
}
ret = -1;
}
+ if (arch == VIR_ARCH_PPC64 || arch == VIR_ARCH_PPC64LE) {
+ virHostMsgCheck("QEMU", "%s", _("for PowerPC KVM module loaded"));
+
+ if (!virHostKernelModuleIsLoaded("kvm_hv"))
+ virHostMsgFail(VIR_HOST_VALIDATE_WARN,
+ _("Load kvm_hv for better performance"));
+ else
+ virHostMsgPass();
+ }
+
virBitmapFree(flags);
if (virHostValidateDeviceExists("QEMU", "/dev/vhost-net",