Re: Streams support in Linux

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

 



On Sat, Aug 25, 2018 at 07:00:26PM +0100, Al Viro wrote:
> > > Where do dentries of these things belong, anyway?
> > 
> > Do streams have to have dentries?  They don't have names in the hierarchy.
> > Can they share their parent's dentry?  Can they have a NULL dentry?  Or
> > a magic dentry of some kind?
> 
> If you want them as opened files - yes, they have to, no, they can't and no,
> they can't.

I was hoping for something like alloc_file_pseudo() rather than having
real dentries in the dentry tree.

> > > > unlinkat()
> > > > This is how you remove an individual named stream
> > > 
> > > Yeah... and what happens to access via other hardlinks to the same parent
> > > file?
> > 
> > I'm not sure I understand the problem here.  You have, say /a/b/c
> > and /d which refer to the same inode.  This inode has streams x and y.
> > If you unlinkat() /a/b/c::x then it is no longer openable.  Any currently
> > existing open fds for x keep x alive until the last one is closed, no
> > matter which path was used to open them.
> 
> Again, where it the tree would the dentries live?  And I really hope you are
> not suggesting to reserve '::' - not when we have files like
> /usr/share/man/man3/Params::Check.3perl.gz
> just to pull a random line out of locate :: output here...

I was just using '::' as shorthand for this email.  Just to be clear,
there's no intent to have these streams in the filesystem namespace.

> > > > Unlinking a file with named streams removes all named streams from that
> > > > file and then unlinks the file.  Open streams will continue to exist in
> > > > the filesystem until they are closed, just as unlinked files do.
> > > 
> > > Can they be looked up by openat() from such a starting point?
> > 
> > No, you can't use openat() on a stream fd.  I should have been clearer
> > on that above; this proposal should have split the syscall list in two;
> > one for how the syscall behaves on a fd-for-a-file-with-streams and one
> > for how the syscall behaves on a stream-fd.
> 
> I'm not suggesting passing a stream fd as the starting point; just a normal
> opened-and-then-unlinked regular file.

Ah, I see your point.  I think that it makes most sense to define the
semantics of an open-but-unlinked file that you can create new streams,
delete existing streams and rename streams until the last reference to
that file are gone, and all references to streams within a file count
as a reference on that file.  Does that make sense?

> > Right, but that code also assumes it's dealing with files.
> 
> I'm looking forward to your analysis of all code related to dentry tree,
> with an eye towards the places where such asserts are quietly made...

I really was hoping not to change the dentry tree at all.



[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]

  Powered by Linux