提交 afae457d 编写于 作者: D David Howells

afs: Fix missing error handling in afs_write_end()

afs_write_end() is missing page unlock and put if afs_fill_page() fails.
Reported-by: NAl Viro <viro@zeniv.linux.org.uk>
Signed-off-by: NDavid Howells <dhowells@redhat.com>
上级 440fbc3a
...@@ -198,7 +198,7 @@ int afs_write_end(struct file *file, struct address_space *mapping, ...@@ -198,7 +198,7 @@ int afs_write_end(struct file *file, struct address_space *mapping,
ret = afs_fill_page(vnode, key, pos + copied, ret = afs_fill_page(vnode, key, pos + copied,
len - copied, page); len - copied, page);
if (ret < 0) if (ret < 0)
return ret; goto out;
} }
SetPageUptodate(page); SetPageUptodate(page);
} }
...@@ -206,10 +206,12 @@ int afs_write_end(struct file *file, struct address_space *mapping, ...@@ -206,10 +206,12 @@ int afs_write_end(struct file *file, struct address_space *mapping,
set_page_dirty(page); set_page_dirty(page);
if (PageDirty(page)) if (PageDirty(page))
_debug("dirtied"); _debug("dirtied");
ret = copied;
out:
unlock_page(page); unlock_page(page);
put_page(page); put_page(page);
return ret;
return copied;
} }
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册