[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

RE: [Xen-ia64-devel] Event channel vs current scheme speed [wasvIOSAPIC and IRQs delivery]



Anyway, good discussion by far though still some way to go for 
consensus. :-)

Maybe we want to look at this from another way - fairness.

On native system, OS may receive hardware interruptions includes 
exception, trap, fault and interrupts. (Copying from SDM) Interruptions 
are events that occur during instruction processing, causing the flow 
control to be passed to an interruption handling routine. Then Interrupts 
are normally the events that managed by interrupt controller.

Then let's see the major difference between two arguing mechanism 
(event channel Vs current interrupt injection): 
        whether to expose "xen event" as a new type of interruption (not 
interrupt) to guest.

Let's first look at current xen/ia64 behavior. All the "xen events" are 
bound to one hard-coded per-cpu vector (0xE9). From guest point of 
view, "xen events" are simply an interrupt. Xen event dispatcher is 
registered as an irq_action bound to vector 0xE9. Then __do_IRQ will 
finally jump to that dispatcher to handle "xen events".

Then the event channel mechanism is to expose "xen events" as a 
new interruption to xenlinux, with a specific callback handler as the 
direct resume point. Finally it's xen event dispatcher to invoke __do_IRQ 
if it's device interrupt.

Regarding current model, there seems to be an issue about fairness 
between physical interrupts and "xen events". Taking current 0xE9 for 
example, it's lower than timer but higher than all external device interrupts. 
This means "xen events" will always preempt device interrupts in this case,
which is unfair and not what we want.

Then, how about change it to a smaller value like smaller than all device
 interrupts? That's unfair again, since all the "xen events" are put on the 
bottom list even after keyboard interrupts. Some "xen events" are critical 
which has to be put at high priority. For example, xen may send 
VIRQ_DOM_EXC to guest when trying to kill domain. Also we shouldn't 
low down the priority of the traffic between frontend/backend drivers.

People may further think to place that hard-code vector in the middle. 
The question still holds that we can only move whole "xen events" to 
another priority level together. There is priority difference among external
 device interrupts, so are xen events. Two groups are interleaved without 
distinct split line. However current approach binds all "xen events" to one 
vector, thus such unfairness is difficult to handle at this rough grained level.

So how things go different for event channel mechanism? After introducing 
the callback to handle "xen events", actually "xen events" are the basic 
hardware event now that guest will receive. There'll be no interrupt injected 
into xenlinux any more. All the pirq, virq, ipi, and pure inter-domain event 
are bound to this "xen event". Since this is the new layer under interrupt, no 
need to change a lot to xenlinux (Major C change is contained in evtchn.c) 
and drivers in xenlinux still needs to request irq resource with difference 
that 
irq will be bound to event at the same time.

Since above two groups are now in a plain layer, and described by consistent 
evtchn_pending bit, it's possible and easy for event dispatcher to allocate 
priority globally. 

All in all, above long context is just one factor that I view to choose the 
proper 
mechanism. :-)

Thanks,
Kevin


>-----Original Message-----
>From: xen-ia64-devel-bounces@xxxxxxxxxxxxxxxxxxx
>[mailto:xen-ia64-devel-bounces@xxxxxxxxxxxxxxxxxxx] On Behalf Of Tristan
>Gingold
>Sent: 2006年3月9日 16:40
>To: Dong, Eddie; Magenheimer, Dan (HP Labs Fort Collins);
>xen-ia64-devel@xxxxxxxxxxxxxxxxxxx
>Subject: [Xen-ia64-devel] Event channel vs current scheme speed
>[wasvIOSAPIC and IRQs delivery]
>
>I'd like to narrow the discussion on this problem within this thread.
>
>We all agree we'd like to support shared IRQs and drivers domain.
>I am saying I can do that without event channel, while Eddie says it is
>required.
>
>One of Eddie argument is performance, as discussed previously.  Since I
>don't
>agree and things should be obvious here, I'd like to understand why we don't
>agree.
>
>See my comments.
>
>> >> 4: More new hypercall is introduced and more call to hypervisor.
>> > Only physdev_op hypercall is added, but it is also used in x86 to set
>> > up IOAPIC.  You can't avoid it.
>>
>> Initial time is OK for no matter what approach, runtime is critical.
>Ok.
>
>> I saw a lot of hypercall for RTE write.
>Did you see them by reading the code or by running ?
>
>There are hypercalls to mask/unmask interrupts.  Is it a performance
>bottleneck ?  I don't think so, since masking/unmasking shouldn't be very
>frequent.  Please tell me if I am wrong.
>
>There are also hypercalls to do EOI.  This can be a performance issue.
>If the interrupt is edge triggered, EOI is not required and could be optimized
>out if not yet done.
>If the interrupt is level-triggered, then it is required and I don't
>understand how event-channel can avoid it.  For me, this is the purpose of
>hypercall PHYSDEVOP_IRQ_UNMASK_NOTIFY.  Xen has to know when all
>domains have
>finished to handle the interrupt.
>
>Finally, there is the LSAPIC TPR, IVR and EOI.  I think the overhead is very
>small thanks to Dan's work.  And this overhead was measured with the timer.
>
>In my current understanding, I don't see the performance gain of
>event-channel.  And I repeat, I'd like to understand.
>
>Tristan.
>
>
>_______________________________________________
>Xen-ia64-devel mailing list
>Xen-ia64-devel@xxxxxxxxxxxxxxxxxxx
>http://lists.xensource.com/xen-ia64-devel

_______________________________________________
Xen-ia64-devel mailing list
Xen-ia64-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-ia64-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.