Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp670342pxb; Fri, 22 Apr 2022 08:57:10 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzqpBZXu+/kgTXPzGmAYdPlc6aZpq+l/IYno+ieo0DHBzr8CvdO1CHGgtJbGZ2uKp4gq8a+ X-Received: by 2002:a17:907:3d8b:b0:6f3:674f:c7dc with SMTP id he11-20020a1709073d8b00b006f3674fc7dcmr1154030ejc.563.1650643030417; Fri, 22 Apr 2022 08:57:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650643030; cv=none; d=google.com; s=arc-20160816; b=Iwn+0Ad+5okIIZQsxm1FBf0d2kM0rIbPu/PMhEE4PWOtTpE7yvDMY6tvRCyHyoR/KR LWKv/uc4+rXQBWYqdkWapkZJzxsTKGLhlbZwrUMShWDNNDNu1tZ1BFPxwVSyF4HzYBZL iE4PBLxq8/YEEDOoPBybq3aQcC1BR1XEAihTHvECzH/RgeMkQaRKI0VsXULnsRanzk8S 54KjowwNQ8ImZYy7L1CVxWTAoc1d/qwiDok6bSgq4jU+cnTsaAU0sTZ0xp9b93Kt4BR0 /cur87YcKqf2dI0VAgD/5V/s1H+T163kQhNaEr3OlrAgeT+KSsSEBugOkg+HVA5qhS/+ AL/g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=8IKhjIvFr29ZMESXzsimRJOPTN0Pz37lwOkipPbskCE=; b=DmuuM99BAsZUnoKrtQ7KWvrjAcHkxIulTsjOU9P1VQ2RhaDpQI6F5UZfeFpB4gNmye e1J9WcJivkvu0j3ZbCk+f8C2ptZTHlDxMEeZDt9Lk9ZuqJ46FBRahD2TJ1tCeFraT7I4 CeOpigPr66N77150sA8BC6friRTIJexbiisX+CpjtzUhst7jAqdHLVhwd/3nCSCkbu6N Pj9dFYpYmUPSJhHP0CMX0Xiz9S4HGXaq2AjEK6TUJCuOf+32MD+Hw9r9x+Z9UHPLeTk4 f5BcxWP0Kjz60jPehki/TeJpYoV/TFUf9SPG/3ruYPvkPA3EHGTdg59He0cLmli2JPnz H9Xw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=t7hyOiEZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id mb11-20020a170906eb0b00b006e7fd413915si7116567ejb.946.2022.04.22.08.56.46; Fri, 22 Apr 2022 08:57:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=t7hyOiEZ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1359009AbiDTCsP (ORCPT + 99 others); Tue, 19 Apr 2022 22:48:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42346 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239192AbiDTCsP (ORCPT ); Tue, 19 Apr 2022 22:48:15 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D80972F01B for ; Tue, 19 Apr 2022 19:45:30 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 73A7D61616 for ; Wed, 20 Apr 2022 02:45:30 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 7AE93C385A5; Wed, 20 Apr 2022 02:45:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1650422729; bh=dqJj8cxS5GfPVVKnznBjD5JCJjlatiZ36UsnvCkAqdU=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=t7hyOiEZA5rsal29kufImzA7DtamHpc4g66YlVBPR60X8mdVmNtZmJ0Hqh5VFVosu bhKqxpVCmBmB1Q+prNwfR8uuvz0jp/vdZSyuZYbZLcXfFBiGmJRTEKHb7VtxKY/0D0 t3u66PEYuGl1/m2LgpBAy2pVaqxQi9jPj18u0XyD2xgWtONZ/Vqz8dPm91qpDXjSR2 mRr42Z96nK7216CHcl8eomJ2StHS7NrJTaOiNk+4H+TMD3E01jmBLSX40LI5JmJjvN X2Ulh88OdGqg7zdT0oS5ZuEmMviajkMyhLY3q9MLmQRxRnRUO5YT5fW/qUaIW1Hl8N jkcJek0od1uRw== Message-ID: <47f19561-11a7-9da3-1cf9-78843e0d0ec3@kernel.org> Date: Wed, 20 Apr 2022 10:45:25 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:91.0) Gecko/20100101 Thunderbird/91.8.0 Subject: Re: [f2fs-dev] [PATCH 2/2] f2fs: keep io_flags to avoid IO split due to different op_flags in two fio holders Content-Language: en-US To: Jaegeuk Kim Cc: linux-kernel@vger.kernel.org, linux-f2fs-devel@lists.sourceforge.net References: <20220413154920.2024872-1-jaegeuk@kernel.org> <20220413154920.2024872-2-jaegeuk@kernel.org> From: Chao Yu In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-10.9 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A, RCVD_IN_DNSWL_HI,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2022/4/20 6:47, Jaegeuk Kim wrote: > On 04/17, Chao Yu wrote: >> On 2022/4/13 23:49, Jaegeuk Kim wrote: >>> Let's attach io_flags to bio only, so that we can merge IOs given original >>> io_flags only. >>> >>> Fixes: 64bf0eef0171 ("f2fs: pass the bio operation to bio_alloc_bioset") >> >> Nice catch. >> >> Wasn't this bug introduced by: > > I don't think so. Oh, correct, it looks in original patch, we only attach IO flag before __submit_bio(). Reviewed-by: Chao Yu Thanks, > >> >> commit da9953b729c1 ("f2fs: introduce sysfs/data_io_flag to attach REQ_META/FUA") >> >> static void __attach_data_io_flag(struct f2fs_io_info *fio) >> { >> ... >> if ((1 << fio->temp) & meta_flag) >> fio->op_flags |= REQ_META; >> if ((1 << fio->temp) & fua_flag) >> fio->op_flags |= REQ_FUA; >> ... >> >> Thanks, >> >>> Signed-off-by: Jaegeuk Kim >>> --- >>> fs/f2fs/data.c | 33 +++++++++++++++++++++------------ >>> 1 file changed, 21 insertions(+), 12 deletions(-) >>> >>> diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c >>> index acc523f893ba..fcf0daa386de 100644 >>> --- a/fs/f2fs/data.c >>> +++ b/fs/f2fs/data.c >>> @@ -387,11 +387,23 @@ int f2fs_target_device_index(struct f2fs_sb_info *sbi, block_t blkaddr) >>> return 0; >>> } >>> -static void __attach_io_flag(struct f2fs_io_info *fio, unsigned int io_flag) >>> +static unsigned int f2fs_io_flags(struct f2fs_io_info *fio) >>> { >>> unsigned int temp_mask = (1 << NR_TEMP_TYPE) - 1; >>> - unsigned int fua_flag = io_flag & temp_mask; >>> - unsigned int meta_flag = (io_flag >> NR_TEMP_TYPE) & temp_mask; >>> + unsigned int fua_flag, meta_flag, io_flag; >>> + unsigned int op_flags = 0; >>> + >>> + if (fio->op != REQ_OP_WRITE) >>> + return 0; >>> + if (fio->type == DATA) >>> + io_flag = fio->sbi->data_io_flag; >>> + else if (fio->type == NODE) >>> + io_flag = fio->sbi->node_io_flag; >>> + else >>> + return 0; >>> + >>> + fua_flag = io_flag & temp_mask; >>> + meta_flag = (io_flag >> NR_TEMP_TYPE) & temp_mask; >>> /* >>> * data/node io flag bits per temp: >>> @@ -400,9 +412,10 @@ static void __attach_io_flag(struct f2fs_io_info *fio, unsigned int io_flag) >>> * Cold | Warm | Hot | Cold | Warm | Hot | >>> */ >>> if ((1 << fio->temp) & meta_flag) >>> - fio->op_flags |= REQ_META; >>> + op_flags |= REQ_META; >>> if ((1 << fio->temp) & fua_flag) >>> - fio->op_flags |= REQ_FUA; >>> + op_flags |= REQ_FUA; >>> + return op_flags; >>> } >>> static struct bio *__bio_alloc(struct f2fs_io_info *fio, int npages) >>> @@ -412,14 +425,10 @@ static struct bio *__bio_alloc(struct f2fs_io_info *fio, int npages) >>> sector_t sector; >>> struct bio *bio; >>> - if (fio->type == DATA) >>> - __attach_io_flag(fio, sbi->data_io_flag); >>> - else if (fio->type == NODE) >>> - __attach_io_flag(fio, sbi->node_io_flag); >>> - >>> bdev = f2fs_target_device(sbi, fio->new_blkaddr, §or); >>> - bio = bio_alloc_bioset(bdev, npages, fio->op | fio->op_flags, GFP_NOIO, >>> - &f2fs_bioset); >>> + bio = bio_alloc_bioset(bdev, npages, >>> + fio->op | fio->op_flags | f2fs_io_flags(fio), >>> + GFP_NOIO, &f2fs_bioset); >>> bio->bi_iter.bi_sector = sector; >>> if (is_read_io(fio->op)) { >>> bio->bi_end_io = f2fs_read_end_io;