Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 5 Mar 2003 11:40:30 -0800 (PST)
From:      Julian Elischer <julian@elischer.org>
To:        John Baldwin <jhb@FreeBSD.org>
Cc:        cvs-all@FreeBSD.org, cvs-src@FreeBSD.org, src-committers@FreeBSD.org, "Brian F. Feldman" <green@FreeBSD.org>
Subject:   Re: cvs commit: src/sys/kern kern_mutex.c
Message-ID:  <Pine.BSF.4.21.0303051134130.61509-100000@InterJet.elischer.org>
In-Reply-To: <XFMail.20030305115639.jhb@FreeBSD.org>

next in thread | previous in thread | raw e-mail | index | archive | help


On Wed, 5 Mar 2003, John Baldwin wrote:

> 
> On 05-Mar-2003 Julian Elischer wrote:
> > 
> > 
> > On Tue, 4 Mar 2003, Brian F. Feldman wrote:
> 
> mtx_trylock() really should be used sparingly I think.  I don't
> want people doing this:
> 
>         if (!mtx_trylock(foo))
>                 tsleep(...);
> 
> If they want to block on a lock they should use mtx_lock().  Cases
> where one might use mtx_trylock() that I can think of is for
> optional optimizations for cases that might otherwise be a lock
> order violation.  I.e., if I can lock two X objects, then I can
> bypass having to lock one, stick it on a queue so that some other
> thread can connect it to the other.  The only time I have used it
> is in the OOM killer where I need to be able to lock a process I
> am checking while keeping the current target process locked for
> the whole loop.  Really, I want the programmer to think carefully
> when they use mtx_trylock() and blindly recursing on a lock might
> result in some hard to track down bugs.
> 

The case I was using it for was basically:
	if (!mtx_trylock(foo)) {
		queue_data_for_later_proccessing(data)
		return;
	}
	do_the_work_immediatly();

where it was possible that I had called myself as part of
do_the_work_immediatly() and wanted it to complete immediatly
since I knew I already owned the object.

I can see that in other cases you would want the alternative
behaviour however.



To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe cvs-all" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.BSF.4.21.0303051134130.61509-100000>