[PREVIEW] [PATCH RESEND 2/4] staging: erofs: introduce erofs_grab_bio
Chao Yu
yuchao0 at huawei.com
Fri Aug 10 13:08:44 AEST 2018
Hi Xiang,
On 2018/8/10 11:01, Gao Xiang wrote:
> Hi Chao,
>
> On 2018/8/10 10:46, Chao Yu wrote:
>> On 2018/8/1 14:04, Gao Xiang wrote:
>>> this patch renames prepare_bio to erofs_grab_bio, and
>>> adds a nofail option in order to retry in the bio allocator.
>>>
>>> Signed-off-by: Gao Xiang <gaoxiang25 at huawei.com>
>>> ---
>>> drivers/staging/erofs/data.c | 12 ++++++++++--
>>> drivers/staging/erofs/internal.h | 35 +++++++++++++++++------------------
>>> drivers/staging/erofs/unzip_vle.c | 4 ++--
>>> 3 files changed, 29 insertions(+), 22 deletions(-)
>>>
>>> diff --git a/drivers/staging/erofs/data.c b/drivers/staging/erofs/data.c
>>> index ac263a1..2426eda 100644
>>> --- a/drivers/staging/erofs/data.c
>>> +++ b/drivers/staging/erofs/data.c
>>> @@ -60,7 +60,8 @@ struct page *erofs_get_meta_page(struct super_block *sb,
>>> struct bio *bio;
>>> int err;
>>>
>>> - bio = prepare_bio(sb, blkaddr, 1, read_endio);
>>> + bio = erofs_grab_bio(sb, blkaddr, 1, read_endio, true);
>>> +
>>> err = bio_add_page(bio, page, PAGE_SIZE, 0);
>>> BUG_ON(err != PAGE_SIZE);
>>>
>>> @@ -278,7 +279,14 @@ static inline struct bio *erofs_read_raw_page(
>>> if (nblocks > BIO_MAX_PAGES)
>>> nblocks = BIO_MAX_PAGES;
>>>
>>> - bio = prepare_bio(inode->i_sb, blknr, nblocks, read_endio);
>>> + bio = erofs_grab_bio(inode->i_sb,
>>> + blknr, nblocks, read_endio, false);
>>> +
>>> + if (unlikely(IS_ERR(bio))) {
>>> + err = PTR_ERR(bio);
>>> + bio = NULL;
>>> + goto err_out;
>>> + }
>>> }
>>>
>>> err = bio_add_page(bio, page, PAGE_SIZE, 0);
>>> diff --git a/drivers/staging/erofs/internal.h b/drivers/staging/erofs/internal.h
>>> index 4518729..acce2d6 100644
>>> --- a/drivers/staging/erofs/internal.h
>>> +++ b/drivers/staging/erofs/internal.h
>>> @@ -419,26 +419,25 @@ struct erofs_map_blocks {
>>> #define EROFS_GET_BLOCKS_RAW 0x0001
>>>
>>> /* data.c */
>>> -static inline struct bio *prepare_bio(
>>> - struct super_block *sb,
>>> - erofs_blk_t blkaddr, unsigned nr_pages,
>>> - bio_end_io_t endio)
>>> +static inline struct bio *
>>> +erofs_grab_bio(struct super_block *sb,
>>> + erofs_blk_t blkaddr, unsigned nr_pages,
>>> + bio_end_io_t endio, bool nofail)
>>> {
>>> - gfp_t gfp = GFP_NOIO;
>>> - struct bio *bio = bio_alloc(gfp, nr_pages);
>>> -
>>> - if (unlikely(bio == NULL) &&
>>> - (current->flags & PF_MEMALLOC)) {
>>> - do {
>>> - nr_pages /= 2;
>>> - if (unlikely(!nr_pages)) {
>>> - bio = bio_alloc(gfp | __GFP_NOFAIL, 1);
>>> - BUG_ON(bio == NULL);
>>> - break;
>>> + const gfp_t gfp = GFP_NOIO;
>>> + struct bio *bio;
>>> +
>>> + do {
>>> + if (nr_pages == 1) {
>>> + bio = bio_alloc(gfp | (nofail ? __GFP_NOFAIL : 0), 1);
>>> + if (unlikely(bio == NULL)) {
>>> + DBG_BUGON(nofail);
>>> + return ERR_PTR(-ENOMEM);
>>> }
>>> - bio = bio_alloc(gfp, nr_pages);
>>> - } while (bio == NULL);
>>> - }
>>> + }
>>> + bio = bio_alloc(gfp, nr_pages);
>>
>> Need to cover this bio_alloc, so should initialize gfp as:
>>
>> gfp_t gfp = GFP_NOIO | (nofail ? __GFP_NOFAIL : 0);
>>
>> Thanks,
> This patch means if bio = bio_alloc(gfp, nr_pages); fails, try to bio_alloc with nr_pages/2, nr_page/4... until 1...
> and tag __GFP_NOFAIL with 1...
Correct, it's okay to me, thanks for explanation. ;)
Thanks,
>
> As you said offline, there is another bug :-(, let me send the next patch...
>
> Thanks,
> Gao Xiang
>
> .
>
More information about the Linux-erofs
mailing list