Re: [PATCH 12/41] union-mount: Allow removal of a directory

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

 



In message <1256152779-10054-13-git-send-email-vaurora@xxxxxxxxxx>, Valerie Aurora writes:
> From: Jan Blunck <jblunck@xxxxxxx>
> 
> do_whiteout() allows removal of a directory when it has whiteouts but
> is logically empty.
> 
> XXX - This patch abuses readdir() to check if the union directory is
> logically empty - that is, all the entries are whiteouts (or "." or
> "..").  Currently, we have no clean VFS interface to ask the lower
> file system if a directory is empty.
> 
> Fixes:
>  - Add ->is_directory_empty() op
>  - Add is_directory_empty flag to dentry (ugly dcache populate)
>  - Ask underlying fs to remove it and look for an error return
>  - (your idea here)

Yeah, this is a difficult issue.  I think the best way would be to

1. add an OPTIONAL ->is_directory_empty() inode op.

2. have the VFS use some default/generic behavior ala filldir_is_empty()
   below if inode->i_op->is_directory_empty is NULL.  I assume this behavior
   will only need to be checked for file systems that support whiteouts in
   the first place.

This'll provide some working behavior for all whiteout-supporting file
systems, but allow anyone who wants to develop a more efficient method to
provide one.

> Signed-off-by: Jan Blunck <jblunck@xxxxxxx>
> Signed-off-by: Valerie Aurora <vaurora@xxxxxxxxxx>
> ---
>  fs/namei.c |   85 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
>  1 files changed, 85 insertions(+), 0 deletions(-)
> 
> diff --git a/fs/namei.c b/fs/namei.c
> index 5da1635..9a62c75 100644
> --- a/fs/namei.c
> +++ b/fs/namei.c
> @@ -2284,6 +2284,91 @@ int vfs_whiteout(struct inode *dir, struct dentry *dentry, int isdir)
>  }
>  
>  /*
> + * This is abusing readdir to check if a union directory is logically empty.
> + * Al Viro barfed when he saw this, but Val said: "Well, at this point I'm
> + * aiming for working, pretty can come later"
> + */
> +static int filldir_is_empty(void *__buf, const char *name, int namlen,
> +			    loff_t offset, u64 ino, unsigned int d_type)
> +{

Why not make filldir_is_empty() return a bool?  That explains more clearly
the function's return code.

> +static int directory_is_empty(struct dentry *dentry, struct vfsmount *mnt)
> +{

This can also return a bool.

> +static int do_whiteout(struct nameidata *nd, struct path *path, int isdir)
> +{

'isdir' can be bool.

> +	struct path safe = { .dentry = dget(nd->path.dentry),
> +			     .mnt = mntget(nd->path.mnt) };
> +	struct dentry *dentry = path->dentry;
> +	int err;

You might want to move the initialization of 'struct path safe' down below,
and add a BUG_ON(!nd) before that.  I think during the development phases of
UM, it's a good idea to have a few more debugging BUG_ON's.

Erez.
--
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