summaryrefslogtreecommitdiffstats
path: root/block/blk-flush.c
diff options
context:
space:
mode:
authorDavid Vrabel <david.vrabel@citrix.com>2015-05-19 19:40:49 +0200
committerDavid Vrabel <david.vrabel@citrix.com>2015-05-19 20:55:36 +0200
commit77bb3dfdc0d554befad58fdefbc41be5bc3ed38a (patch)
tree845e60544a5b07d4adc6beb6249997c909575c1c /block/blk-flush.c
parentxen/arm: Define xen_arch_suspend() (diff)
downloadlinux-77bb3dfdc0d554befad58fdefbc41be5bc3ed38a.tar.xz
linux-77bb3dfdc0d554befad58fdefbc41be5bc3ed38a.zip
xen/events: don't bind non-percpu VIRQs with percpu chip
A non-percpu VIRQ (e.g., VIRQ_CONSOLE) may be freed on a different VCPU than it is bound to. This can result in a race between handle_percpu_irq() and removing the action in __free_irq() because handle_percpu_irq() does not take desc->lock. The interrupt handler sees a NULL action and oopses. Only use the percpu chip/handler for per-CPU VIRQs (like VIRQ_TIMER). # cat /proc/interrupts | grep virq 40: 87246 0 xen-percpu-virq timer0 44: 0 0 xen-percpu-virq debug0 47: 0 20995 xen-percpu-virq timer1 51: 0 0 xen-percpu-virq debug1 69: 0 0 xen-dyn-virq xen-pcpu 74: 0 0 xen-dyn-virq mce 75: 29 0 xen-dyn-virq hvc_console Signed-off-by: David Vrabel <david.vrabel@citrix.com> Cc: <stable@vger.kernel.org>
Diffstat (limited to 'block/blk-flush.c')
0 files changed, 0 insertions, 0 deletions