Received: by 2002:ac2:48a3:0:0:0:0:0 with SMTP id u3csp568401lfg; Fri, 11 Mar 2022 13:33:48 -0800 (PST) X-Google-Smtp-Source: ABdhPJwPloWnSuJRDKmS2ytvgbYO9/jlmBtE4Rhd/wvN7WjYwf8MHNXcTTQjIrNa9QUO5n959Fbl X-Received: by 2002:a63:c56:0:b0:378:7ad0:c01c with SMTP id 22-20020a630c56000000b003787ad0c01cmr10127673pgm.510.1647034428472; Fri, 11 Mar 2022 13:33:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1647034428; cv=none; d=google.com; s=arc-20160816; b=O0utVd+F1V5uXPiiHyXIVx+xrW2Jd+O2+/MJKDjgfSi0CqLIx7lSxtNvUDXzSrcDoQ tq1QHBF7c5Aoi+6OcFhUELfU015Vc7vD41VNjQyqlj+TWG0rO+/VIqxDj9zWfjp8b+BP U8MGv0KXOtEc62TBdkevqSwACO3F7tBM9WZESjRcAVdpoaYNNdLiOmieSOtGxZ5PnQJg AlsDviCDTBiavExssD1kaRsNsubPnAOXG3hobvxW5ClQ7K6BncADiazNT7ASuwhvsDrJ mRlLe0y5EI85KnBBf63Taf8S9ks18F/3odinCKmyXs3MR0GdteyoS9rXiQldvaHLtpaC dM8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dkim-signature; bh=UzP5nyGsG5GcBeZpseFrZjEpwCJXFyPvLwGQvRUfnNo=; b=oe0HjHTJXhDe7zJBJzzBldxaEdPvu5NR11S/jx8qnFQrot56zw0UBsj27zu8GQavaP rUBApnkhK9kNOGo6gAyOSF5uLfPjjGnu7I3fZGXx7d4apbLRS2P+Jm+kIMgomb3vKuj4 MpuaIokNaXr/qXvR5ywZ9/+YkKFL/loMUjC04mblJzkKTw+AUX90xY39wJqMt1xi3S8l YM/hZDfqQyFsPA7SOVcUKQT2xhLKZS9WaZjnOBb6utGDjyYZHqdBqIASSQy6VKWHaHuH Lujvnl5/0VAH73KKbs8H3sC3qAI0PFj8w26SWy9Op5+0NV7LmDXQbFro/ULNxgs0OG2+ i3cA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=I+MNjb3C; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id 24-20020a631358000000b003809d3f64afsi8501837pgt.525.2022.03.11.13.33.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 11 Mar 2022 13:33:48 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=I+MNjb3C; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id C3ECBF4615; Fri, 11 Mar 2022 13:03:00 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1346826AbiCKHuf (ORCPT + 99 others); Fri, 11 Mar 2022 02:50:35 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:40900 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S245098AbiCKHuc (ORCPT ); Fri, 11 Mar 2022 02:50:32 -0500 Received: from mail-pl1-x62d.google.com (mail-pl1-x62d.google.com [IPv6:2607:f8b0:4864:20::62d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7FCBA6E8FF for ; Thu, 10 Mar 2022 23:49:29 -0800 (PST) Received: by mail-pl1-x62d.google.com with SMTP id r12so7052229pla.1 for ; Thu, 10 Mar 2022 23:49:29 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=date:from:to:cc:subject:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=UzP5nyGsG5GcBeZpseFrZjEpwCJXFyPvLwGQvRUfnNo=; b=I+MNjb3CDGdWqP0vN8lxP24xDaRT2FsDjXqHEF8anMTchEqnJESHsAJ5VSU3coSSh+ UZTErUAkeAAjATqg/sexMBi4kvDDB3kcFgReh8VQTfrL0lRESjd2BykhwR3FJOA1yNhO wlNDdrP78dFszJNYudc8oOTvgCfj1r6NOtjNYyjbX7DY22XC9+62V6xgbiYbZVYlzq/S PxcHJBvwZfy9iWVhodI/6rsEKS+xDy/lsu0v3uGeJHXr9ozgn9FSGdCjRVcrfg2We15x w9hxuSnTMiECb92PKg2M9mpJiNpZUtDvBeU+ING2wAgQuFPPRo9QN5Haa4YP1vKpxX/W PbFw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:date:from:to:cc:subject:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=UzP5nyGsG5GcBeZpseFrZjEpwCJXFyPvLwGQvRUfnNo=; b=2BKARYrSXSJ2pMAdfhQX33GeFLt8ybHaYmJ9wAWMZ1clPEeDaS9gABmPjWfH/tq/RI s+cx6RODjU/QFcS0+PlAHQAOYJN9Sk2p9suuK4r5OCOV8TmmnDDBqc8KdKCAFo8RrfoZ uq8IhtC5iZsM34RxPTtwF6yGpQ6OFtOww+vNDBp5NtTURwMUjpfyJU58zSfgt4hbc8uB Az29k+Tf0CcUaRTJDjDekiidNkinPrapjKksy7K41D56E+mydo+AiXQrIQ3cT2i/ydDF LuA5wew8SReWkEgd+U+fkRHI1El6S6td5ydNkuZ/6DSUgftbChDspksFcy2bpnQP8hG/ Adeg== X-Gm-Message-State: AOAM532YrVcsRYcxGYlQbKmAqJexELpAns4jQSYq6QAfSCgWENNVj2Yu CyA9Nsfx3zbWlCObEjW7QBI= X-Received: by 2002:a17:90b:3ec8:b0:1bf:ddf:92f0 with SMTP id rm8-20020a17090b3ec800b001bf0ddf92f0mr9324478pjb.161.1646984969050; Thu, 10 Mar 2022 23:49:29 -0800 (PST) Received: from localhost ([103.220.76.197]) by smtp.gmail.com with ESMTPSA id mu1-20020a17090b388100b001bf861ef154sm12668948pjb.55.2022.03.10.23.49.27 (version=TLS1_2 cipher=ECDHE-ECDSA-CHACHA20-POLY1305 bits=256/256); Thu, 10 Mar 2022 23:49:28 -0800 (PST) Date: Fri, 11 Mar 2022 15:48:16 +0800 From: Yue Hu To: Gao Xiang Cc: linux-erofs@lists.ozlabs.org, LKML , huyue2@coolpad.com, zhangwen@coolpad.com Subject: Re: [PATCH 1/2] erofs: clean up z_erofs_extent_lookback Message-ID: <20220311154816.00004d23.zbestahu@gmail.com> In-Reply-To: References: <20220310182743.102365-1-hsiangkao@linux.alibaba.com> <20220311151232.00003619.zbestahu@gmail.com> X-Mailer: Claws Mail 3.17.3 (GTK+ 2.24.32; i686-w64-mingw32) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,RDNS_NONE, SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no 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 Fri, 11 Mar 2022 15:39:00 +0800 Gao Xiang wrote: > On Fri, Mar 11, 2022 at 03:28:28PM +0800, Gao Xiang wrote: > > On Fri, Mar 11, 2022 at 03:12:32PM +0800, Yue Hu wrote: > > > On Fri, 11 Mar 2022 02:27:42 +0800 > > > Gao Xiang wrote: > > > > > > > Avoid the unnecessary tail recursion since it can be converted into > > > > a loop directly in order to prevent potential stack overflow. > > > > > > > > It's a pretty straightforward conversion. > > > > > > > > Signed-off-by: Gao Xiang > > > > --- > > > > fs/erofs/zmap.c | 67 ++++++++++++++++++++++++------------------------- > > > > 1 file changed, 33 insertions(+), 34 deletions(-) > > > > > > > > diff --git a/fs/erofs/zmap.c b/fs/erofs/zmap.c > > > > index b4059b9c3bac..572f0b8151ba 100644 > > > > --- a/fs/erofs/zmap.c > > > > +++ b/fs/erofs/zmap.c > > > > @@ -431,48 +431,47 @@ static int z_erofs_extent_lookback(struct z_erofs_maprecorder *m, > > > > unsigned int lookback_distance) > > > > { > > > > struct erofs_inode *const vi = EROFS_I(m->inode); > > > > - struct erofs_map_blocks *const map = m->map; > > > > const unsigned int lclusterbits = vi->z_logical_clusterbits; > > > > - unsigned long lcn = m->lcn; > > > > - int err; > > > > > > > > - if (lcn < lookback_distance) { > > > > - erofs_err(m->inode->i_sb, > > > > - "bogus lookback distance @ nid %llu", vi->nid); > > > > - DBG_BUGON(1); > > > > - return -EFSCORRUPTED; > > > > - } > > > > + while (m->lcn >= lookback_distance) { > > > > + unsigned long lcn = m->lcn - lookback_distance; > > > > + int err; > > > > > > may better to declare variable 'lclusterbits' in loop just like 'err' usage? > > > > I'm fine with either way. Ok, will post the next version later. > > Oh, I just noticed that you mean `lclusterbits', I think it won't > change in this function, so I don't tend to move it into the inner > loop. Ok, looks good to me. Reviewed-by: Yue Hu > > Thanks, > Gao Xiang > > > > > Thanks, > > Gao Xiang