Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 23 Nov 2007 17:48:45 +0100
From:      "Attilio Rao" <attilio@freebsd.org>
To:        "Stephan Uphoff" <ups@freebsd.org>
Cc:        Max Laier <max@love2party.net>, Alfred Perlstein <alfred@freebsd.org>, freebsd-arch@freebsd.org
Subject:   Re: rwlocks, correctness over speed.
Message-ID:  <3bbf2fe10711230848t29a711ccg74f6cfc37f84a2e5@mail.gmail.com>
In-Reply-To: <4746F858.4070301@freebsd.org>
References:  <20071121222319.GX44563@elvis.mu.org> <200711221641.02484.max@love2party.net> <3bbf2fe10711220753u435ff4cbxa94d5b682292b970@mail.gmail.com> <200711221726.27108.max@love2party.net> <20071123082339.GN44563@elvis.mu.org> <47469328.8020404@freebsd.org> <20071123092415.GP44563@elvis.mu.org> <4746F858.4070301@freebsd.org>

next in thread | previous in thread | raw e-mail | index | archive | help
2007/11/23, Stephan Uphoff <ups@freebsd.org>:
> Alfred Perlstein wrote:
> >
> > That's an interesting hack, I guess it could be done.
> >
> > I would still like to disallow recursion.
> >
> Oh - I am all for disallowing recursion.
> In my opinion the only valid place for a thread to acquire the same lock
> multiple times is inside a transaction system with full deadlock detection.
> The question is if we can do that this late in the game?
> Maybe we could make non recursive the default and add a call
> rw_allow_recurse  or rw_init_recurse  to allow recursion on a lock if we
> can't get away with
> the straight out removal of the option? (Or less desirable - keep the
> current default and add functions to disallow recursion)

This is still tricky as long as the other set of functions (downgrade,
upgrade, etc.) rely on the bits settings and wakeup algorithms which
will differ between the two version.

My idea is to add recursion detection for readers in witness so that
rwlock consumers which still recurse in read mode can be fixed and
later detected.

Attilio


-- 
Peace can only be achieved by understanding - A. Einstein



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3bbf2fe10711230848t29a711ccg74f6cfc37f84a2e5>