| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
 Re: [Xen-devel] vmx: VT-d posted-interrupt core logic handling
 
To: "David Vrabel" <david.vrabel@xxxxxxxxxx>From: "Jan Beulich" <JBeulich@xxxxxxxx>Date: Thu, 10 Mar 2016 06:24:07 -0700Cc: Lars Kurth <lars.kurth@xxxxxxxxxx>, Kevin Tian <kevin.tian@xxxxxxxxx>, Feng Wu <feng.wu@xxxxxxxxx>, GeorgeDunlap <George.Dunlap@xxxxxxxxxxxxx>, Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, Dario Faggioli <dario.faggioli@xxxxxxxxxx>, Ian Jackson <Ian.Jackson@xxxxxxxxxxxxx>, George Dunlap <george.dunlap@xxxxxxxxxx>, "xen-devel@xxxxxxxxxxxxx" <xen-devel@xxxxxxxxxxxxx>Delivery-date: Thu, 10 Mar 2016 13:24:19 +0000List-id: Xen developer discussion <xen-devel.lists.xen.org> 
 >>> On 10.03.16 at 12:16, <david.vrabel@xxxxxxxxxx> wrote:
> On 10/03/16 10:46, George Dunlap wrote:
>> On 10/03/16 10:35, David Vrabel wrote:
>>> You could also consider only waking the first N VCPUs and just making
>>> the rest runnable.  If you wake more VCPUs than PCPUs at the same time
>>> most of them won't actually be scheduled.
>> 
>> "Waking" a vcpu means "changing from blocked to runnable", so those two
>> things are the same.  And I can't figure out what you mean instead --
>> can you elaborate?
>> 
>> Waking up 1000 vcpus is going to take strictly more time than checking
>> whether there's a PI interrupt pending on 1000 vcpus to see if they need
>> to be woken up.
> 
> Waking means making it runnable /and/ attempt to make it running.
> 
> So I mean, for the > N'th VCPU don't call __runq_tickle(), only call
> __runq_insert().
We expect only some (hopefully small) percentage of the vCPU-s
on the list to actually need unblocking anyway. As George said,
list traversal alone can be an issue here, and we can't stop going
through the list half way. The case where a large portion of the
vCPU-s on the list actually need waking up would be even more
worrying.
Jan
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
 
 |