lists.openwall.net | lists / announce owl-users owl-dev john-users john-dev passwdqc-users yescrypt popa3d-users / oss-security kernel-hardening musl sabotage tlsify passwords / crypt-dev xvendor / Bugtraq Full-Disclosure linux-kernel linux-netdev linux-ext4 linux-hardening linux-cve-announce PHC | |
Open Source and information security mailing list archives
| ||
|
Message-ID: <723f8070-1f03-dcab-4592-bceaf9cbdf07@linux.intel.com> Date: Sat, 28 Jan 2023 15:10:09 +0800 From: Baolu Lu <baolu.lu@...ux.intel.com> To: kan.liang@...ux.intel.com, joro@...tes.org, will@...nel.org, dwmw2@...radead.org, robin.murphy@....com, robert.moore@...el.com, rafael.j.wysocki@...el.com, lenb@...nel.org, iommu@...ts.linux.dev, linux-kernel@...r.kernel.org Cc: baolu.lu@...ux.intel.com, yu-cheng.yu@...el.com Subject: Re: [PATCH V3 0/7] iommu/vt-d: Support performance monitoring for IOMMU On 2023/1/21 0:54, kan.liang@...ux.intel.com wrote: > From: Kan Liang <kan.liang@...ux.intel.com> > > Changes since V2: > - Move ecmd_submit_sync() to iommu.c to avoid #ifdef CONFIG_INTEL_IOMMU > > Changes since V1: > - The cap and ecap registers are always in the first page. It's not > necessary to use the reg size in dmar_validate_one_drhd(). (Patch 1) > - Move reg_size up and pair it with reg_base_addr in struct > dmar_drhd_unit (Patch 1) > - Update the year of Copyright (Patch 2) > - Return 0 if PMS is not supported (Patch 2) > - Refine the comments and add a pr_warn for per-counter capabilities > check (Patch 2) > - Remove unnecessary iommu_pmu->num_cntr = i (Patch 2) > - Remove has_ob of ecmd_submit_sync() (Patch 3) > - Remove the helpers from non-INTEL_IOMMU. (Patch 3) > - Still keep #ifdef CONFIG_INTEL_IOMMU for ecmd_submit_sync() to > avoid compile warning with non-INTEL_IOMMU config. > - Use pr_warn_once() to replace WARN_ONCE() (Patch 4 & 6) > - Free iommu PMU if it fails to be registered. (Patch 4) > - Remove unnecessary 'handled' variable. (Patch 6) > > A performance monitoring infrastructure, perfmon, is introduced with > the VT-d Spec 4.0. The purpose of perfmon is to support collection of > information about key events occurring during operation of the remapping > hardware, to aid performance tuning and debug. The patch series is to > support the perfmon for IOMMU. > > To facilitate the perfmon support, the patch series also supports two > new generic features of VT-d Spec 4.0. > - Support the 'size' field to retrieve the accurate size of the register > set for each dmar device from DRHD. (Patch 1) > - Support the new Enhanced Command Interface. (Patch 3) > > With the patch series, users can collect the performance data of IOMMU > via Linux perf tool. For example, > > $ perf stat -e dmar0/iommu_requests,filter_ats=0/ -a sleep 1 > > Performance counter stats for 'system wide': > > 2135 dmar0/iommu_requests,filter_ats=0/ > > 1.001087695 seconds time elapsed > > The IOMMU PMUs can be found under /sys/bus/event_source/devices/dmar* > > The available filters and event format can be found at the format folder > $ ls /sys/bus/event_source/devices/dmar0/format/ > event event_group filter_ats filter_page_table > > The supported events can be found at the events folder > > $ ls /sys/bus/event_source/devices/dmar0/events/ > ats_blocked int_cache_hit_nonposted iommu_mrds > pasid_cache_lookup > ctxt_cache_hit int_cache_hit_posted iommu_requests > pg_req_posted > ctxt_cache_lookup int_cache_lookup iotlb_hit > pw_occupancy > fs_nonleaf_hit iommu_clocks iotlb_lookup > ss_nonleaf_hit > fs_nonleaf_lookup iommu_mem_blocked pasid_cache_hit > ss_nonleaf_lookup > > Kan Liang (7): > iommu/vt-d: Support size of the register set in DRHD > iommu/vt-d: Retrieve IOMMU perfmon capability information > iommu/vt-d: Support Enhanced Command Interface > iommu/vt-d: Add IOMMU perfmon support > iommu/vt-d: Support cpumask for IOMMU perfmon > iommu/vt-d: Add IOMMU perfmon overflow handler support > iommu/vt-d: Enable IOMMU perfmon support > > .../sysfs-bus-event_source-devices-iommu | 32 + > drivers/iommu/intel/Kconfig | 9 + > drivers/iommu/intel/Makefile | 1 + > drivers/iommu/intel/dmar.c | 33 +- > drivers/iommu/intel/iommu.c | 59 ++ > drivers/iommu/intel/iommu.h | 101 +- > drivers/iommu/intel/perfmon.c | 860 ++++++++++++++++++ > drivers/iommu/intel/perfmon.h | 65 ++ > drivers/iommu/intel/svm.c | 2 +- > include/acpi/actbl1.h | 2 +- > include/linux/cpuhotplug.h | 1 + > include/linux/dmar.h | 1 + > 12 files changed, 1159 insertions(+), 7 deletions(-) > create mode 100644 Documentation/ABI/testing/sysfs-bus-event_source-devices-iommu > create mode 100644 drivers/iommu/intel/perfmon.c > create mode 100644 drivers/iommu/intel/perfmon.h Thanks for the work. The overall looks good to me now. But I am still seeing some code style issues after running "./scripts/checkpatch.pl --strict" scripts. Can you please fix those issues and post a v4? Best regards, baolu
Powered by blists - more mailing lists