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

RE: [Xen-ia64-devel] vIOSAPIC and IRQs delivery



Alex Williamson wrote:
> On Wed, 2006-03-08 at 12:00 -0800, Magenheimer, Dan (HP Labs Fort
> Collins) wrote:
>>>    We agree IOSAPIC must belong to Xen.  And it should be able to
>>> deliver interrupts to domains and handle shared IRQs.
>> 
>> Did I miss an answer to Tristan's earlier question,
>> which was approximately: How many systems out there
>> require shared IRQ's?  I realize there are some huge
>> mainframe-class boxes that have hundreds of I/O cards
>> that probably do require shared IRQ's, but I wonder
>> if this class of machine will even consider using
>> Xen?  Mainframe-class machines have other partitioning
>> technologies with customer-expected features that Xen
>> will never have (such as hardware fault containment).
> 
>    Hopefully I'm not stepping into a rat-hole here, but what are we
> defining as a shared IRQ?  If we're only talking about running out of
> external interrupt vectors on the CPU and programming multiple IOSAPIC
> RTEs to trigger the same vector, I agree.  That case requires are
> rather large system.  Eventually we should support this, but things
> like interrupt domains may be a better long term solutions.

Thanks!
The problem is that Xen already support it by default, the solution is
already there.
What we do is just to use it :-) Linux already support this !
Then why IA64 want to remove this support and leave an extra effort to
future.
If it is a new one, I would say yes we should start from simple.

> 
> Then the third question:  Is there a performance
> cost for shared IRQ support, even on systems that
> don't share IRQ's?  Is there an additional
> performance cost for sharing an IRQ across domains?
> With each NIC card capable of generating thousands
> of interrupts/second, it doesn't seem wise to
> add additional overhead to every interrupt on
> every Xen system to support the possibility that
> someone may want to configure a system to share
> IRQs across domains.

The extra overhead cost in shared IRQ support approach is 0. When this
IRQ
 is not shared, xen just inject it into guest, no extra logic. Event
channel
based pirq handling is much faster than vIOSAPIC based solution as we
have
 conducted in previous discussion.


Some basic conclusion from previous mail include:
1: Event channel based solution has better performance than vIOSAPIC. 
The detail amount is hard to say now, and should depend on benchmark
tool.

2: Event channel based solution can support shared IRQ lines amongst
domains
without any extra logic.

3: Stability:
Event channel based solution has undergone long time well test and real
deployment, 
but vIOSAPIC is not. BTW, IRQ is very important in OS, a race condition
issue may
cost people weeks or even months debug effort.

Some statement people are still arguing:
4: Which one change linux less ?
    My answer is still event channel based solution, as all event
channel code are xen common and 
is already in (VBD/VNIF use it).

5: Which one is much transparent?
   Event channel based solution only needs to do in initial time using
if running_on_xen 
to choice different type hardware interrupt object (i.e. pirq_type vs,
iosapic level_irq_type
 and edge_xxx). After that no extra code.
  vIOSAPIC need to check runtime for every IOSAPIC MMIO access.

6: Stability of future:
   My answer is clear, fixing an intial time bug only costs one-tenth of
runtime bug. Eventchannel
based solution only change intial time code.

Hope this be helpful, thx
Eddie

_______________________________________________
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®.