aboutsummaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_vnodeops.c
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@infradead.org>2007-08-27 23:58:24 -0400
committerTim Shimmin <tes@chook.melbourne.sgi.com>2007-10-15 02:49:49 -0400
commit051e7cd44ab8f0f7c2958371485b4a1ff64a8d1b (patch)
tree23389d878944e0566effed4eb2de4c1ed5fed96e /fs/xfs/xfs_vnodeops.c
parent2bdf7cd0baa67608ada1517a281af359faf4c58c (diff)
[XFS] use filldir internally
Currently xfs has a rather complicated internal scheme to allow for different directory formats in IRIX. This patch rips all code related to this out and pushes useage of the Linux filldir callback into the lowlevel directory code. This does not make the code any less portable because filldir can be used to create dirents of all possible variations (including the IRIX ones as proved by the IRIX binary emulation code under arch/mips/). This patch get rid of an unessecary copy in the readdir path, about 400 lines of code and one of the last two users of the uio structure. This version is updated to deal with dmapi aswell which greatly simplifies the get_dirattrs code. The dmapi part has been tested using the get_dirattrs tools from the xfstest dmapi suite1 with various small and large directories. SGI-PV: 968563 SGI-Modid: xfs-linux-melb:xfs-kern:29478a Signed-off-by: Christoph Hellwig <hch@infradead.org> Signed-off-by: David Chinner <dgc@sgi.com> Signed-off-by: Tim Shimmin <tes@sgi.com>
Diffstat (limited to 'fs/xfs/xfs_vnodeops.c')
-rw-r--r--fs/xfs/xfs_vnodeops.c31
1 files changed, 0 insertions, 31 deletions
diff --git a/fs/xfs/xfs_vnodeops.c b/fs/xfs/xfs_vnodeops.c
index 0116ce1ad59e..36318c66a7bf 100644
--- a/fs/xfs/xfs_vnodeops.c
+++ b/fs/xfs/xfs_vnodeops.c
@@ -3284,37 +3284,6 @@ xfs_rmdir(
3284 goto std_return; 3284 goto std_return;
3285} 3285}
3286 3286
3287
3288/*
3289 * Read dp's entries starting at uiop->uio_offset and translate them into
3290 * bufsize bytes worth of struct dirents starting at bufbase.
3291 */
3292STATIC int
3293xfs_readdir(
3294 bhv_desc_t *dir_bdp,
3295 uio_t *uiop,
3296 cred_t *credp,
3297 int *eofp)
3298{
3299 xfs_inode_t *dp;
3300 xfs_trans_t *tp = NULL;
3301 int error = 0;
3302 uint lock_mode;
3303
3304 vn_trace_entry(BHV_TO_VNODE(dir_bdp), __FUNCTION__,
3305 (inst_t *)__return_address);
3306 dp = XFS_BHVTOI(dir_bdp);
3307
3308 if (XFS_FORCED_SHUTDOWN(dp->i_mount))
3309 return XFS_ERROR(EIO);
3310
3311 lock_mode = xfs_ilock_map_shared(dp);
3312 error = xfs_dir_getdents(tp, dp, uiop, eofp);
3313 xfs_iunlock_map_shared(dp, lock_mode);
3314 return error;
3315}
3316
3317
3318STATIC int 3287STATIC int
3319xfs_symlink( 3288xfs_symlink(
3320 bhv_desc_t *dir_bdp, 3289 bhv_desc_t *dir_bdp,