Re: [PATCH v2 6/8] kvm tools: Add rwlock wrapper

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

 



On Mon, 2011-05-30 at 12:13 +0200, Ingo Molnar wrote:
> * Sasha Levin <levinsasha928@xxxxxxxxx> wrote:
> 
> > On Mon, 2011-05-30 at 11:56 +0200, Ingo Molnar wrote:
> > > * Sasha Levin <levinsasha928@xxxxxxxxx> wrote:
> > > 
> > > > I'm just saying that we're limited to as many VCPU threads as we 
> > > > can create. br_read_lock() won't do anything on a non-VCPU thread, 
> > > > which makes it impossible to test it on non-VCPUs.
> > > 
> > > btw., i wondered about that limit - don't we want to fix it?
> > > 
> > > I mean, there's no fundamental reason why brlocks should do 'nothing' 
> > > in worker threads. In fact it's a subtle breakage waiting AFAICS.
> > 
> > Can they do anything useful without locking? I think we should work 
> > on integrating an RCU and changing brlocks to use that instead of 
> > focusing too much on the current implementation.
> 
> What do you mean 'without locking'? If a worker thread uses a 
> br_read_lock() then that will be 'locking'. It should map to a real 
> read_lock() in the rwlock debug case, etc.
> 
I meant without locking anything within br_read_lock(), because we
wanted to keep the read patch lock-free.

> > This will also fix that limit you don't like :)
> 
> I'd prefer brlocks to more complex solutions in cases where the write 
> path is very infrequent!
> 
> So we don't want to keep brlocks intentionally crippled.
> 
Do you see brlock as a global lock that will pause the entire guest (not
just VCPUs - anything except the calling thread)?

> Currently we should at minimum need to BUG_ON() if br_read_lock() or 
> br_write_lock() is called in a worker thread context, right?
> 
> > > We should have enumeration for all threads that kvm starts, and 
> > > that we can use for a generic pause/resume facility. Can you see 
> > > anything that prevents that model?
> > 
> > Theres a difference between how you would pause a VCPU thread as 
> > opposed to a non-VCPU thread, other than that - no. We could use a 
> > thread manager.
> 
> Exactly, which would be useful for other purposes as well :-)
> 
> This only involves the write path so it is not an issue.
> 
> Thanks,
> 
> 	Ingo

-- 

Sasha.

--
To unsubscribe from this list: send the line "unsubscribe kvm" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [KVM ARM]     [KVM ia64]     [KVM ppc]     [Virtualization Tools]     [Spice Development]     [Libvirt]     [Libvirt Users]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite Questions]     [Linux Kernel]     [Linux SCSI]     [XFree86]
  Powered by Linux