iommu/vt-d: Enable IOMMU perfmon support
authorKan Liang <kan.liang@linux.intel.com>
Tue, 31 Jan 2023 07:37:40 +0000 (15:37 +0800)
committerJoerg Roedel <jroedel@suse.de>
Fri, 3 Feb 2023 10:06:09 +0000 (11:06 +0100)
Register and enable an IOMMU perfmon for each active IOMMU device.

The failure of IOMMU perfmon registration doesn't impact other
functionalities of an IOMMU device.

Signed-off-by: Kan Liang <kan.liang@linux.intel.com>
Link: https://lore.kernel.org/r/20230128200428.1459118-8-kan.liang@linux.intel.com
Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/intel/dmar.c
drivers/iommu/intel/iommu.c

index 43db6eb..6acfe87 100644 (file)
@@ -1144,6 +1144,8 @@ static int alloc_iommu(struct dmar_drhd_unit *drhd)
                err = iommu_device_register(&iommu->iommu, &intel_iommu_ops, NULL);
                if (err)
                        goto err_sysfs;
+
+               iommu_pmu_register(iommu);
        }
 
        drhd->iommu = iommu;
@@ -1166,6 +1168,7 @@ error:
 static void free_iommu(struct intel_iommu *iommu)
 {
        if (intel_iommu_enabled && !iommu->drhd->ignored) {
+               iommu_pmu_unregister(iommu);
                iommu_device_unregister(&iommu->iommu);
                iommu_device_sysfs_remove(&iommu->iommu);
        }
index e314c30..691b306 100644 (file)
@@ -29,6 +29,7 @@
 #include "../iommu-sva.h"
 #include "pasid.h"
 #include "cap_audit.h"
+#include "perfmon.h"
 
 #define ROOT_SIZE              VTD_PAGE_SIZE
 #define CONTEXT_SIZE           VTD_PAGE_SIZE
@@ -4012,6 +4013,8 @@ int __init intel_iommu_init(void)
                                       intel_iommu_groups,
                                       "%s", iommu->name);
                iommu_device_register(&iommu->iommu, &intel_iommu_ops, NULL);
+
+               iommu_pmu_register(iommu);
        }
        up_read(&dmar_global_lock);