diff options
author | Stanislav Kinsbursky <skinsbursky@parallels.com> | 2012-01-10 07:13:19 -0500 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2012-01-31 18:20:27 -0500 |
commit | eee17325f1dfbe004f1475743bab9e3d050d00f5 (patch) | |
tree | ca48905e04e88658cff7d1a745a12ac3c04cfd77 /include/linux/sunrpc | |
parent | 4929d1d33fdbe8385cdd49ccd23563e9ff247ff8 (diff) |
NFS: idmap PipeFS notifier introduced
v2:
1) Added "nfs_idmap_init" and "nfs_idmap_quit" definitions for kernels built
without CONFIG_NFS_V4 option set.
This patch subscribes NFS clients to RPC pipefs notifications. Idmap notifier
is registering on NFS module load. This notifier callback is responsible for
creation/destruction of PipeFS idmap pipe dentry for NFS4 clients.
Since ipdmap pipe is created in rpc client pipefs directory, we have make sure,
that this directory has been created already. IOW RPC client notifier callback
has been called already. To achive this, PipeFS notifier priorities has been
introduced (RPC clients notifier priority is greater than NFS idmap one).
But this approach gives another problem: unlink for RPC client directory will
be called before NFS idmap pipe unlink on UMOUNT event and will fail, because
directory is not empty.
The solution, introduced in this patch, is to try to remove client directory
once again after idmap pipe was unlinked. This looks like ugly hack, so
probably it should be replaced in some more elegant way.
Note that no locking required in notifier callback because PipeFS superblock
pointer is passed as an argument from it's creation or destruction routine and
thus we can be sure about it's validity.
Signed-off-by: Stanislav Kinsbursky <skinsbursky@parallels.com>
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'include/linux/sunrpc')
-rw-r--r-- | include/linux/sunrpc/rpc_pipe_fs.h | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/include/linux/sunrpc/rpc_pipe_fs.h b/include/linux/sunrpc/rpc_pipe_fs.h index 0d1f748f76da..ca32ebd14c18 100644 --- a/include/linux/sunrpc/rpc_pipe_fs.h +++ b/include/linux/sunrpc/rpc_pipe_fs.h | |||
@@ -49,6 +49,11 @@ RPC_I(struct inode *inode) | |||
49 | return container_of(inode, struct rpc_inode, vfs_inode); | 49 | return container_of(inode, struct rpc_inode, vfs_inode); |
50 | } | 50 | } |
51 | 51 | ||
52 | enum { | ||
53 | SUNRPC_PIPEFS_NFS_PRIO, | ||
54 | SUNRPC_PIPEFS_RPC_PRIO, | ||
55 | }; | ||
56 | |||
52 | extern int rpc_pipefs_notifier_register(struct notifier_block *); | 57 | extern int rpc_pipefs_notifier_register(struct notifier_block *); |
53 | extern void rpc_pipefs_notifier_unregister(struct notifier_block *); | 58 | extern void rpc_pipefs_notifier_unregister(struct notifier_block *); |
54 | 59 | ||
@@ -78,6 +83,8 @@ extern struct dentry *rpc_create_cache_dir(struct dentry *, | |||
78 | struct cache_detail *); | 83 | struct cache_detail *); |
79 | extern void rpc_remove_cache_dir(struct dentry *); | 84 | extern void rpc_remove_cache_dir(struct dentry *); |
80 | 85 | ||
86 | extern int rpc_rmdir(struct dentry *dentry); | ||
87 | |||
81 | struct rpc_pipe *rpc_mkpipe_data(const struct rpc_pipe_ops *ops, int flags); | 88 | struct rpc_pipe *rpc_mkpipe_data(const struct rpc_pipe_ops *ops, int flags); |
82 | void rpc_destroy_pipe_data(struct rpc_pipe *pipe); | 89 | void rpc_destroy_pipe_data(struct rpc_pipe *pipe); |
83 | extern struct dentry *rpc_mkpipe_dentry(struct dentry *, const char *, void *, | 90 | extern struct dentry *rpc_mkpipe_dentry(struct dentry *, const char *, void *, |