On Wed, Nov 29, 2023 at 08:08:16PM -0400, Jason Gunthorpe wrote:
On Wed, Nov 29, 2023 at 02:07:58PM -0800, Nicolin Chen wrote:
On Wed, Nov 29, 2023 at 03:58:04PM -0400, Jason Gunthorpe wrote:
On Tue, Nov 28, 2023 at 05:09:07PM -0800, Nicolin Chen wrote:
With that being said, I think errno (-EIO) could do the job, as you suggested too.
Do we have any idea what HW failures can be generated by the commands this will execture? IIRC I don't remember seeing any smmu specific codes related to invalid invalidation? Everything is a valid input?
"7.1 Command queue errors" has the info.
Hmm CERROR_ATC_INV_SYNC needs to be forwarded to the guest somehow
Oh, for sure. That's typically triggered with an asynchronous timeout from the eventq, so we'd need the io page fault series as you previously remarked. Though I also wonder if an invalid vSID that doesn't link to a pSID should be CERROR_ATC_INV_SYNC also v.s. CERROR_ILL.
Yes, something like that make sense
Presumably sync becomes emulated and turns into something generated when the ioctl returns.
CMD_SYNC right? Yes. When the ioctl returns, VMM simply moves the CONS index next to CMD_SYNC upon a success, or stops the index at the faulty command upon a failure.
So userspace would have to read the event FD before returning to be correct?
Maybe the kernel can somehow return a flag to indicate the event fd has data in it?
If yes then all errors would flow through the event fd?
I think it'd be nicer to return an immediate error to stop guest CMDQ to raise a fault there accordingly, similar to returning a -EIO for a bad STE in your SMMU part-3 series.
If the "return a flag" is an errno of the ioctl, it could work by reading from a separate memory that belongs to the event fd. Yet, in this case, an eventfd signal (assuming there is one to trigger VMM's fault handler) becomes unnecessary, since the invalidation ioctl is already handling it?
Thanks Nic
Would Intel be basically the same too?
Jason