[PATCH v2 3/6] hw/char: pl011 don't keep setting the IRQ if nothing changed
Alex Bennée
alex.bennee at linaro.org
Fri Mar 13 03:38:58 PDT 2015
Peter Maydell <peter.maydell at linaro.org> writes:
> On 12 March 2015 at 15:51, Peter Maydell <peter.maydell at linaro.org> wrote:
>> On 4 March 2015 at 14:35, Alex Bennée <alex.bennee at linaro.org> wrote:
>>> While observing KVM traces I can see additional IRQ calls on pretty much
>>> every MMIO access which is just plain inefficient. Only update the QEMU
>>> IRQ level if something has actually changed from last time. Otherwise we
>>> may be papering over other failure modes.
>
>> Consider this sequence of events:
>
> Incidentally, the code review rule of thumb that led me to
> construct that scenario is:
> * state inside the device struct which doesn't correspond
> to real hardware state is suspicious
> * state which doesn't have any handling on migration
> save/restore is doubly suspicious
> ...and then it was just a matter of "find the situation
> where this is broken" :-)
>
> If we want to avoid making syscalls back into KVM it might
> be better to attack the problem in the GIC object rather
> than in all the devices that might be connected to it.
> In general QEMU devices tend to assume they can just
> always call qemu_set_irq() and it's the other end's
> job to avoid doing anything too expensive in that situation.
Fair enough - I'll drop this patch on the re-spin
>
> -- PMM
--
Alex Bennée
More information about the linux-arm-kernel
mailing list