diff options
Diffstat (limited to 'fs/xfs/xfs_dfrag.c')
-rw-r--r-- | fs/xfs/xfs_dfrag.c | 38 |
1 files changed, 22 insertions, 16 deletions
diff --git a/fs/xfs/xfs_dfrag.c b/fs/xfs/xfs_dfrag.c index f25e54027d10..cd27c9d6c71f 100644 --- a/fs/xfs/xfs_dfrag.c +++ b/fs/xfs/xfs_dfrag.c | |||
@@ -45,15 +45,21 @@ | |||
45 | #include "xfs_vnodeops.h" | 45 | #include "xfs_vnodeops.h" |
46 | #include "xfs_trace.h" | 46 | #include "xfs_trace.h" |
47 | 47 | ||
48 | |||
49 | static int xfs_swap_extents( | ||
50 | xfs_inode_t *ip, /* target inode */ | ||
51 | xfs_inode_t *tip, /* tmp inode */ | ||
52 | xfs_swapext_t *sxp); | ||
53 | |||
48 | /* | 54 | /* |
49 | * Syssgi interface for swapext | 55 | * ioctl interface for swapext |
50 | */ | 56 | */ |
51 | int | 57 | int |
52 | xfs_swapext( | 58 | xfs_swapext( |
53 | xfs_swapext_t *sxp) | 59 | xfs_swapext_t *sxp) |
54 | { | 60 | { |
55 | xfs_inode_t *ip, *tip; | 61 | xfs_inode_t *ip, *tip; |
56 | struct file *file, *target_file; | 62 | struct file *file, *tmp_file; |
57 | int error = 0; | 63 | int error = 0; |
58 | 64 | ||
59 | /* Pull information for the target fd */ | 65 | /* Pull information for the target fd */ |
@@ -68,46 +74,46 @@ xfs_swapext( | |||
68 | goto out_put_file; | 74 | goto out_put_file; |
69 | } | 75 | } |
70 | 76 | ||
71 | target_file = fget((int)sxp->sx_fdtmp); | 77 | tmp_file = fget((int)sxp->sx_fdtmp); |
72 | if (!target_file) { | 78 | if (!tmp_file) { |
73 | error = XFS_ERROR(EINVAL); | 79 | error = XFS_ERROR(EINVAL); |
74 | goto out_put_file; | 80 | goto out_put_file; |
75 | } | 81 | } |
76 | 82 | ||
77 | if (!(target_file->f_mode & FMODE_WRITE) || | 83 | if (!(tmp_file->f_mode & FMODE_WRITE) || |
78 | (target_file->f_flags & O_APPEND)) { | 84 | (tmp_file->f_flags & O_APPEND)) { |
79 | error = XFS_ERROR(EBADF); | 85 | error = XFS_ERROR(EBADF); |
80 | goto out_put_target_file; | 86 | goto out_put_tmp_file; |
81 | } | 87 | } |
82 | 88 | ||
83 | if (IS_SWAPFILE(file->f_path.dentry->d_inode) || | 89 | if (IS_SWAPFILE(file->f_path.dentry->d_inode) || |
84 | IS_SWAPFILE(target_file->f_path.dentry->d_inode)) { | 90 | IS_SWAPFILE(tmp_file->f_path.dentry->d_inode)) { |
85 | error = XFS_ERROR(EINVAL); | 91 | error = XFS_ERROR(EINVAL); |
86 | goto out_put_target_file; | 92 | goto out_put_tmp_file; |
87 | } | 93 | } |
88 | 94 | ||
89 | ip = XFS_I(file->f_path.dentry->d_inode); | 95 | ip = XFS_I(file->f_path.dentry->d_inode); |
90 | tip = XFS_I(target_file->f_path.dentry->d_inode); | 96 | tip = XFS_I(tmp_file->f_path.dentry->d_inode); |
91 | 97 | ||
92 | if (ip->i_mount != tip->i_mount) { | 98 | if (ip->i_mount != tip->i_mount) { |
93 | error = XFS_ERROR(EINVAL); | 99 | error = XFS_ERROR(EINVAL); |
94 | goto out_put_target_file; | 100 | goto out_put_tmp_file; |
95 | } | 101 | } |
96 | 102 | ||
97 | if (ip->i_ino == tip->i_ino) { | 103 | if (ip->i_ino == tip->i_ino) { |
98 | error = XFS_ERROR(EINVAL); | 104 | error = XFS_ERROR(EINVAL); |
99 | goto out_put_target_file; | 105 | goto out_put_tmp_file; |
100 | } | 106 | } |
101 | 107 | ||
102 | if (XFS_FORCED_SHUTDOWN(ip->i_mount)) { | 108 | if (XFS_FORCED_SHUTDOWN(ip->i_mount)) { |
103 | error = XFS_ERROR(EIO); | 109 | error = XFS_ERROR(EIO); |
104 | goto out_put_target_file; | 110 | goto out_put_tmp_file; |
105 | } | 111 | } |
106 | 112 | ||
107 | error = xfs_swap_extents(ip, tip, sxp); | 113 | error = xfs_swap_extents(ip, tip, sxp); |
108 | 114 | ||
109 | out_put_target_file: | 115 | out_put_tmp_file: |
110 | fput(target_file); | 116 | fput(tmp_file); |
111 | out_put_file: | 117 | out_put_file: |
112 | fput(file); | 118 | fput(file); |
113 | out: | 119 | out: |
@@ -186,7 +192,7 @@ xfs_swap_extents_check_format( | |||
186 | return 0; | 192 | return 0; |
187 | } | 193 | } |
188 | 194 | ||
189 | int | 195 | static int |
190 | xfs_swap_extents( | 196 | xfs_swap_extents( |
191 | xfs_inode_t *ip, /* target inode */ | 197 | xfs_inode_t *ip, /* target inode */ |
192 | xfs_inode_t *tip, /* tmp inode */ | 198 | xfs_inode_t *tip, /* tmp inode */ |