diff options
author | Christoph Hellwig <hch@lst.de> | 2007-10-21 19:42:05 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-22 11:13:19 -0400 |
commit | 2596110a3994593f6aa3e2bb76345ad4791b1a14 (patch) | |
tree | 0f1773238265f83e1b5640256176851a60ff5ea8 /include/linux | |
parent | 6e91ea2bb0b6a3ddf6d4faeb54a9c20d4e20bc42 (diff) |
exportfs: add new methods
Add the guts for the new filesystem API to exportfs.
There's now a fh_to_dentry method that returns a dentry for the object looked
for given a filehandle fragment, and a fh_to_parent operation that returns the
dentry for the encoded parent directory in case the file handle contains it.
There are default implementations for these methods that only take a callback
for an nfs-enhanced iget variant and implement the rest of the semantics.
Signed-off-by: Christoph Hellwig <hch@lst.de>
Cc: Neil Brown <neilb@suse.de>
Cc: "J. Bruce Fields" <bfields@fieldses.org>
Cc: <linux-ext4@vger.kernel.org>
Cc: Dave Kleikamp <shaggy@austin.ibm.com>
Cc: Anton Altaparmakov <aia21@cantab.net>
Cc: David Chinner <dgc@sgi.com>
Cc: Timothy Shimmin <tes@sgi.com>
Cc: OGAWA Hirofumi <hirofumi@mail.parknet.co.jp>
Cc: Hugh Dickins <hugh@veritas.com>
Cc: Chris Mason <mason@suse.com>
Cc: Jeff Mahoney <jeffm@suse.com>
Cc: "Vladimir V. Saveliev" <vs@namesys.com>
Cc: Steven Whitehouse <swhiteho@redhat.com>
Cc: Mark Fasheh <mark.fasheh@oracle.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/exportfs.h | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/include/linux/exportfs.h b/include/linux/exportfs.h index 06178a1336ff..b44f6b6871c8 100644 --- a/include/linux/exportfs.h +++ b/include/linux/exportfs.h | |||
@@ -4,6 +4,7 @@ | |||
4 | #include <linux/types.h> | 4 | #include <linux/types.h> |
5 | 5 | ||
6 | struct dentry; | 6 | struct dentry; |
7 | struct inode; | ||
7 | struct super_block; | 8 | struct super_block; |
8 | struct vfsmount; | 9 | struct vfsmount; |
9 | 10 | ||
@@ -101,6 +102,21 @@ struct fid { | |||
101 | * the filehandle fragment. encode_fh() should return the number of bytes | 102 | * the filehandle fragment. encode_fh() should return the number of bytes |
102 | * stored or a negative error code such as %-ENOSPC | 103 | * stored or a negative error code such as %-ENOSPC |
103 | * | 104 | * |
105 | * fh_to_dentry: | ||
106 | * @fh_to_dentry is given a &struct super_block (@sb) and a file handle | ||
107 | * fragment (@fh, @fh_len). It should return a &struct dentry which refers | ||
108 | * to the same file that the file handle fragment refers to. If it cannot, | ||
109 | * it should return a %NULL pointer if the file was found but no acceptable | ||
110 | * &dentries were available, or an %ERR_PTR error code indicating why it | ||
111 | * couldn't be found (e.g. %ENOENT or %ENOMEM). Any suitable dentry can be | ||
112 | * returned including, if necessary, a new dentry created with d_alloc_root. | ||
113 | * The caller can then find any other extant dentries by following the | ||
114 | * d_alias links. | ||
115 | * | ||
116 | * fh_to_parent: | ||
117 | * Same as @fh_to_dentry, except that it returns a pointer to the parent | ||
118 | * dentry if it was encoded into the filehandle fragment by @encode_fh. | ||
119 | * | ||
104 | * get_name: | 120 | * get_name: |
105 | * @get_name should find a name for the given @child in the given @parent | 121 | * @get_name should find a name for the given @child in the given @parent |
106 | * directory. The name should be stored in the @name (with the | 122 | * directory. The name should be stored in the @name (with the |
@@ -139,6 +155,10 @@ struct export_operations { | |||
139 | void *context); | 155 | void *context); |
140 | int (*encode_fh)(struct dentry *de, __u32 *fh, int *max_len, | 156 | int (*encode_fh)(struct dentry *de, __u32 *fh, int *max_len, |
141 | int connectable); | 157 | int connectable); |
158 | struct dentry * (*fh_to_dentry)(struct super_block *sb, struct fid *fid, | ||
159 | int fh_len, int fh_type); | ||
160 | struct dentry * (*fh_to_parent)(struct super_block *sb, struct fid *fid, | ||
161 | int fh_len, int fh_type); | ||
142 | int (*get_name)(struct dentry *parent, char *name, | 162 | int (*get_name)(struct dentry *parent, char *name, |
143 | struct dentry *child); | 163 | struct dentry *child); |
144 | struct dentry * (*get_parent)(struct dentry *child); | 164 | struct dentry * (*get_parent)(struct dentry *child); |
@@ -161,4 +181,14 @@ extern struct dentry *exportfs_decode_fh(struct vfsmount *mnt, struct fid *fid, | |||
161 | int fh_len, int fileid_type, int (*acceptable)(void *, struct dentry *), | 181 | int fh_len, int fileid_type, int (*acceptable)(void *, struct dentry *), |
162 | void *context); | 182 | void *context); |
163 | 183 | ||
184 | /* | ||
185 | * Generic helpers for filesystems. | ||
186 | */ | ||
187 | extern struct dentry *generic_fh_to_dentry(struct super_block *sb, | ||
188 | struct fid *fid, int fh_len, int fh_type, | ||
189 | struct inode *(*get_inode) (struct super_block *sb, u64 ino, u32 gen)); | ||
190 | extern struct dentry *generic_fh_to_parent(struct super_block *sb, | ||
191 | struct fid *fid, int fh_len, int fh_type, | ||
192 | struct inode *(*get_inode) (struct super_block *sb, u64 ino, u32 gen)); | ||
193 | |||
164 | #endif /* LINUX_EXPORTFS_H */ | 194 | #endif /* LINUX_EXPORTFS_H */ |