Quoting Marc Zyngier (2018-04-10 08:23:00) > On 10/04/18 16:01, Thomas Petazzoni wrote: > > > In the upcoming Armada 8KP, we have a GICv3, which has built-in support > > for memory-triggered SPIs, thanks to the GICD_SETSPI_NSR and > > GICD_CLRSPI_NSR, and the ICU will directly use this GICv3 > > functionality. We would therefore very much like to have this GICv3 > > feature provided as a MSI controller, which as Marc said would require > > supporting level-triggered MSIs. > > > > Marc, let me know how we can collaborate on this topic. I'm able to > > either test some preliminary patches, or work on such patches if > > necessary (preferably with some initial directions). > > I have a vague idea how to support this. Given that level-triggered MSIs > have to be platform MSIs (because it is just madness otherwise), we can > probably store an extra message in the struct platform_msi_desc for the > "lower the line" write. On activation, you'd get two callbacks, probably > with a flag of some sort to indicate whether this is for the rising or > falling edge. The thing I'm unclear about so far is how to let the > generic MSI layer know that we're dealing with such an interrupt without > make a total mess of everything. It is probably done by marking the > interrupt level triggered, but there are some corner cases. > > And if that works, the PCI stuff will come for free (it is just a matter > of implementing a new irqdomain on top of the base GICv3 one). > > I'll try to spend some time on it in the coming couple of weeks, but > will have to rely on you for the testing (as I don't have much in the > way of HW).
I resent these patches late last year. On the HW I had at the time we were trying to support PCIe devices and we didn't need level interrupts. I thought Marc had agreed to accept the patches without the level interrupt support as long as we described the range of interrupts that were supported but that doesn't seem to be the case anymore. Anyway, this is mostly an FYI that I don't have the hardware to test with anymore and I'm not going to keep sending patches on this topic. Srini should have some hardware to test whatever solution you come up with.  http://lkml.kernel.org/r/20171127102408.6631-1-sb...@codeaurora.org