[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250114134158.GC5556@nvidia.com>
Date: Tue, 14 Jan 2025 09:41:58 -0400
From: Jason Gunthorpe <jgg@...dia.com>
To: Nicolin Chen <nicolinc@...dia.com>
Cc: kevin.tian@...el.com, corbet@....net, will@...nel.org, joro@...tes.org,
suravee.suthikulpanit@....com, robin.murphy@....com,
dwmw2@...radead.org, baolu.lu@...ux.intel.com, shuah@...nel.org,
linux-kernel@...r.kernel.org, iommu@...ts.linux.dev,
linux-arm-kernel@...ts.infradead.org,
linux-kselftest@...r.kernel.org, linux-doc@...r.kernel.org,
eric.auger@...hat.com, jean-philippe@...aro.org, mdf@...nel.org,
mshavit@...gle.com, shameerali.kolothum.thodi@...wei.com,
smostafa@...gle.com, ddutile@...hat.com, yi.l.liu@...el.com,
patches@...ts.linux.dev
Subject: Re: [PATCH v5 08/14] iommufd/viommu: Add iommufd_viommu_report_event
helper
On Mon, Jan 13, 2025 at 12:44:37PM -0800, Nicolin Chen wrote:
> > You'd want to push a special event when the first overflow happens and
> > probably also report a counter so userspace can know how many events
> > got lost.
>
> How about this:
>
> enum iommufd_veventq_header_type {
> IOMMU_VEVENTQ_HEADER_TYPE_V1,
> };
You don't need another format tag, just describe it in the driver tag.
> enum iommu_hwpt_pgfault_flags {
> IOMMU_VEVENT_HEADER_FLAGS_OVERFLOW = (1 << 0),
> };
>
> struct iommufd_vevent_header_v1 {
> __u64 flags;
> __u32 num_events;
> __u32 num_overflows; // valid if flag_overflow is set
> };
num_overflows is hard, I'd just keep a counter.
> > This seems most robust and simplest to implement..
> >
> > I think I'd implement it by having a static overflow list entry so no
> > memory allocation is needed and just keep moving that entry to the
> > back of the list every time an event is lost. This way it will cover
> > lost events due to memory outages too
>
> Could double-adding the same static node to the list happen and
> corrupt the list?
It has to be done carefully, but under a lock you can make this work
> > For old formats like the fault queue you could return EOVERFLOW
> > whenever the sequence number becomes discontiguous or it sees the
> > overflow event..
>
> So, IOMMU_OBJ_FAULT is safe to return EOVERFLOW via read(), as
> you mentioned that it is self-limited right?
The idea for fault is that we wouldn't hit it, but if we add a limit,
or hit a memory allocation error, then it could happen
Jason
Powered by blists - more mailing lists