Commit 30379f45 authored by majianpeng's avatar majianpeng Committed by Greg Kroah-Hartman

ceph: allow sync_read/write return partial successed size of read/write.

commit ee7289bf upstream.

For sync_read/write, it may do multi stripe operations.If one of those
met erro, we return the former successed size rather than a error value.
There is a exception for write-operation met -EOLDSNAPC.If this occur,we
retry the whole write again.
Signed-off-by: default avatarJianpeng Ma <majianpeng@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 533bc295
......@@ -373,7 +373,7 @@ static int striped_read(struct inode *inode,
goto more;
}
if (ret >= 0) {
if (read > 0) {
ret = read;
/* did we bounce off eof? */
if (pos + left > inode->i_size)
......@@ -611,6 +611,8 @@ static ssize_t ceph_sync_write(struct file *file, const char __user *data,
if (check_caps)
ceph_check_caps(ceph_inode(inode), CHECK_CAPS_AUTHONLY,
NULL);
} else if (ret != -EOLDSNAPC && written > 0) {
ret = written;
}
return ret;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment