Re: [PATCH] powerpc/mpic: Add DT option to skip readback after EOI

From: Scott Wood
Date: Wed Jan 21 2015 - 04:50:07 EST


On Wed, 2015-01-21 at 11:35 +0200, Purcareata Bogdan wrote:
> On 14.01.2015 19:58, Scott Wood wrote:
> > On Wed, 2015-01-14 at 11:57 +0000, Bogdan Purcareata wrote:
> >> The readback is necessary in order to handle PCI posted
> >> writes,
> >
> > That is unclear.
>
> I'm going to try an venture a different explanation here.
>
> I found a good explanation in Writing PCI Drivers [1] as to why it's
> necessary that a read is performed before returning from an EOI write:
>
> "A good example of such a case is when a driverâs Interrupt Service
> Routine (ISR) is dealing with the Interrupt Request Register (IRR) on a
> card. Clearing a bit in the register indicates that the interrupt has
> been serviced. This is done by posting a write to the register. If the
> driver posts this write and exits its ISR, it could get interrupted
> again immediately because the write hadnât yet reached the bit in the
> IRR to tell it to stop trying to interrupt. One solution to this
> potential problem is to make sure to read back the value in the IRR
> before exiting from the ISR. Most drivers do this anyway so they can
> handle multiple interrupts in the same ISR visit."

That's an issue of ordering the device write versus the EOI -- it
doesn't explain why we'd need to order the EOI versus rfi, except maybe
that the extra delay just happens to be enough to give the device the
time it needs to deassert the second interrupt before it gets to the
point of interrupting the CPU.

FWIW, I'm skeptical of the "most drivers do this anyway" claim.

> >> or when the MPIC is handling interrupts in a loop
> >> (ppc_md.get_irq).
> >
> > I'm questioning this one as well -- if reading WHOAMI is sufficient to
> > sync with the EOI, why wouldn't reading INTACK work as well?
>
> I think I'm going to drop this part of the description. However, I don't
> think reading INTACK is good, since it has some additional side effects
> - interrupt pending register is cleared for edge-sensitive interrupts,
> the in-service register is updated, and the int output signal from the
> MPIC is negated. This is available for Freescale SoCs. This also
> signifies entering the processing cycle of a new interrupt.

I wasn't suggesting that we start reading INTACK there. I'm asking why,
back when we did read INTACK in a loop, that wasn't ordered relative to
the EOI write (but reading WHOAMI was).

> Normally, the readback should be done on the EOI register - this is
> stated in the OpenPIC specification and actually was the initial
> implementation of the driver. However, this can't be done since, at
> least for Freescale SoCs, the EOI register is write only.
>
> However, in the light of the above explanation related to PCI posted
> writes, I don't see how performing a readback on the WHOAMI register,
> which is specific to the MPIC, would have any effect in synchronizing
> with the PCI device registers. I guess it's related to the bus
> interconnect on the SoC.

I wonder if anyone has checked whether the spurious interrupts that
reading EOI got rid of have come back on those systems, now that we read
WHOAMI instead.

-Scott


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/