ceph: handle -EAGAIN returned by ceph_update_writeable_page()
when ceph_update_writeable_page() return -EAGAIN, caller should lock the page and call ceph_update_writeable_page() again. Signed-off-by: Yan, Zheng <zyan@redhat.com>
This commit is contained in:
parent
6ce026e411
commit
f0b33df57a
|
@ -1475,12 +1475,13 @@ static int ceph_page_mkwrite(struct vm_area_struct *vma, struct vm_fault *vmf)
|
||||||
/* Update time before taking page lock */
|
/* Update time before taking page lock */
|
||||||
file_update_time(vma->vm_file);
|
file_update_time(vma->vm_file);
|
||||||
|
|
||||||
|
do {
|
||||||
lock_page(page);
|
lock_page(page);
|
||||||
|
|
||||||
if ((off > size) || (page->mapping != inode->i_mapping)) {
|
if ((off > size) || (page->mapping != inode->i_mapping)) {
|
||||||
unlock_page(page);
|
unlock_page(page);
|
||||||
ret = VM_FAULT_NOPAGE;
|
ret = VM_FAULT_NOPAGE;
|
||||||
goto out;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = ceph_update_writeable_page(vma->vm_file, off, len, page);
|
ret = ceph_update_writeable_page(vma->vm_file, off, len, page);
|
||||||
|
@ -1489,7 +1490,8 @@ static int ceph_page_mkwrite(struct vm_area_struct *vma, struct vm_fault *vmf)
|
||||||
set_page_dirty(page);
|
set_page_dirty(page);
|
||||||
ret = VM_FAULT_LOCKED;
|
ret = VM_FAULT_LOCKED;
|
||||||
}
|
}
|
||||||
out:
|
} while (ret == -EAGAIN);
|
||||||
|
|
||||||
if (ret == VM_FAULT_LOCKED ||
|
if (ret == VM_FAULT_LOCKED ||
|
||||||
ci->i_inline_version != CEPH_INLINE_NONE) {
|
ci->i_inline_version != CEPH_INLINE_NONE) {
|
||||||
int dirty;
|
int dirty;
|
||||||
|
|
Loading…
Reference in New Issue