]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
iommu/vt-d: Remove debugfs use of private data field
authorJingqi Liu <Jingqi.liu@intel.com>
Wed, 24 Apr 2024 07:16:30 +0000 (15:16 +0800)
committerJoerg Roedel <jroedel@suse.de>
Fri, 26 Apr 2024 09:57:38 +0000 (11:57 +0200)
Since the page fault report and response have been tracked by ftrace, the
users can easily calculate the time used for a page fault handling. There's
no need to expose the similar functionality in debugfs. Hence, remove the
corresponding operations in debugfs.

Signed-off-by: Jingqi Liu <Jingqi.liu@intel.com>
Link: https://lore.kernel.org/r/20240308103811.76744-2-Jingqi.liu@intel.com
Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>
Signed-off-by: Joerg Roedel <jroedel@suse.de>
drivers/iommu/intel/debugfs.c
drivers/iommu/intel/perf.h
drivers/iommu/intel/svm.c

index 86b506af7daa1418e70fb87bded66181248a1ec4..affbf4a1558dee4404805bb7e7ad2c57ef0bab2b 100644 (file)
@@ -706,7 +706,6 @@ static ssize_t dmar_perf_latency_write(struct file *filp,
                        dmar_latency_disable(iommu, DMAR_LATENCY_INV_IOTLB);
                        dmar_latency_disable(iommu, DMAR_LATENCY_INV_DEVTLB);
                        dmar_latency_disable(iommu, DMAR_LATENCY_INV_IEC);
-                       dmar_latency_disable(iommu, DMAR_LATENCY_PRQ);
                }
                rcu_read_unlock();
                break;
@@ -728,12 +727,6 @@ static ssize_t dmar_perf_latency_write(struct file *filp,
                        dmar_latency_enable(iommu, DMAR_LATENCY_INV_IEC);
                rcu_read_unlock();
                break;
-       case 4:
-               rcu_read_lock();
-               for_each_active_iommu(iommu, drhd)
-                       dmar_latency_enable(iommu, DMAR_LATENCY_PRQ);
-               rcu_read_unlock();
-               break;
        default:
                return -EINVAL;
        }
index fd6db8049d1a773fa3c1dd9482f9b9a64b12061f..df9a36942d643562575888285a2ec6f6a9237f94 100644 (file)
@@ -11,7 +11,6 @@ enum latency_type {
        DMAR_LATENCY_INV_IOTLB = 0,
        DMAR_LATENCY_INV_DEVTLB,
        DMAR_LATENCY_INV_IEC,
-       DMAR_LATENCY_PRQ,
        DMAR_LATENCY_NUM
 };
 
index ee3b469e2da1551889ba0e200f386e010bc6f68f..e014350db3545e863fb5dbfb9f706470e57bbf71 100644 (file)
@@ -583,12 +583,6 @@ static void intel_svm_prq_report(struct intel_iommu *iommu, struct device *dev,
                event.fault.prm.flags |= IOMMU_FAULT_PAGE_REQUEST_PRIV_DATA;
                event.fault.prm.private_data[0] = desc->priv_data[0];
                event.fault.prm.private_data[1] = desc->priv_data[1];
-       } else if (dmar_latency_enabled(iommu, DMAR_LATENCY_PRQ)) {
-               /*
-                * If the private data fields are not used by hardware, use it
-                * to monitor the prq handle latency.
-                */
-               event.fault.prm.private_data[0] = ktime_to_ns(ktime_get());
        }
 
        iommu_report_device_fault(dev, &event);
@@ -768,9 +762,6 @@ void intel_svm_page_response(struct device *dev, struct iopf_fault *evt,
                if (private_present) {
                        desc.qw2 = prm->private_data[0];
                        desc.qw3 = prm->private_data[1];
-               } else if (prm->private_data[0]) {
-                       dmar_latency_update(iommu, DMAR_LATENCY_PRQ,
-                               ktime_to_ns(ktime_get()) - prm->private_data[0]);
                }
 
                qi_submit_sync(iommu, &desc, 1, 0);