On 01/20/2012 05:05 PM, Benjamin Herrenschmidt wrote: > On Thu, 2012-01-19 at 13:29 -0600, Stuart Yoder wrote: >> Also, Scott had posted an approach to do option #2 a while back, >> but as I recall there was some negative feedback about this. See: >> <http://lists.ozlabs.org/pipermail/linuxppc-dev/2011-August/092103.html> > > I see... the problems with doorbells are workable tho. A reject hcall > could also raise the CPU priority to avoid lower priority interrupts for > example. The decrementer option works too. > > Another approach is to do an hcall into the interrupt re-enable path > when an interrupt occurred while masked, which is what we do on i or > ps3, which could then trigger a replay.
Here's what I previously wrote to you about this: > If we never hard-enable with a pending interrupt (go straight to the > exception entry), we can leave the interrupt in EPR. If we hard-enable > even briefly, we can't guarantee that another (higher priority) > interrupt won't come in before the doorbell, so we need to be able to > queue up a number of interrupts equal to the number of priorities in use. > > Care will need to be taken to dequeue in proper order, whether the > interrupt comes in via extirq or doorbell (e.g. if we take an extirq on > hard-enable, and then the doorbell fires when that interrupt > hard-enables, we don't want to run the lower-priority queued interrupt > until after the high prio handler is done). > > BTW, for non-booke, when is DEC checked when interrupts are hard-enabled > as part of exception return? Likewise with the PS3 HV thing. I only > see the iseries check in the exception path. Perhaps the issues with a higher priority interrupt intervening can be addressed by messing around with current task priority at the MPIC (with an hcall introduced for the hv case, since currently task priority is not exposed to the guest). I haven't had time to revisit this, and don't expect to soon. If someone else wants to try, fine. In the meantime, lazy EE is causing problems. I'd still like to know the answer to that last question. It's difficult to determine how to correctly implement this stuff for our hardware if it looks like there are holes in the scheme for hardware that this is supposed to already work with. > Traditionally EE's have always been "level sensitive" on PowerPC, You mean besides the places you already have to work around, such as doorbells and book3s decrementers and other hypervisors... and you force all functions that enable interrupts to create a stack frame to deal with this. > the way you changed that is arguably an utterly broken HW design Just because you don't like it, and it doesn't play well with your hack, doesn't make it "utterly broken". > and I am not too keen on changing our core interrupt handling to deal with it > via > ifdef's if we can find a less invasive solution. Wheras having to significantly change the way interrupts work because the register size doubled is so totally reasonable... What is the compelling reason for forcing lazy EE on us? Why is it tied to 64-bit? -Scott _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev