Received: by 2002:a05:6358:53a8:b0:117:f937:c515 with SMTP id z40csp3591816rwe; Sun, 16 Apr 2023 23:56:08 -0700 (PDT) X-Google-Smtp-Source: AKy350aCir+lLfqC7e4mlydYsdikw9tdGlWEO6qvMQDz5nolbohexU2TYHz2NZMrvTxhEuN4rMnB X-Received: by 2002:a05:6a20:b29b:b0:eb:fdca:c5d1 with SMTP id ei27-20020a056a20b29b00b000ebfdcac5d1mr13969004pzb.13.1681714568306; Sun, 16 Apr 2023 23:56:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1681714568; cv=none; d=google.com; s=arc-20160816; b=f4n1El4ehi6iXpQqXOOq8ID/iAkJ28dMNOJ8HHZctnc3mt6BQmjv2lfx/A8+CqcS7V BMzGRgDTW9aBQvbYF7cop/Nu0iIORG6pkC60+RWDAwo+9jo3KK92zK5swKiGVhuIm003 dWUje/RrL6uRF3HVYXGGJAlCVtLrJECiyRsDvye8YdMBJtaZfO1wy0QqOUEL20A+gKjc QpdkWk1bIoFr1ajrecsv5UtP0BY/R0vZhqWU/glDr/qObrWrjnyM2epIv6jwn8aUqknQ pGdnikpTwhP8Vl7relNEKq/VA6P4hxUOeBNdTAmt77cHrGDLwdyShwwGSYCcBcQGjRxe mlkw== 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:subject:user-agent:mime-version:date:message-id; bh=f9uxCsrvtAEemOhaVvpOKzzy9zI6jILp9AripYw18Uc=; b=ENj7OywIBjb/fCS4Cxx7Dq60ckAagbRltyrvmoGdRK3UoSblPhYSXzeox0GSpgIDOc PVZeXrj6NtWoT7HzPAxvHkkBIHazWTi9acVSgovaZa074R0e+f2JWuMBGxk5yHrcBi9D Ltc+hgpnnhJulNQfCm5xEaUqCciwr1B+3TMoznH/fE/pwoAtXZDfqNjfBCqCTGAKT26N uhVI8fil+pBmJJkJfyrJ5RzbC8Oz2OfQvxdCjGJuRhPxphxZ/39ope0hnaRASP1IAc2+ W7P9cLTjfYD2XCjSAtC5xfHorngBoR1LmXtDEruBqxmh2zkY3UWTrjyzR2bSwKAPyT5F 1Gzw== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id g5-20020a63dd45000000b0051b856ffbc1si6344077pgj.659.2023.04.16.23.55.54; Sun, 16 Apr 2023 23:56:08 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230146AbjDQGyU (ORCPT + 99 others); Mon, 17 Apr 2023 02:54:20 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48046 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230117AbjDQGyT (ORCPT ); Mon, 17 Apr 2023 02:54:19 -0400 Received: from out30-113.freemail.mail.aliyun.com (out30-113.freemail.mail.aliyun.com [115.124.30.113]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3C753DF for ; Sun, 16 Apr 2023 23:53:36 -0700 (PDT) X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R201e4;CH=green;DM=||false|;DS=||;FP=0|-1|-1|-1|0|-1|-1|-1;HT=ay29a033018046059;MF=hsiangkao@linux.alibaba.com;NM=1;PH=DS;RN=8;SR=0;TI=SMTPD_---0VgELZVh_1681714379; Received: from 30.97.49.3(mailfrom:hsiangkao@linux.alibaba.com fp:SMTPD_---0VgELZVh_1681714379) by smtp.aliyun-inc.com; Mon, 17 Apr 2023 14:53:00 +0800 Message-ID: <26cdf7b0-5d7d-68ba-da76-1ad800708946@linux.alibaba.com> Date: Mon, 17 Apr 2023 14:52:59 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.9.1 Subject: Re: [PATCH] erofs: remove unneeded icur field from struct z_erofs_decompress_frontend To: Yue Hu , xiang@kernel.org, chao@kernel.org, linux-erofs@lists.ozlabs.org Cc: jefflexu@linux.alibaba.com, linux-kernel@vger.kernel.org, huyue2@coolpad.com, zhangwen@coolpad.com References: <20230417064136.5890-1-zbestahu@gmail.com> From: Gao Xiang In-Reply-To: <20230417064136.5890-1-zbestahu@gmail.com> 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, ENV_AND_HDR_SPF_MATCH,NICE_REPLY_A,RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE, UNPARSEABLE_RELAY,USER_IN_DEF_SPF_WL 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 2023/4/17 14:41, Yue Hu wrote: > From: Yue Hu > > The icur field is only used in z_erofs_try_inplace_io(). Let's just use > a local variable instead. And no need to check if the pcluster is inline > when setting icur since inline page cannot be used for inplace I/O. > > Signed-off-by: Yue Hu Nope, it's a behavior change. Other users could feed more inplace I/O pages before I/O submission to reduce memory consumption, it's common when applying stress model in low memory scenarios. Thanks, Gao Xiang > --- > fs/erofs/zdata.c | 13 +++++-------- > 1 file changed, 5 insertions(+), 8 deletions(-) > > diff --git a/fs/erofs/zdata.c b/fs/erofs/zdata.c > index f759152feffa..f8bf2b227942 100644 > --- a/fs/erofs/zdata.c > +++ b/fs/erofs/zdata.c > @@ -554,9 +554,6 @@ struct z_erofs_decompress_frontend { > /* used for applying cache strategy on the fly */ > bool backmost; > erofs_off_t headoffset; > - > - /* a pointer used to pick up inplace I/O pages */ > - unsigned int icur; > }; > > #define DECOMPRESS_FRONTEND_INIT(__i) { \ > @@ -707,11 +704,13 @@ static bool z_erofs_try_inplace_io(struct z_erofs_decompress_frontend *fe, > struct z_erofs_bvec *bvec) > { > struct z_erofs_pcluster *const pcl = fe->pcl; > + /* file-backed online pages are traversed in reverse order */ > + unsigned int icur = pcl->pclusterpages; > > - while (fe->icur > 0) { > - if (!cmpxchg(&pcl->compressed_bvecs[--fe->icur].page, > + while (icur > 0) { > + if (!cmpxchg(&pcl->compressed_bvecs[--icur].page, > NULL, bvec->page)) { > - pcl->compressed_bvecs[fe->icur] = *bvec; > + pcl->compressed_bvecs[icur] = *bvec; > return true; > } > } > @@ -877,8 +876,6 @@ static int z_erofs_collector_begin(struct z_erofs_decompress_frontend *fe) > } > z_erofs_bvec_iter_begin(&fe->biter, &fe->pcl->bvset, > Z_EROFS_INLINE_BVECS, fe->pcl->vcnt); > - /* since file-backed online pages are traversed in reverse order */ > - fe->icur = z_erofs_pclusterpages(fe->pcl); > return 0; > } >