Re: Re: Re: [1/8] readdir-plus system call - LSF/MM follow up

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

 



On Tuesday, May 28, 2013 09:47:01 Frank S Filz wrote:
> Jim Lieb <jlieb@xxxxxxxxxxx> wrote on 05/28/2013 08:13:02 AM:
> > On Tuesday, May 28, 2013 10:49:31 Abhijith Das wrote:
> > > Zack, thanks for taking a peek at the patches.
> > > 
> > > > Some quick things that struck me as I glanced through the patches:
> > > > 
> > > > - Please post the patch series, don't make us go digging through
> > > > 
> > > >   bugzilla.
> > > 
> > > Duly noted. I wasn't hoping for my patches to be a serious submission,
> 
> just
> 
> > > something I wrote up as a POC. I was mainly looking to (re)start a
> > > conversation about readdirplus to see what's the best way to go about
> 
> doing
> 
> > > this. Your point applies nonetheless; I'll post my patchset again,
> > > properly.
> > 
> > Speaking for the nfs-ganesha project, one of the issues that we couldn't
> 
> sort
> 
> > out at lsf was whether to to include xattrs.  As far as ganesha is
> 
> concerned,
> 
> > the xstat struct is sufficient.  At readdir time, we pretty much just
> 
> want to
> 
> > build our cache entries and get basic stat info.  The only case where
> 
> we'd
> 
> > really need xattrs would be for acls but that is usually later in
> > the protocol
> > op sequence.  I'd just like to get the path from readdir+ thru the
> 
> callbacks
> 
> > to the xdr into the reply as simple as possible.  That and get enough in
> 
> the
> 
> > cache entry to be ready for the next step.
> 
> Actually, ACLs are critical for Ganesha. Unless we decide to have separate
> attr validity bits for "stat" attributes and ACLs, Ganesha will have a
> difficult time knowing if the ACL attribute is up to date (or even
> available).

True enough.  But one of the pushbacks was the amount of work needed to get to 
xattrs where acls live.  One thing I heard that made not having acls on the 
readdir+ pass was a status of some kind that indicated "I have acls..."  The 
readdir is a dir op and so 10k+ entries need to be minimal overhead.  we 
already have the acls of the dir from the lookup.  we don't need an entry's 
acls until we do the lookup on it.  at that time we can grab the acls.  That 
was the argument as I remember and I'm willing to accept it.  IIRC, the client 
is going to send us a getattrs later.  we can do it then.  Is this reasonable?

> 
> > > > - Don't use variable size types in the ABI or you'll have to add
> 
> compat_
> 
> > > >   wrappers to fix it all up on the stack when going between 32bit
> > > >   userspace and 64bit kernelspace.  This is going to be especially
> 
> nasty
> 
> > > >   if this is a giant sequence of variable length blobs.
> > > >   
> > > >   +struct linux_xdirent {
> > > >   +   unsigned long        xd_ino;
> > > >   +   char                 xd_type;
> > > >   +   unsigned long        xd_off;
> > > >   +   struct xstat         xd_stat;
> > > >   +   unsigned long        xd_reclen;
> > > >   +   struct xdirent_blob  xd_blob;
> > > >   +};
> > > >   
> > > >   Notice how, in contrast, David was careful to use naturally aligned
> > > >   fixed-width types in his xstat patch.
> > > 
> > > Yes, you're right. I'll fix this.
> > > 
> > > > - z
> > > 
> > > Cheers!
> > > --Abhi
> > 
> > --
> > Jim Lieb
> > Linux Systems Engineer
> > Panasas Inc.
-- 
Jim Lieb
Linux Systems Engineer
Panasas Inc.
--
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html




[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