Date: Fri, 8 May 2009 23:12:03 +0300 From: Kostik Belousov <kostikbel@gmail.com> To: Tim Kientzle <kientzle@freebsd.org> Cc: "'freebsd-hackers@freebsd.org'" <freebsd-hackers@freebsd.org> Subject: Re: fdescfs brokenness Message-ID: <20090508201203.GJ1948@deviant.kiev.zoral.com.ua> In-Reply-To: <4A03A202.2050101@freebsd.org> References: <4A03A202.2050101@freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
--/SgVJVxFudH2R+XP Content-Type: text/plain; charset=us-ascii Content-Disposition: inline Content-Transfer-Encoding: quoted-printable On Thu, May 07, 2009 at 08:07:46PM -0700, Tim Kientzle wrote: > Colin Percival recently pointed out some issues > with tar and fdescfs. Part of the problem > here is tar; I need to rethink some of the > traversal logic. >=20 > But fdescfs is really wonky: >=20 > * This is a nit, but: ls /dev/fd/18 should not > return EBADF; it should return ENOENT, just > like any other reference to a non-existent filename. > (Just because a filename reflects a file descriptor > does not mean it is a file descriptor.) This is a traditional behaviour for fdescfs. According to man page, open("dev/fd/N") shall be equivalent to fcntl(N, F_DUPFD, 0). Solaris behaviour is the same. >=20 > * The fairly routine recursive directory walker > below gets hung in fdescfs. It appears that > the two opendir() invocations active at the > same time interfere with each other. What you mean by "gets hung" ? In my limited testing, it works. Opendir creates a new directory in /dir/fd by the mere fact of opening the directory. So it walks into that dir, returning to step 1. >=20 > * A similar chdir()-based version of the directory > walker below breaks badly; you can chdir() into > a directory under /dev/fd, but you can't chdir("..") > to get back out of it. (This is the particular > problem that tar is running afoul of.) Not sure about this one. I think that fdescfs vnodes do not support lookup on anything not being root of the fdescfs. >=20 > * Running "find /dev/fd" generates bogus ENOENT errors > because you can opendir() a directory inside of /dev/fd, > and read the entries, but you can't access those entries > because path searches don't work through fdescfs. Again, this may be a consequence of the previous issue. >=20 > I think the right solution here is to add a VOP_ACCESS > handler to fdescfs that bars all access to directory > nodes under /dev/fd. Basically, if your program has a > directory open, that should be reflected as a directory > node that you can't do anything with. The current implementation > allows you to chdir(), opendir(), etc, those directory > nodes, but the machinery to fully support those operations > is missing so they just screw things up. This would chomp the fdescfs functionality, IMHO. Why directory file descriptors should behave differently then any other file descriptor ? I think that the actual solution for the walker problems is to ignore the synthetic filesystems altogether. The information is provided by sysctl vfs.conflist (note that the output is binary), see VFCF_* flags, esp. VFCF_SYNTHETIC. The flag is correctly set at least by procfs, devfs and fdescfs. --/SgVJVxFudH2R+XP Content-Type: application/pgp-signature Content-Disposition: inline -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.9 (FreeBSD) iEYEARECAAYFAkoEkhIACgkQC3+MBN1Mb4ieHACfSdqlU3dWNPycraSH9+63Yy3a W54AoIL1nvTk/mYAQ5b7UVQoMig81SBR =/GP5 -----END PGP SIGNATURE----- --/SgVJVxFudH2R+XP--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20090508201203.GJ1948>