Skip to content
Snippets Groups Projects
Commit c44b849c authored by Juergen Gross's avatar Juergen Gross
Browse files

xen/events: switch user event channels to lateeoi model


Instead of disabling the irq when an event is received and enabling
it again when handled by the user process use the lateeoi model.

This is part of XSA-332.

Cc: stable@vger.kernel.org
Reported-by: default avatarJulien Grall <julien@xen.org>
Signed-off-by: default avatarJuergen Gross <jgross@suse.com>
Tested-by: default avatarStefano Stabellini <sstabellini@kernel.org>
Reviewed-by: default avatarStefano Stabellini <sstabellini@kernel.org>
Reviewed-by: default avatarJan Beulich <jbeulich@suse.com>
Reviewed-by: default avatarWei Liu <wl@xen.org>
parent c2711441
No related branches found
No related tags found
No related merge requests found
...@@ -167,7 +167,6 @@ static irqreturn_t evtchn_interrupt(int irq, void *data) ...@@ -167,7 +167,6 @@ static irqreturn_t evtchn_interrupt(int irq, void *data)
"Interrupt for port %u, but apparently not enabled; per-user %p\n", "Interrupt for port %u, but apparently not enabled; per-user %p\n",
evtchn->port, u); evtchn->port, u);
disable_irq_nosync(irq);
evtchn->enabled = false; evtchn->enabled = false;
spin_lock(&u->ring_prod_lock); spin_lock(&u->ring_prod_lock);
...@@ -293,7 +292,7 @@ static ssize_t evtchn_write(struct file *file, const char __user *buf, ...@@ -293,7 +292,7 @@ static ssize_t evtchn_write(struct file *file, const char __user *buf,
evtchn = find_evtchn(u, port); evtchn = find_evtchn(u, port);
if (evtchn && !evtchn->enabled) { if (evtchn && !evtchn->enabled) {
evtchn->enabled = true; evtchn->enabled = true;
enable_irq(irq_from_evtchn(port)); xen_irq_lateeoi(irq_from_evtchn(port), 0);
} }
} }
...@@ -393,8 +392,8 @@ static int evtchn_bind_to_user(struct per_user_data *u, evtchn_port_t port) ...@@ -393,8 +392,8 @@ static int evtchn_bind_to_user(struct per_user_data *u, evtchn_port_t port)
if (rc < 0) if (rc < 0)
goto err; goto err;
rc = bind_evtchn_to_irqhandler(port, evtchn_interrupt, 0, rc = bind_evtchn_to_irqhandler_lateeoi(port, evtchn_interrupt, 0,
u->name, evtchn); u->name, evtchn);
if (rc < 0) if (rc < 0)
goto err; goto err;
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment