svn commit: r321839 - in head: share/man/man4 share/man/man5 sys/fs/fdescfs sys/kern sys/sys

Chagin Dmitry dchagin at freebsd.org
Tue Aug 1 04:04:47 UTC 2017


On Tue, Aug 01, 2017 at 03:40:19AM +0000, Dmitry Chagin wrote:
> Author: dchagin
> Date: Tue Aug  1 03:40:19 2017
> New Revision: 321839
> URL: https://svnweb.freebsd.org/changeset/base/321839
> 
> Log:
>   Implement proper Linux /dev/fd and /proc/self/fd behavior by adding
>   Linux specific things to the native fdescfs file system.
>   
>   Unlike FreeBSD, the Linux fdescfs is a directory containing a symbolic
>   links to the actual files, which the process has open.
>   A readlink(2) call on this file returns a full path in case of regular file
>   or a string in a special format (type:[inode], anon_inode:<file-type>, etc..).
>   As well as in a FreeBSD, opening the file in the Linux fdescfs directory is
>   equivalent to duplicating the corresponding file descriptor.
>   
>   Here we have mutually exclusive requirements:
>   - in case of readlink(2) call fdescfs lookup() method should return VLNK
>   vnode otherwise our kern_readlink() fail with EINVAL error;
>   - in the other calls fdescfs lookup() method should return non VLNK vnode.
>   
>   For what new vnode v_flag VV_READLINK was added, which is set if fdescfs has beed
>   mounted with linrdlnk option an modified kern_readlinkat() to properly handle it.
>   
>   For now For Linux ABI compatibility mount fdescfs volume with linrdlnk option:
>   
>       mount -t fdescfs -o linrdlnk null /compat/linux/dev/fd
>   
>   Reviewed by:	kib@
>   MFC after:	1 week
>   Relnotes:	yes

Differential Revision:		https://reviews.freebsd.org/D11452 


More information about the svn-src-head mailing list