Re: [RFC][PATCH 4/4] configfs: Make multiple default_groupdestructions lockdep friendly

From: Joel Becker
Date: Fri Jun 06 2008 - 19:08:44 EST


On Tue, Jun 03, 2008 at 06:00:34PM +0200, Louis Rilling wrote:
> On Mon, Jun 02, 2008 at 04:07:21PM -0700, Joel Becker wrote:
> > A couple comments.
> > First, put a BUG_ON() where you have BAD BAD BAD - we shouldn't
> > be creating a depth we can't delete.
>
> I think that the best way to avoid this is to use the same numbering scheme
> while attaching default groups.

If I'm reading this right, when we come back up from one child
chain, we update the parent to be the same as the child - this is, i
assume, to allow all the locks to be held at once. IOW, you are trying
to have all locks in the default groups have unique lock levels,
regardless of their depth.
This is obviously limiting on the number of default groups for
one item - it's a total cap, not a depth cap. But I have another
concern. We lock a particular default_group with level N, then its
child default_group with level N+1. But how does that integrate with
VFS locking of the same mutexes?
Say we have an group G. It has one default group D1. D1 has a
default group itself, D2. So, when we populate the groups, we lock G at
MUTEX_CHILD, D1 at MUTEX_CHILD+1, and D2 at MUTEX_CHILD+2. However,
when the VFS navigates the tree (eg, lookup() or someone attempting an
rmdir() of D2's non-default child), it will lock with _PARENT and
_CHILD, not with our subclasses.
Am I right about this? We won't be using the same classes as
the VFS, and thus won't be able to see about interactions between the
VFS locking and our locking? I'd love to be wrong :-)

Joel

--

"The real reason GNU ls is 8-bit-clean is so that they can
start using ISO-8859-1 option characters."
- Christopher Davis (ckd@xxxxxxxxxxxxxx)

Joel Becker
Principal Software Developer
Oracle
E-mail: joel.becker@xxxxxxxxxx
Phone: (650) 506-8127
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/