f2fs: fix to avoid triggering IO in write path
authorChao Yu <yuchao0@huawei.com>
Tue, 18 Feb 2020 10:21:35 +0000 (18:21 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Thu, 19 Mar 2020 18:41:26 +0000 (11:41 -0700)
If we are in write IO path, we need to avoid using GFP_KERNEL.

Signed-off-by: Chao Yu <yuchao0@huawei.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/compress.c
fs/f2fs/data.c
fs/f2fs/f2fs.h

index 748933813cd1fa25d5307278d404d447af9b7f2b..bd3ea01db4486fa0e339ddf78418de71d397a515 100644 (file)
@@ -656,7 +656,7 @@ retry:
                struct bio *bio = NULL;
 
                ret = f2fs_read_multi_pages(cc, &bio, cc->cluster_size,
-                                               &last_block_in_bio, false);
+                                       &last_block_in_bio, false, true);
                f2fs_destroy_compress_ctx(cc);
                if (ret)
                        goto release_pages;
index 68da6036cadd9110a04c90e5f7c293a73f31f2b9..9a9391a1790e1cd278cf13d917a5329bd7a7e0c1 100644 (file)
@@ -925,14 +925,15 @@ static inline bool f2fs_need_verity(const struct inode *inode, pgoff_t idx)
 
 static struct bio *f2fs_grab_read_bio(struct inode *inode, block_t blkaddr,
                                      unsigned nr_pages, unsigned op_flag,
-                                     pgoff_t first_idx)
+                                     pgoff_t first_idx, bool for_write)
 {
        struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
        struct bio *bio;
        struct bio_post_read_ctx *ctx;
        unsigned int post_read_steps = 0;
 
-       bio = f2fs_bio_alloc(sbi, min_t(int, nr_pages, BIO_MAX_PAGES), false);
+       bio = f2fs_bio_alloc(sbi, min_t(int, nr_pages, BIO_MAX_PAGES),
+                                                               for_write);
        if (!bio)
                return ERR_PTR(-ENOMEM);
        f2fs_target_device(sbi, blkaddr, bio);
@@ -967,12 +968,12 @@ static void f2fs_release_read_bio(struct bio *bio)
 
 /* This can handle encryption stuffs */
 static int f2fs_submit_page_read(struct inode *inode, struct page *page,
-                                                       block_t blkaddr)
+                                               block_t blkaddr, bool for_write)
 {
        struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
        struct bio *bio;
 
-       bio = f2fs_grab_read_bio(inode, blkaddr, 1, 0, page->index);
+       bio = f2fs_grab_read_bio(inode, blkaddr, 1, 0, page->index, for_write);
        if (IS_ERR(bio))
                return PTR_ERR(bio);
 
@@ -1158,7 +1159,7 @@ got_it:
                return page;
        }
 
-       err = f2fs_submit_page_read(inode, page, dn.data_blkaddr);
+       err = f2fs_submit_page_read(inode, page, dn.data_blkaddr, for_write);
        if (err)
                goto put_err;
        return page;
@@ -1971,7 +1972,8 @@ submit_and_realloc:
        }
        if (bio == NULL) {
                bio = f2fs_grab_read_bio(inode, block_nr, nr_pages,
-                               is_readahead ? REQ_RAHEAD : 0, page->index);
+                               is_readahead ? REQ_RAHEAD : 0, page->index,
+                               false);
                if (IS_ERR(bio)) {
                        ret = PTR_ERR(bio);
                        bio = NULL;
@@ -2006,7 +2008,7 @@ out:
 #ifdef CONFIG_F2FS_FS_COMPRESSION
 int f2fs_read_multi_pages(struct compress_ctx *cc, struct bio **bio_ret,
                                unsigned nr_pages, sector_t *last_block_in_bio,
-                               bool is_readahead)
+                               bool is_readahead, bool for_write)
 {
        struct dnode_of_data dn;
        struct inode *inode = cc->inode;
@@ -2100,7 +2102,7 @@ submit_and_realloc:
                if (!bio) {
                        bio = f2fs_grab_read_bio(inode, blkaddr, nr_pages,
                                        is_readahead ? REQ_RAHEAD : 0,
-                                       page->index);
+                                       page->index, for_write);
                        if (IS_ERR(bio)) {
                                ret = PTR_ERR(bio);
                                bio = NULL;
@@ -2201,7 +2203,7 @@ int f2fs_mpage_readpages(struct address_space *mapping,
                                ret = f2fs_read_multi_pages(&cc, &bio,
                                                        max_nr_pages,
                                                        &last_block_in_bio,
-                                                       is_readahead);
+                                                       is_readahead, false);
                                f2fs_destroy_compress_ctx(&cc);
                                if (ret)
                                        goto set_error_page;
@@ -2244,7 +2246,7 @@ next_page:
                                ret = f2fs_read_multi_pages(&cc, &bio,
                                                        max_nr_pages,
                                                        &last_block_in_bio,
-                                                       is_readahead);
+                                                       is_readahead, false);
                                f2fs_destroy_compress_ctx(&cc);
                        }
                }
@@ -3274,7 +3276,7 @@ repeat:
                        err = -EFSCORRUPTED;
                        goto fail;
                }
-               err = f2fs_submit_page_read(inode, page, blkaddr);
+               err = f2fs_submit_page_read(inode, page, blkaddr, true);
                if (err)
                        goto fail;
 
index 241a87d0d71c1a871ae3a25217074490e9c81f5c..14f7af37ff4bb0a8823e00f3716eb5d82c503402 100644 (file)
@@ -3796,7 +3796,7 @@ int f2fs_write_multi_pages(struct compress_ctx *cc,
 int f2fs_is_compressed_cluster(struct inode *inode, pgoff_t index);
 int f2fs_read_multi_pages(struct compress_ctx *cc, struct bio **bio_ret,
                                unsigned nr_pages, sector_t *last_block_in_bio,
-                               bool is_readahead);
+                               bool is_readahead, bool for_write);
 struct decompress_io_ctx *f2fs_alloc_dic(struct compress_ctx *cc);
 void f2fs_free_dic(struct decompress_io_ctx *dic);
 void f2fs_decompress_end_io(struct page **rpages,