Re: [PATCH] AFS: Fix file locking

From: Andrew Morton
Date: Thu Jul 19 2007 - 23:41:34 EST


On Wed, 18 Jul 2007 15:56:53 +1000 Nick Piggin <nickpiggin@xxxxxxxxxxxx> wrote:

> Andrew Morton wrote:
> > On Tue, 17 Jul 2007 13:47:32 +0100
> > David Howells <dhowells@xxxxxxxxxx> wrote:
> >
> >
> >>+ if (type == AFS_LOCK_READ &&
> >>+ vnode->flags & (1 << AFS_VNODE_READLOCKED)) {
> >
> >
> > Here we use
> >
> > vnode->flags & (1 << foo)
> >
> >
> >>+ set_bit(AFS_VNODE_LOCKING, &vnode->flags);
> >
> >
> > and elsewhere we use set_bit(foo, &vnode->flags) and clear_bit()
> >
> > This is a bit strange. Does the open-coded bit-test have any performance
> > benefit on any architecture? Not on x86 at least, afaik.
>
> It uses locked operations on x86, but you can use __set_bit instead
> (which should always be at least as efficient as the C version).

I said "bit-test". ie: test_bit(). That doesn't use a locked operation.
-
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/