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:
Yan, Zheng 2016-05-10 19:09:06 +08:00 committed by Ilya Dryomov
parent 6ce026e411
commit f0b33df57a
1 changed files with 15 additions and 13 deletions

View File

@ -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;