diff options
author | Akira Fujita <a-fujita@rs.jp.nec.com> | 2009-09-05 22:46:29 -0400 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2009-09-05 22:46:29 -0400 |
commit | 8d6669133d8cdbb7cbe0e1f0f3744e7802a84afe (patch) | |
tree | ab4799f9299037ecb41de56bc1ad0b8c946c30f0 /fs/ext4/ioctl.c | |
parent | daea696dbac0e33af3cfe304efbfb8d74e0effe6 (diff) | |
download | op-kernel-dev-8d6669133d8cdbb7cbe0e1f0f3744e7802a84afe.zip op-kernel-dev-8d6669133d8cdbb7cbe0e1f0f3744e7802a84afe.tar.gz |
ext4: Return exchanged blocks count to user space in failure
Return exchanged blocks count (moved_len) to user space,
if ext4_move_extents() failed on the way.
Signed-off-by: Akira Fujita <a-fujita@rs.jp.nec.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs/ext4/ioctl.c')
-rw-r--r-- | fs/ext4/ioctl.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/fs/ext4/ioctl.c b/fs/ext4/ioctl.c index 7050a9c..c1cdf61 100644 --- a/fs/ext4/ioctl.c +++ b/fs/ext4/ioctl.c @@ -243,10 +243,9 @@ setversion_out: me.donor_start, me.len, &me.moved_len); fput(donor_filp); - if (!err) - if (copy_to_user((struct move_extent *)arg, - &me, sizeof(me))) - return -EFAULT; + if (copy_to_user((struct move_extent *)arg, &me, sizeof(me))) + return -EFAULT; + return err; } |