Commit 12377024 authored by Chao Yu's avatar Chao Yu Committed by Jaegeuk Kim

f2fs: avoid duplicated code by reusing f2fs_read_end_io

This patch tries to clean up code because part code of f2fs_read_end_io
and mpage_end_io are the same, so it's better to merge and reuse them.
Signed-off-by: default avatarChao Yu <chao2.yu@samsung.com>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent 26bf3dc7
...@@ -34,29 +34,6 @@ static void f2fs_read_end_io(struct bio *bio, int err) ...@@ -34,29 +34,6 @@ static void f2fs_read_end_io(struct bio *bio, int err)
struct bio_vec *bvec; struct bio_vec *bvec;
int i; int i;
bio_for_each_segment_all(bvec, bio, i) {
struct page *page = bvec->bv_page;
if (!err) {
SetPageUptodate(page);
} else {
ClearPageUptodate(page);
SetPageError(page);
}
unlock_page(page);
}
bio_put(bio);
}
/*
* I/O completion handler for multipage BIOs.
* copied from fs/mpage.c
*/
static void mpage_end_io(struct bio *bio, int err)
{
struct bio_vec *bv;
int i;
if (f2fs_bio_encrypted(bio)) { if (f2fs_bio_encrypted(bio)) {
if (err) { if (err) {
f2fs_release_crypto_ctx(bio->bi_private); f2fs_release_crypto_ctx(bio->bi_private);
...@@ -66,8 +43,8 @@ static void mpage_end_io(struct bio *bio, int err) ...@@ -66,8 +43,8 @@ static void mpage_end_io(struct bio *bio, int err)
} }
} }
bio_for_each_segment_all(bv, bio, i) { bio_for_each_segment_all(bvec, bio, i) {
struct page *page = bv->bv_page; struct page *page = bvec->bv_page;
if (!err) { if (!err) {
SetPageUptodate(page); SetPageUptodate(page);
...@@ -77,7 +54,6 @@ static void mpage_end_io(struct bio *bio, int err) ...@@ -77,7 +54,6 @@ static void mpage_end_io(struct bio *bio, int err)
} }
unlock_page(page); unlock_page(page);
} }
bio_put(bio); bio_put(bio);
} }
...@@ -122,7 +98,7 @@ static struct bio *__bio_alloc(struct f2fs_sb_info *sbi, block_t blk_addr, ...@@ -122,7 +98,7 @@ static struct bio *__bio_alloc(struct f2fs_sb_info *sbi, block_t blk_addr,
bio->bi_bdev = sbi->sb->s_bdev; bio->bi_bdev = sbi->sb->s_bdev;
bio->bi_iter.bi_sector = SECTOR_FROM_BLOCK(blk_addr); bio->bi_iter.bi_sector = SECTOR_FROM_BLOCK(blk_addr);
bio->bi_end_io = is_read ? f2fs_read_end_io : f2fs_write_end_io; bio->bi_end_io = is_read ? f2fs_read_end_io : f2fs_write_end_io;
bio->bi_private = sbi; bio->bi_private = is_read ? NULL : sbi;
return bio; return bio;
} }
...@@ -1584,7 +1560,7 @@ static int f2fs_mpage_readpages(struct address_space *mapping, ...@@ -1584,7 +1560,7 @@ static int f2fs_mpage_readpages(struct address_space *mapping,
} }
bio->bi_bdev = bdev; bio->bi_bdev = bdev;
bio->bi_iter.bi_sector = SECTOR_FROM_BLOCK(block_nr); bio->bi_iter.bi_sector = SECTOR_FROM_BLOCK(block_nr);
bio->bi_end_io = mpage_end_io; bio->bi_end_io = f2fs_read_end_io;
bio->bi_private = ctx; bio->bi_private = ctx;
} }
......
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