提交 809f9016 编写于 作者: F Filipe Manana 提交者: Chris Mason

Btrfs: make sure we retry if page is a retriable exception

In inode.c:btrfs_page_exists_in_range(), if the page we get from the
radix tree is an exception which should make us retry, set page to
NULL in order to really retry, because otherwise we don't get another
loop iteration executed (page != NULL makes the while loop exit).
This also was making us call page_cache_release after exiting the loop,
which isn't correct because page doesn't point to a valid page, and
possibly return true from the function when we shouldn't.
Signed-off-by: NFilipe David Borba Manana <fdmanana@gmail.com>
Signed-off-by: NChris Mason <clm@fb.com>
上级 91405151
...@@ -6767,8 +6767,10 @@ bool btrfs_page_exists_in_range(struct inode *inode, loff_t start, loff_t end) ...@@ -6767,8 +6767,10 @@ bool btrfs_page_exists_in_range(struct inode *inode, loff_t start, loff_t end)
break; break;
if (radix_tree_exception(page)) { if (radix_tree_exception(page)) {
if (radix_tree_deref_retry(page)) if (radix_tree_deref_retry(page)) {
page = NULL;
continue; continue;
}
/* /*
* Otherwise, shmem/tmpfs must be storing a swap entry * Otherwise, shmem/tmpfs must be storing a swap entry
* here as an exceptional entry: so return it without * here as an exceptional entry: so return it without
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册