Commit 99a01bd6 authored by David Sterba's avatar David Sterba

btrfs: use btrfs_inode inside compress_file_range

The function is mostly using internal interfaces so we should use the
btrfs_inode.
Reviewed-by: default avatarAnand Jain <anand.jain@oracle.com>
Signed-off-by: default avatarDavid Sterba <dsterba@suse.com>
parent 99a81a44
...@@ -648,8 +648,8 @@ static inline void inode_should_defrag(struct btrfs_inode *inode, ...@@ -648,8 +648,8 @@ static inline void inode_should_defrag(struct btrfs_inode *inode,
*/ */
static noinline int compress_file_range(struct async_chunk *async_chunk) static noinline int compress_file_range(struct async_chunk *async_chunk)
{ {
struct inode *inode = &async_chunk->inode->vfs_inode; struct btrfs_inode *inode = async_chunk->inode;
struct btrfs_fs_info *fs_info = btrfs_sb(inode->i_sb); struct btrfs_fs_info *fs_info = inode->root->fs_info;
u64 blocksize = fs_info->sectorsize; u64 blocksize = fs_info->sectorsize;
u64 start = async_chunk->start; u64 start = async_chunk->start;
u64 end = async_chunk->end; u64 end = async_chunk->end;
...@@ -666,8 +666,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -666,8 +666,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
int compressed_extents = 0; int compressed_extents = 0;
int redirty = 0; int redirty = 0;
inode_should_defrag(BTRFS_I(inode), start, end, end - start + 1, inode_should_defrag(inode, start, end, end - start + 1, SZ_16K);
SZ_16K);
/* /*
* We need to save i_size before now because it could change in between * We need to save i_size before now because it could change in between
...@@ -679,7 +678,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -679,7 +678,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
* does that for us. * does that for us.
*/ */
barrier(); barrier();
i_size = i_size_read(inode); i_size = i_size_read(&inode->vfs_inode);
barrier(); barrier();
actual_end = min_t(u64, i_size, end + 1); actual_end = min_t(u64, i_size, end + 1);
again: again:
...@@ -708,7 +707,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -708,7 +707,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
* isn't an inline extent, since it doesn't save disk space at all. * isn't an inline extent, since it doesn't save disk space at all.
*/ */
if (total_compressed <= blocksize && if (total_compressed <= blocksize &&
(start > 0 || end + 1 < BTRFS_I(inode)->disk_i_size)) (start > 0 || end + 1 < inode->disk_i_size))
goto cleanup_and_bail_uncompressed; goto cleanup_and_bail_uncompressed;
/* /*
...@@ -732,7 +731,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -732,7 +731,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
* inode has not been flagged as nocompress. This flag can * inode has not been flagged as nocompress. This flag can
* change at any time if we discover bad compression ratios. * change at any time if we discover bad compression ratios.
*/ */
if (inode_need_compress(BTRFS_I(inode), start, end)) { if (inode_need_compress(inode, start, end)) {
WARN_ON(pages); WARN_ON(pages);
pages = kcalloc(nr_pages, sizeof(struct page *), GFP_NOFS); pages = kcalloc(nr_pages, sizeof(struct page *), GFP_NOFS);
if (!pages) { if (!pages) {
...@@ -741,10 +740,10 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -741,10 +740,10 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
goto cont; goto cont;
} }
if (BTRFS_I(inode)->defrag_compress) if (inode->defrag_compress)
compress_type = BTRFS_I(inode)->defrag_compress; compress_type = inode->defrag_compress;
else if (BTRFS_I(inode)->prop_compress) else if (inode->prop_compress)
compress_type = BTRFS_I(inode)->prop_compress; compress_type = inode->prop_compress;
/* /*
* we need to call clear_page_dirty_for_io on each * we need to call clear_page_dirty_for_io on each
...@@ -759,14 +758,14 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -759,14 +758,14 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
* has moved, the end is the original one. * has moved, the end is the original one.
*/ */
if (!redirty) { if (!redirty) {
extent_range_clear_dirty_for_io(inode, start, end); extent_range_clear_dirty_for_io(&inode->vfs_inode, start, end);
redirty = 1; redirty = 1;
} }
/* Compression level is applied here and only here */ /* Compression level is applied here and only here */
ret = btrfs_compress_pages( ret = btrfs_compress_pages(
compress_type | (fs_info->compress_level << 4), compress_type | (fs_info->compress_level << 4),
inode->i_mapping, start, inode->vfs_inode.i_mapping, start,
pages, pages,
&nr_pages, &nr_pages,
&total_in, &total_in,
...@@ -795,12 +794,12 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -795,12 +794,12 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
/* we didn't compress the entire range, try /* we didn't compress the entire range, try
* to make an uncompressed inline extent. * to make an uncompressed inline extent.
*/ */
ret = cow_file_range_inline(BTRFS_I(inode), actual_end, ret = cow_file_range_inline(inode, actual_end,
0, BTRFS_COMPRESS_NONE, 0, BTRFS_COMPRESS_NONE,
NULL, false); NULL, false);
} else { } else {
/* try making a compressed inline extent */ /* try making a compressed inline extent */
ret = cow_file_range_inline(BTRFS_I(inode), actual_end, ret = cow_file_range_inline(inode, actual_end,
total_compressed, total_compressed,
compress_type, pages, compress_type, pages,
false); false);
...@@ -823,7 +822,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -823,7 +822,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
* our outstanding extent for clearing delalloc for this * our outstanding extent for clearing delalloc for this
* range. * range.
*/ */
extent_clear_unlock_delalloc(BTRFS_I(inode), start, end, extent_clear_unlock_delalloc(inode, start, end,
NULL, NULL,
clear_flags, clear_flags,
PAGE_UNLOCK | PAGE_UNLOCK |
...@@ -898,8 +897,8 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -898,8 +897,8 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
/* flag the file so we don't compress in the future */ /* flag the file so we don't compress in the future */
if (!btrfs_test_opt(fs_info, FORCE_COMPRESS) && if (!btrfs_test_opt(fs_info, FORCE_COMPRESS) &&
!(BTRFS_I(inode)->prop_compress)) { !(inode->prop_compress)) {
BTRFS_I(inode)->flags |= BTRFS_INODE_NOCOMPRESS; inode->flags |= BTRFS_INODE_NOCOMPRESS;
} }
} }
cleanup_and_bail_uncompressed: cleanup_and_bail_uncompressed:
...@@ -917,7 +916,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk) ...@@ -917,7 +916,7 @@ static noinline int compress_file_range(struct async_chunk *async_chunk)
} }
if (redirty) if (redirty)
extent_range_redirty_for_io(inode, start, end); extent_range_redirty_for_io(&inode->vfs_inode, start, end);
add_async_extent(async_chunk, start, end - start + 1, 0, NULL, 0, add_async_extent(async_chunk, start, end - start + 1, 0, NULL, 0,
BTRFS_COMPRESS_NONE); BTRFS_COMPRESS_NONE);
compressed_extents++; compressed_extents++;
......
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