[openfabrics-ewg] [PATCH/RFC 2.6.21 3/5] ehca: completion queue: remove use of do_mmap()

Christoph Hellwig hch at infradead.org
Thu Jan 11 11:43:46 PST 2007


On Thu, Jan 11, 2007 at 01:40:54PM -0600, Nathan Lynch wrote:
> Christoph Hellwig wrote:
> > On Thu, Jan 11, 2007 at 08:08:36PM +0100, Hoang-Nam Nguyen wrote:
> > 
> > >  	spin_lock_irqsave(&ehca_cq_idr_lock, flags);
> > >  	while (my_cq->nr_callbacks)
> > >  		yield();
> > 
> > Calling yield is a very bad idea in general.  You should probably
> > add a waitqueue that gets woken when nr_callbacks reaches zero to
> > sleep effectively here.
> 
> Isn't that code outright buggy?  Calling into the scheduler with a
> spinlock held and local interrupts disabled...

Umm, yes - of course.  I missed the spin_lock_irqsave line just above.




More information about the ewg mailing list