Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp386252ybx; Tue, 29 Oct 2019 20:58:08 -0700 (PDT) X-Google-Smtp-Source: APXvYqyDEtGunZxCu6W6cMw9EdzStV01FFXMgYptnBuWE+BLzaAntZ5fXneH3VUdlYQ2+PLHEa53 X-Received: by 2002:a17:906:d972:: with SMTP id rp18mr6868872ejb.179.1572407888262; Tue, 29 Oct 2019 20:58:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1572407888; cv=none; d=google.com; s=arc-20160816; b=eCto92L/5bdC99yTCfmVTBJ2cwo8cZnq5dYpCvuHjVHonHzhW4cC77rX53YP3AqPuZ Xq/VLdBD7o6TOzMgLRqmal0QgAeYUqfch4ii/k5xwn/KL3UBzq6zMdiCWEIOs9iC4S0v 0kjM+vlxWfU6PNMRPTH1Jewsyw/Mu+IaoFsSTS7r4A0GFANLXmhx8PO8bhgsUhuldcWi 0WBhcsDYw25LmEdc8fmItRwzTRwpRKFyZRNjKXhLR8vPC1ldRIjYc12HK8427VJ0oNj1 ZUxUQs6ktb0u2t7M8TL09KiPCBctHhUK1i8syI7gdNRNLZRO7FaoerhBq8je7iD1jraa Qt5A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:subject:cc :to:from; bh=o7rB2ohehVm21cdkUE6uZwiSM+wxLsxN57r0XESA5V8=; b=W8gKbj334quQrbL1HXRHXD99pB2dNR06941B+yqL7o3S26K6JxBetnUceFDXxUJQ2K +W932Xhs1qLXW50PF/lYEew9jS7+WZRj0oaLZ8WPrD4dJNz/H0qO+veCN57ijIJo0O6H n1fojWsVfgyKfxHlrvvL6hB9ddTSF2JH//LUzXtdT1NnztWX9Yi2oSE0aZvOayvQ/rHI 53UAfvpFxOKvcWjJUCnP7rVQWTK+2Pnt/2fPWiIcjnbj411TAaLJk4fQrZO2nxTh9P4i f7uuynV64xKzt44N17msC7ygDBtSMpKtJXm8oYLoUbYEhWwMJaKCkf83TWbK4A+KzYmX TbUg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r21si450318ejo.151.2019.10.29.20.57.44; Tue, 29 Oct 2019 20:58:08 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727015AbfJ3Dyj (ORCPT + 99 others); Tue, 29 Oct 2019 23:54:39 -0400 Received: from szxga04-in.huawei.com ([45.249.212.190]:5649 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726747AbfJ3Dyj (ORCPT ); Tue, 29 Oct 2019 23:54:39 -0400 Received: from DGGEMS406-HUB.china.huawei.com (unknown [172.30.72.60]) by Forcepoint Email with ESMTP id 133EAF416A0042295C05; Wed, 30 Oct 2019 11:54:35 +0800 (CST) Received: from architecture4.huawei.com (10.140.130.215) by smtp.huawei.com (10.3.19.206) with Microsoft SMTP Server (TLS) id 14.3.439.0; Wed, 30 Oct 2019 11:54:25 +0800 From: Gao Xiang To: Jaegeuk Kim , Chao Yu CC: Jonathan Corbet , , , , Gao Xiang Subject: [PATCH] f2fs: bio_alloc should never fail Date: Wed, 30 Oct 2019 11:55:18 +0800 Message-ID: <20191030035518.65477-1-gaoxiang25@huawei.com> X-Mailer: git-send-email 2.17.1 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.140.130.215] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org remove such useless code and related fault injection. Signed-off-by: Gao Xiang --- Documentation/filesystems/f2fs.txt | 1 - fs/f2fs/data.c | 6 ++---- fs/f2fs/f2fs.h | 21 --------------------- fs/f2fs/segment.c | 5 +---- fs/f2fs/super.c | 1 - 5 files changed, 3 insertions(+), 31 deletions(-) diff --git a/Documentation/filesystems/f2fs.txt b/Documentation/filesystems/f2fs.txt index 7e1991328473..3477c3e4c08b 100644 --- a/Documentation/filesystems/f2fs.txt +++ b/Documentation/filesystems/f2fs.txt @@ -172,7 +172,6 @@ fault_type=%d Support configuring fault injection type, should be FAULT_KVMALLOC 0x000000002 FAULT_PAGE_ALLOC 0x000000004 FAULT_PAGE_GET 0x000000008 - FAULT_ALLOC_BIO 0x000000010 FAULT_ALLOC_NID 0x000000020 FAULT_ORPHAN 0x000000040 FAULT_BLOCK 0x000000080 diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c index 5755e897a5f0..3b88dcb15de6 100644 --- a/fs/f2fs/data.c +++ b/fs/f2fs/data.c @@ -288,7 +288,7 @@ static struct bio *__bio_alloc(struct f2fs_io_info *fio, int npages) struct f2fs_sb_info *sbi = fio->sbi; struct bio *bio; - bio = f2fs_bio_alloc(sbi, npages, true); + bio = bio_alloc(GFP_NOIO, npages); f2fs_target_device(sbi, fio->new_blkaddr, bio); if (is_read_io(fio->op)) { @@ -682,9 +682,7 @@ static struct bio *f2fs_grab_read_bio(struct inode *inode, block_t blkaddr, 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); - if (!bio) - return ERR_PTR(-ENOMEM); + bio = bio_alloc(GFP_KERNEL, min_t(int, nr_pages, BIO_MAX_PAGES)); f2fs_target_device(sbi, blkaddr, bio); bio->bi_end_io = f2fs_read_end_io; bio_set_op_attrs(bio, REQ_OP_READ, op_flag); diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h index 4024790028aa..40012f874be0 100644 --- a/fs/f2fs/f2fs.h +++ b/fs/f2fs/f2fs.h @@ -44,7 +44,6 @@ enum { FAULT_KVMALLOC, FAULT_PAGE_ALLOC, FAULT_PAGE_GET, - FAULT_ALLOC_BIO, FAULT_ALLOC_NID, FAULT_ORPHAN, FAULT_BLOCK, @@ -2210,26 +2209,6 @@ static inline void *f2fs_kmem_cache_alloc(struct kmem_cache *cachep, return entry; } -static inline struct bio *f2fs_bio_alloc(struct f2fs_sb_info *sbi, - int npages, bool no_fail) -{ - struct bio *bio; - - if (no_fail) { - /* No failure on bio allocation */ - bio = bio_alloc(GFP_NOIO, npages); - if (!bio) - bio = bio_alloc(GFP_NOIO | __GFP_NOFAIL, npages); - return bio; - } - if (time_to_inject(sbi, FAULT_ALLOC_BIO)) { - f2fs_show_injection_info(FAULT_ALLOC_BIO); - return NULL; - } - - return bio_alloc(GFP_KERNEL, npages); -} - static inline bool is_idle(struct f2fs_sb_info *sbi, int type) { if (sbi->gc_mode == GC_URGENT) diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c index 808709581481..28457c878d0d 100644 --- a/fs/f2fs/segment.c +++ b/fs/f2fs/segment.c @@ -552,10 +552,7 @@ static int __submit_flush_wait(struct f2fs_sb_info *sbi, struct bio *bio; int ret; - bio = f2fs_bio_alloc(sbi, 0, false); - if (!bio) - return -ENOMEM; - + bio = bio_alloc(GFP_KERNEL, 0); bio->bi_opf = REQ_OP_WRITE | REQ_SYNC | REQ_PREFLUSH; bio_set_dev(bio, bdev); ret = submit_bio_wait(bio); diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c index 1443cee15863..51945dd27f00 100644 --- a/fs/f2fs/super.c +++ b/fs/f2fs/super.c @@ -44,7 +44,6 @@ const char *f2fs_fault_name[FAULT_MAX] = { [FAULT_KVMALLOC] = "kvmalloc", [FAULT_PAGE_ALLOC] = "page alloc", [FAULT_PAGE_GET] = "page get", - [FAULT_ALLOC_BIO] = "alloc bio", [FAULT_ALLOC_NID] = "alloc nid", [FAULT_ORPHAN] = "orphan", [FAULT_BLOCK] = "no more block", -- 2.17.1