Commit 600b6cf4 authored by David Sterba's avatar David Sterba

btrfs: replace async_cow::root with fs_info

The async_cow::root is used to propagate fs_info to async_cow_submit.
We can't use inode to reach it because it could become NULL after
write without compression in async_cow_start.
Reviewed-by: default avatarNikolay Borisov <nborisov@suse.com>
Reviewed-by: default avatarJohannes Thumshirn <jthumshirn@suse.de>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 06ea01b1
...@@ -358,7 +358,7 @@ struct async_extent { ...@@ -358,7 +358,7 @@ struct async_extent {
struct async_cow { struct async_cow {
struct inode *inode; struct inode *inode;
struct btrfs_root *root; struct btrfs_fs_info *fs_info;
struct page *locked_page; struct page *locked_page;
u64 start; u64 start;
u64 end; u64 end;
...@@ -1144,13 +1144,11 @@ static noinline void async_cow_submit(struct btrfs_work *work) ...@@ -1144,13 +1144,11 @@ static noinline void async_cow_submit(struct btrfs_work *work)
{ {
struct btrfs_fs_info *fs_info; struct btrfs_fs_info *fs_info;
struct async_cow *async_cow; struct async_cow *async_cow;
struct btrfs_root *root;
unsigned long nr_pages; unsigned long nr_pages;
async_cow = container_of(work, struct async_cow, work); async_cow = container_of(work, struct async_cow, work);
root = async_cow->root; fs_info = async_cow->fs_info;
fs_info = root->fs_info;
nr_pages = (async_cow->end - async_cow->start + PAGE_SIZE) >> nr_pages = (async_cow->end - async_cow->start + PAGE_SIZE) >>
PAGE_SHIFT; PAGE_SHIFT;
...@@ -1179,7 +1177,6 @@ static int cow_file_range_async(struct inode *inode, struct page *locked_page, ...@@ -1179,7 +1177,6 @@ static int cow_file_range_async(struct inode *inode, struct page *locked_page,
{ {
struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb); struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb);
struct async_cow *async_cow; struct async_cow *async_cow;
struct btrfs_root *root = BTRFS_I(inode)->root;
unsigned long nr_pages; unsigned long nr_pages;
u64 cur_end; u64 cur_end;
...@@ -1189,7 +1186,7 @@ static int cow_file_range_async(struct inode *inode, struct page *locked_page, ...@@ -1189,7 +1186,7 @@ static int cow_file_range_async(struct inode *inode, struct page *locked_page,
async_cow = kmalloc(sizeof(*async_cow), GFP_NOFS); async_cow = kmalloc(sizeof(*async_cow), GFP_NOFS);
BUG_ON(!async_cow); /* -ENOMEM */ BUG_ON(!async_cow); /* -ENOMEM */
async_cow->inode = igrab(inode); async_cow->inode = igrab(inode);
async_cow->root = root; async_cow->fs_info = fs_info;
async_cow->locked_page = locked_page; async_cow->locked_page = locked_page;
async_cow->start = start; async_cow->start = start;
async_cow->write_flags = write_flags; async_cow->write_flags = write_flags;
......
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