From owner-freebsd-current@FreeBSD.ORG Wed Jan 14 07:28:55 2004 Return-Path: Delivered-To: freebsd-current@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 054E416A4CF; Wed, 14 Jan 2004 07:28:55 -0800 (PST) Received: from fledge.watson.org (fledge.watson.org [204.156.12.50]) by mx1.FreeBSD.org (Postfix) with ESMTP id 86B0F43D39; Wed, 14 Jan 2004 07:28:52 -0800 (PST) (envelope-from robert@fledge.watson.org) Received: from fledge.watson.org (localhost [127.0.0.1]) by fledge.watson.org (8.12.10/8.12.10) with ESMTP id i0EFRBUd046787; Wed, 14 Jan 2004 10:27:11 -0500 (EST) (envelope-from robert@fledge.watson.org) Received: from localhost (robert@localhost)i0EFRBnv046784; Wed, 14 Jan 2004 10:27:11 -0500 (EST) (envelope-from robert@fledge.watson.org) Date: Wed, 14 Jan 2004 10:27:11 -0500 (EST) From: Robert Watson X-Sender: robert@fledge.watson.org To: Don Lewis In-Reply-To: <200401141308.i0ED8p7E039161@gw.catspoiler.org> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII cc: current@FreeBSD.org Subject: Re: simplifying linux_emul_convpath() X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 14 Jan 2004 15:28:55 -0000 On Wed, 14 Jan 2004, Don Lewis wrote: > I just stumbled across a vnode locking violation in > linux_emul_convpath(). Rather than locking and unlocking each vnode for > the VOP_GETATTR() calls, is there any reason that this code should not > be simplified to just compare the vnode pointers rather than fetching > the vnode attributes and comparing the attributes for equality. For some time, I've been thinking of adding samefile() and fsamefile() system calls to FreeBSD, which would allow userspace applications to determine if two names or file handles refer to the same object without playing games with inode numbers, device ids, etc. The reason to do this would be that 32-bit inode numbers are subject to collision on large file systems. My initial implementation simply compared vnode pointers, but that raises an interesting question about how stacked file systems should be treated, and depends a lot on the semantics of the stacked file system, really. My leaning is that in general they should probably be treated as different objects if they have different vnodes, because with the exception of nullfs (and occasionally unionfs), that probably is the desired semantic. You could imagine introducing a VOP to ask "Are you the same as this other vnode", and pointing it at both vnodes, but I think that adds unnecessary complexity without a whole lot of benefit. Robert N M Watson FreeBSD Core Team, TrustedBSD Projects robert@fledge.watson.org Senior Research Scientist, McAfee Research