Re: [PATCH] [2.5] reiserfs: fix races between link and unlink on same file

From: Chris Mason (mason@suse.com)
Date: Fri Aug 01 2003 - 09:05:40 EST


On Fri, 2003-08-01 at 07:10, Oleg Drokin wrote:
> Hello!
>
> On Thu, Jul 31, 2003 at 01:37:08PM -0700, Andrew Morton wrote:
>
> > > This patch (originally by Chris Mason) fixes link/unlink races in reiserfs.
> > Could you describe the race a little more please? Why is the VFS's hold of
> > i_sem on the parent directory not sufficient?
>
> Well, we do not take i_sem on parent directory of source filename for sys_link, I think.
> So we might endup in sys_link() with inode that is already deleted/being deleted (and nlink==0).
> Actually, I naturally thought that only i_nlink check to be non zero at reiserfs_link time should be
> enough, but Chris is sure that we need entire patch, so may be he may add more comments to that.
>

Yes, it's basically a problem of making sure reiserfs_link sees any
changes made by reiserfs_unlink and vice versa. Toss in the BKL and a
few funcs that schedule and you get small windows where the object
you're linking to can have a inode->i_nlink of zero.

All of which is dealt with properly at the VFS level. The trick in
reiserfs is that somebody needs to take care of removing the savelink
used to prevent lost files after a crash. If we don't get the i_nlink
timing right, two different procs might try to remove the savelink, or
it might not get removed at all.

> BTW, looking at vfs_link, this patch (below the message) seems to be
> natural thing to do, is not it?
>

Looks fine.

-chris

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Thu Aug 07 2003 - 22:00:16 EST