WARNING - OLD ARCHIVES

This is an archived copy of the Xen.org mailing list, which we have preserved to ensure that existing links to archives are not broken. The live archive, which contains the latest emails, can be found at http://lists.xen.org/
   
 
 
Xen 
 
Home Products Support Community News
 
   
 

xen-ia64-devel

RE: [Xen-ia64-devel] xencons interrupt problem

To: "Alex Williamson" <alex.williamson@xxxxxx>
Subject: RE: [Xen-ia64-devel] xencons interrupt problem
From: "Tian, Kevin" <kevin.tian@xxxxxxxxx>
Date: Mon, 26 Jun 2006 11:17:10 +0800
Cc: xen-ia64-devel <xen-ia64-devel@xxxxxxxxxxxxxxxxxxx>
Delivery-date: Sun, 25 Jun 2006 20:17:46 -0700
Envelope-to: www-data@xxxxxxxxxxxxxxxxxx
List-help: <mailto:xen-ia64-devel-request@lists.xensource.com?subject=help>
List-id: Discussion of the ia64 port of Xen <xen-ia64-devel.lists.xensource.com>
List-post: <mailto:xen-ia64-devel@lists.xensource.com>
List-subscribe: <http://lists.xensource.com/cgi-bin/mailman/listinfo/xen-ia64-devel>, <mailto:xen-ia64-devel-request@lists.xensource.com?subject=subscribe>
List-unsubscribe: <http://lists.xensource.com/cgi-bin/mailman/listinfo/xen-ia64-devel>, <mailto:xen-ia64-devel-request@lists.xensource.com?subject=unsubscribe>
Sender: xen-ia64-devel-bounces@xxxxxxxxxxxxxxxxxxx
Thread-index: AcaYy9hkECBWSZbdR0iNIHyEAvhSKwAAXQaA
Thread-topic: [Xen-ia64-devel] xencons interrupt problem
>From: Alex Williamson [mailto:alex.williamson@xxxxxx]
>Sent: 2006年6月26日 10:54
>>      It easy to fix above checks, like to add an IRQ_BOTH flag on top
>> of IRQ_GUEST to allow such a case. However the real issue is that full
>> PCI knowledge is owned by dom0 instead of xen. To let xen allocate
>> resources for PCI serial and check whether specific irq line is shared
>> between, ACPI namespace enumeration and PCI initialization are
>> required to be brought back to xen. A big effort and whether worthy of
>> doing that? Or some special workaround to bypass that for this special
>> serial case?
>
>   I don't think we have to go to that much trouble, Xen doesn't need to
>be aware of PCI and ACPI.  Xen should be able to note that the
>interrupt
>is shareable by it's trigger/polarity, right?

However how does xen know which interrupt line is shared between xen 
and dom0? Shareable doesn't mean actual share, right?

>
>>      For the interrupt name space, currently xen and dom0 share the
>> same space, meant that vector allocation always happens in xen and
>> dom0 issues hypercall to retrieve allocated vector back as the one
>used
>> in dom0 context directly. Based on this point, xen can ensure same
>> vector returned to dom0 as the one owned by xen itself if irq sharing
>> happens. But xen needs PCI knowledge as said above.
>
>   Xen wouldn't need PCI knowledge to accomplish this.  Shouldn't it
>just need the GSI to determine it's sharing the interrupt w/ the guest?
>In any case, this seems broken as my dom0 is reprogramming the
>IOSAPIC
>RTE w/ a different vector.

That's because current irq allocation doesn't support this share style, 
and thus each assign_irq_vector from dom0 will get a new vector. If 
you have hint to know which irq line is shared with PCI serial port, you 
can change to return same vector when dom0 is requesting for device 
on the same line. Be careful, current difference you observed doesn't 
mean from different vector spaces. Instead they're two vectors 
allocated for same line from same vector space. That's incorrect.

>
>>      Final question is, do we really need support such a PCI serial port
>> owned by xen? :-)
>
>   IMHO, yes.  This is the core I/O on an HP Superdome, and I don't
>think a PCI console UART sharing an interrupt with another non-UART
>device is all that unusual.  Thanks,

Definitely it's usual for PCI device sharing. I should say "... support a 
PCI serial port with irq line enabled for xen?" I still doubt the effort and 
flexibility to support such a model, and maybe some check against it 
to fallback to poll mode is the better choice.

Thanks,
Kevin

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