Re: [PATCH 0/7] cifs: Improve mount option -o reparse and support for native Windows sockets

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



this table looks potentially very helpful - my main focus is making sure
1) that symlinks work in the "native" windows format
2) that we recognize special files created in the various forms
(reparse nfs or wsl, and also sfu)
3) that the reparse=nfs case works with or without the posix
extensions chosen on the mount
4) that we can create special files in reparse=nfs and wsl, and also
sfu - use cases

On Sun, Oct 6, 2024 at 5:01 AM Pali Rohár <pali@xxxxxxxxxx> wrote:
>
> This patch series improves choosing reparse format when creating new
> special files.
>
> In following table is behavior of creating new special files before
> this patch series. In columns are mount options, in rows are file types
> and in each cell is reparse format which is created.
>
>           -o reparse=default  -o reparse=nfs  -o reparse=wsl
> symlink      native              native          native
> socket       nfs                 nfs             wsl
> fifo         nfs                 nfs             wsl
> block        nfs                 nfs             wsl
> char         nfs                 nfs             wsl
>
>
> After this patch series the table looks like:
>
>           -o reparse=default  -o reparse=nfs  -o reparse=wsl  -o reparse=native+nfs  -o reparse=native+wsl  -o reparse=native  -o reparse=none
> symlink      native              nfs             wsl             native                 native                 native             -disallowed-
> socket       native              nfs             wsl             native                 native                 native             -disallowed-
> fifo         nfs                 nfs             wsl             nfs                    wsl                    -disallowed-       -disallowed-
> block        nfs                 nfs             wsl             nfs                    wsl                    -disallowed-       -disallowed-
> char         nfs                 nfs             wsl             nfs                    wsl                    -disallowed-       -disallowed-
>
>
> The default behavior when no option is specified (which is same as
> -o reparse=default) changes only for creating new sockets which are
> now created in its native NTFS form with IO_REPARSE_TAG_AF_UNIX reparse
> tag.
>
> The nfs and wsl behavior is changed to always create new special files
> in its own formats.
>
> There are new options native+nfs and native+wsl which creates by default
> in native form (symlinks + sockets) and fallbacks to nfs/wsl for other
> types (fifo, char, block). This is probably the most useful for
> interoperability. Mount option -o reparse=default is now same as
> -o reparse=native+nfs
>
> For completeness there are also new options -o reparse=native which
> allows to creating only native types used by Windows applications
> (symlinks and sockets) and option -o reparse=none to completely disable
> creating new reparse points.
>
>
> Pali Rohár (7):
>   cifs: Add mount option -o reparse=native
>   cifs: Add mount option -o reparse=none
>   cifs: Add support for creating native Windows sockets
>   cifs: Add support for creating NFS-style symlinks
>   cifs: Improve guard for excluding $LXDEV xattr
>   cifs: Add support for creating WSL-style symlinks
>   cifs: Validate content of WSL reparse point buffers
>
>  fs/smb/client/cifsglob.h   |  18 +++-
>  fs/smb/client/fs_context.c |  16 +++
>  fs/smb/client/fs_context.h |   4 +
>  fs/smb/client/reparse.c    | 211 +++++++++++++++++++++++++++++++------
>  fs/smb/client/reparse.h    |   2 +
>  5 files changed, 218 insertions(+), 33 deletions(-)
>
> --
> 2.20.1
>
>


-- 
Thanks,

Steve





[Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux