mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-05 04:25:19 +00:00
virt-host-validate: check for IOMMU support
This looks for existance of DMAR (Intel) and IVRS (AMD) files under /sys/firmware/acpi/tables/, as a sign that the platform has IOMMU present & enabled in the BIOS. If these are present and /sys/kernel/iommu_groups does not contain any entries this is taken as a sign that the kernel has not enabled the IOMMU currently. If no ACPI tables are found we can't distinguish between disabled in BIOS and not present in the hardware, so we have to give the user a generic hint. Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
parent
179d92c848
commit
9139b46a6b
@ -29,6 +29,7 @@
|
|||||||
#ifdef HAVE_MNTENT_H
|
#ifdef HAVE_MNTENT_H
|
||||||
# include <mntent.h>
|
# include <mntent.h>
|
||||||
#endif /* HAVE_MNTENT_H */
|
#endif /* HAVE_MNTENT_H */
|
||||||
|
#include <sys/stat.h>
|
||||||
|
|
||||||
#include "virutil.h"
|
#include "virutil.h"
|
||||||
#include "viralloc.h"
|
#include "viralloc.h"
|
||||||
@ -354,3 +355,67 @@ int virHostValidateCGroupController(const char *hvname,
|
|||||||
return -1;
|
return -1;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int virHostValidateIOMMU(const char *hvname,
|
||||||
|
virHostValidateLevel level)
|
||||||
|
{
|
||||||
|
struct stat sb;
|
||||||
|
const char *bootarg = NULL;
|
||||||
|
bool isAMD = false, isIntel = false;
|
||||||
|
|
||||||
|
if (virHostValidateHasCPUFlag("vmx"))
|
||||||
|
isIntel = true;
|
||||||
|
else if (virHostValidateHasCPUFlag("svm"))
|
||||||
|
isAMD = true;
|
||||||
|
else
|
||||||
|
/* XXX PPC/ARM/etc support */
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
virHostMsgCheck(hvname, "%s", _("for device assignment IOMMU support"));
|
||||||
|
|
||||||
|
if (isIntel) {
|
||||||
|
if (access("/sys/firmware/acpi/tables/DMAR", F_OK) == 0) {
|
||||||
|
virHostMsgPass();
|
||||||
|
bootarg = "intel_iommu=on";
|
||||||
|
} else {
|
||||||
|
virHostMsgFail(level,
|
||||||
|
"No ACPI DMAR table found, IOMMU either "
|
||||||
|
"disabled in BIOS or not supported by this "
|
||||||
|
"hardware platform");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
} else if (isAMD) {
|
||||||
|
if (access("/sys/firmware/acpi/tables/IVRS", F_OK) == 0) {
|
||||||
|
virHostMsgPass();
|
||||||
|
bootarg = "iommu=pt iommu=1";
|
||||||
|
} else {
|
||||||
|
virHostMsgFail(level,
|
||||||
|
"No ACPI IVRS table found, IOMMU either "
|
||||||
|
"disabled in BIOS or not supported by this "
|
||||||
|
"hardware platform");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
virHostMsgFail(level,
|
||||||
|
"Unknown if this platform has IOMMU support");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* We can only check on newer kernels with iommu groups & vfio */
|
||||||
|
if (stat("/sys/kernel/iommu_groups", &sb) < 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
if (!S_ISDIR(sb.st_mode))
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
virHostMsgCheck(hvname, "%s", _("if IOMMU is enabled by kernel"));
|
||||||
|
if (sb.st_nlink <= 2) {
|
||||||
|
virHostMsgFail(level,
|
||||||
|
"IOMMU appears to be disabled in kernel. "
|
||||||
|
"Add %s to kernel cmdline arguments", bootarg);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
virHostMsgPass();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
@ -70,4 +70,7 @@ extern int virHostValidateCGroupController(const char *hvname,
|
|||||||
virHostValidateLevel level,
|
virHostValidateLevel level,
|
||||||
const char *config_name);
|
const char *config_name);
|
||||||
|
|
||||||
|
extern int virHostValidateIOMMU(const char *hvname,
|
||||||
|
virHostValidateLevel level);
|
||||||
|
|
||||||
#endif /* __VIRT_HOST_VALIDATE_COMMON_H__ */
|
#endif /* __VIRT_HOST_VALIDATE_COMMON_H__ */
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "virt-host-validate-qemu.h"
|
#include "virt-host-validate-qemu.h"
|
||||||
#include "virt-host-validate-common.h"
|
#include "virt-host-validate-common.h"
|
||||||
|
|
||||||
@ -87,5 +89,9 @@ int virHostValidateQEMU(void)
|
|||||||
"BLK_CGROUP") < 0)
|
"BLK_CGROUP") < 0)
|
||||||
ret = -1;
|
ret = -1;
|
||||||
|
|
||||||
|
if (virHostValidateIOMMU("QEMU",
|
||||||
|
VIR_HOST_VALIDATE_WARN) < 0)
|
||||||
|
ret = -1;
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user