Commit a5c0b780 authored by Gao Xiang's avatar Gao Xiang Committed by Greg Kroah-Hartman

erofs: localize erofs_grab_bio()

As Christoph pointed out [1], "erofs_grab_bio tries to
handle a bio_alloc failure, except that the function will
not actually fail due the mempool backing it."

Sorry about useless code, fix it now and
localize erofs_grab_bio [2].

[1] https://lore.kernel.org/r/20190830162812.GA10694@infradead.org/
[2] https://lore.kernel.org/r/20190902122016.GL15931@infradead.org/Reported-by: default avatarChristoph Hellwig <hch@infradead.org>
Signed-off-by: default avatarGao Xiang <gaoxiang25@huawei.com>
Link: https://lore.kernel.org/r/20190904020912.63925-16-gaoxiang25@huawei.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 688a5f2e
...@@ -38,6 +38,19 @@ static inline void read_endio(struct bio *bio) ...@@ -38,6 +38,19 @@ static inline void read_endio(struct bio *bio)
bio_put(bio); bio_put(bio);
} }
static struct bio *erofs_grab_raw_bio(struct super_block *sb,
erofs_blk_t blkaddr,
unsigned int nr_pages)
{
struct bio *bio = bio_alloc(GFP_NOIO, nr_pages);
bio->bi_end_io = read_endio;
bio_set_dev(bio, sb->s_bdev);
bio->bi_iter.bi_sector = (sector_t)blkaddr << LOG_SECTORS_PER_BLOCK;
bio->bi_private = sb;
return bio;
}
/* prio -- true is used for dir */ /* prio -- true is used for dir */
struct page *__erofs_get_meta_page(struct super_block *sb, struct page *__erofs_get_meta_page(struct super_block *sb,
erofs_blk_t blkaddr, bool prio, bool nofail) erofs_blk_t blkaddr, bool prio, bool nofail)
...@@ -62,12 +75,7 @@ struct page *__erofs_get_meta_page(struct super_block *sb, ...@@ -62,12 +75,7 @@ struct page *__erofs_get_meta_page(struct super_block *sb,
if (!PageUptodate(page)) { if (!PageUptodate(page)) {
struct bio *bio; struct bio *bio;
bio = erofs_grab_bio(sb, blkaddr, 1, sb, read_endio, nofail); bio = erofs_grab_raw_bio(sb, blkaddr, 1);
if (IS_ERR(bio)) {
DBG_BUGON(nofail);
err = PTR_ERR(bio);
goto err_out;
}
if (bio_add_page(bio, page, PAGE_SIZE, 0) != PAGE_SIZE) { if (bio_add_page(bio, page, PAGE_SIZE, 0) != PAGE_SIZE) {
err = -EFAULT; err = -EFAULT;
...@@ -276,13 +284,7 @@ static inline struct bio *erofs_read_raw_page(struct bio *bio, ...@@ -276,13 +284,7 @@ static inline struct bio *erofs_read_raw_page(struct bio *bio,
if (nblocks > BIO_MAX_PAGES) if (nblocks > BIO_MAX_PAGES)
nblocks = BIO_MAX_PAGES; nblocks = BIO_MAX_PAGES;
bio = erofs_grab_bio(sb, blknr, nblocks, sb, bio = erofs_grab_raw_bio(sb, blknr, nblocks);
read_endio, false);
if (IS_ERR(bio)) {
err = PTR_ERR(bio);
bio = NULL;
goto err_out;
}
} }
err = bio_add_page(bio, page, PAGE_SIZE, 0); err = bio_add_page(bio, page, PAGE_SIZE, 0);
......
...@@ -411,35 +411,6 @@ static inline int z_erofs_map_blocks_iter(struct inode *inode, ...@@ -411,35 +411,6 @@ static inline int z_erofs_map_blocks_iter(struct inode *inode,
#endif /* !CONFIG_EROFS_FS_ZIP */ #endif /* !CONFIG_EROFS_FS_ZIP */
/* data.c */ /* data.c */
static inline struct bio *erofs_grab_bio(struct super_block *sb,
erofs_blk_t blkaddr,
unsigned int nr_pages,
void *bi_private, bio_end_io_t endio,
bool nofail)
{
const gfp_t gfp = GFP_NOIO;
struct bio *bio;
do {
if (nr_pages == 1) {
bio = bio_alloc(gfp | (nofail ? __GFP_NOFAIL : 0), 1);
if (!bio) {
DBG_BUGON(nofail);
return ERR_PTR(-ENOMEM);
}
break;
}
bio = bio_alloc(gfp, nr_pages);
nr_pages /= 2;
} while (!bio);
bio->bi_end_io = endio;
bio_set_dev(bio, sb->s_bdev);
bio->bi_iter.bi_sector = (sector_t)blkaddr << LOG_SECTORS_PER_BLOCK;
bio->bi_private = bi_private;
return bio;
}
static inline void __submit_bio(struct bio *bio, unsigned int op, static inline void __submit_bio(struct bio *bio, unsigned int op,
unsigned int op_flags) unsigned int op_flags)
{ {
......
...@@ -1263,9 +1263,13 @@ static bool z_erofs_vle_submit_all(struct super_block *sb, ...@@ -1263,9 +1263,13 @@ static bool z_erofs_vle_submit_all(struct super_block *sb,
} }
if (!bio) { if (!bio) {
bio = erofs_grab_bio(sb, first_index + i, bio = bio_alloc(GFP_NOIO, BIO_MAX_PAGES);
BIO_MAX_PAGES, bi_private,
z_erofs_vle_read_endio, true); bio->bi_end_io = z_erofs_vle_read_endio;
bio_set_dev(bio, sb->s_bdev);
bio->bi_iter.bi_sector = (sector_t)(first_index + i) <<
LOG_SECTORS_PER_BLOCK;
bio->bi_private = bi_private;
++nr_bios; ++nr_bios;
} }
......
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