Re: [PATCH] ceph: Add FScache support

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

 



On Tue, Jul 9, 2013 at 6:33 AM, David Howells <dhowells@xxxxxxxxxx> wrote:
> Milosz Tanski <milosz@xxxxxxxxx> wrote:
>
>> It looks like both the cifs and NFS code do not bother with any
>> locking around cifs_fscache_set_inode_cookie. Is there no concern over
>> multiple open() calls racing to create the cookie in those
>> filesystems?
>
> Yeah...  That's probably wrong.  AFS obviates the need for special locking by
> doing it in afs_iget().

I'm going to create a mutex around the enable cache / disable cache in
the Ceph code since the spinlock is also right now.

>
> Hmmm...  I think I've just spotted what might be the cause of pages getting
> marked PG_fscache whilst belonging to the allocator.
>
>         void nfs_fscache_set_inode_cookie(struct inode *inode, struct file *filp)
>         {
>                 if (NFS_FSCACHE(inode)) {
>                         nfs_fscache_inode_lock(inode);
>                         if ((filp->f_flags & O_ACCMODE) != O_RDONLY)
>                                 nfs_fscache_disable_inode_cookie(inode);
>                         else
>                                 nfs_fscache_enable_inode_cookie(inode);
>                         nfs_fscache_inode_unlock(inode);
>                 }
>         }
>
> can release the cookie whilst reads are in progress on it when an inode being
> read suddenly changes to an inode being written.  We need some sort of
> synchronisation on that there.

So far my experience has been that synchronization has been the most
tricky part of implementing fscache for Ceph. Things work great when
there's a simple shell accessing data and break down when you're doing
a HPC kind of workload.

>
> David

--
Linux-cachefs mailing list
Linux-cachefs@xxxxxxxxxx
https://www.redhat.com/mailman/listinfo/linux-cachefs




[Index of Archives]     [LARTC]     [Bugtraq]     [Yosemite Forum]
  Powered by Linux