|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] Multiple issues with event channel on Xen on ARM
On 02/05/2014 01:34 PM, David Vrabel wrote:
Hello David,
> I think the following patch should fix the 2-level problems.
>
> You can force the use of 2-level events by using the xen.fifo_events=0
> Linux command line option.
Thanks for the patch, I'm now able to use 2-level events without issue
for a guest.
Now, I need to look at the fifo events when the domain is killed.
> 8<-------------------------------------------------
> xen/events: bind all new interdomain events to VCPU0
>
> From: David Vrabel <david.vrabel@xxxxxxxxxx>
>
> Commit fc087e10734a4d3e40693fc099461ec1270b3fff (xen/events: remove
> unnecessary init_evtchn_cpu_bindings()) causes a regression.
>
> The kernel-side VCPU binding was not being correctly set for newly
> allocated or bound interdomain events. In ARM guests where 2-level
> events were used, this would result in no interdomain events being
> handled because the local VCPU masks would all be clear.
>
> x86 guests would work because the irq affinity was set during irq
> setup and this would set the correct kernel-side VCPU binding.
>
> Fix this by by properly initializing the kernel-side VCPU binding in
> bind_evtchn_to_irq().
>
> Reported-by: Julian Grall <julien.grall@xxxxxxxxxx>
s/Julian/Julien/
> Signed-off-by: David Vrabel <david.vrabel@xxxxxxxxxx>
Tested-by: Julien Grall <julien.grall@xxxxxxxxxx>
Regards,
> ---
> drivers/xen/events/events_base.c | 3 +++
> 1 files changed, 3 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/xen/events/events_base.c
> b/drivers/xen/events/events_base.c
> index 4672e00..5cc1f78 100644
> --- a/drivers/xen/events/events_base.c
> +++ b/drivers/xen/events/events_base.c
> @@ -862,6 +862,9 @@ int bind_evtchn_to_irq(unsigned int evtchn)
> irq = ret;
> goto out;
> }
> +
> + /* Newly bound event channels start off on VCPU0. */
> + bind_evtchn_to_cpu(evtchn, 0);
> } else {
> struct irq_info *info = info_for_irq(irq);
> WARN_ON(info == NULL || info->type != IRQT_EVTCHN);
>
--
Julien Grall
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |