xen/events/fifo: Handle linked events when closing a port
authorRoss Lagerwall <ross.lagerwall@citrix.com>
Fri, 31 Jul 2015 13:30:42 +0000 (14:30 +0100)
committerDavid Vrabel <david.vrabel@citrix.com>
Tue, 4 Aug 2015 14:41:59 +0000 (15:41 +0100)
commitfcdf31a7c162de0c93a2bee51df4688ab0a348f8
treea93d841ce0104c8e19e6e37253df8512e0113a6e
parent929423fa83e5b75e94101b280738b9a5a376a0e1
xen/events/fifo: Handle linked events when closing a port

An event channel bound to a CPU that was offlined may still be linked
on that CPU's queue.  If this event channel is closed and reused,
subsequent events will be lost because the event channel is never
unlinked and thus cannot be linked onto the correct queue.

When a channel is closed and the event is still linked into a queue,
ensure that it is unlinked before completing.

If the CPU to which the event channel bound is online, spin until the
event is handled by that CPU. If that CPU is offline, it can't handle
the event, so clear the event queue during the close, dropping the
events.

This fixes the missing interrupts (and subsequent disk stalls etc.)
when offlining a CPU.

Signed-off-by: Ross Lagerwall <ross.lagerwall@citrix.com>
Cc: <stable@vger.kernel.org>
Signed-off-by: David Vrabel <david.vrabel@citrix.com>
drivers/xen/events/events_base.c
drivers/xen/events/events_fifo.c
drivers/xen/events/events_internal.h