Received: by 2002:a05:6358:489b:b0:bb:da1:e618 with SMTP id x27csp8129846rwn; Wed, 14 Sep 2022 09:20:10 -0700 (PDT) X-Google-Smtp-Source: AA6agR5txk46qIvKV3na4f9QjmTSyoVLgZTGDYwUseuDxJ51QkD4waPj6wHS3txvlotXOSX9Ewdn X-Received: by 2002:a05:6402:350a:b0:452:8c84:8b with SMTP id b10-20020a056402350a00b004528c84008bmr5737071edd.93.1663172409847; Wed, 14 Sep 2022 09:20:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663172409; cv=none; d=google.com; s=arc-20160816; b=a86u8zgqt5NUtuiN/r+f4xl7o5HjuJkUNkK8U8ZnwxKXhWtvMrhO41z49BcwFhT0W2 5S224aZ2r8KbZwK4wXNPpVTiSZVQb0ZgfgHE9u3wyEt1hgJmpj+O/UjrXF6YG4fClM+X YOOrcsgOFviF6f6YpDFd7Ted34fTv/MzSP99ICUz1IZlI2DOhRegrvCm3ZuBmHeTAXBC DdghA/noV7VcU+/GNSF4o1fxM/uenUBbw2mDmuNbjqU9hZhdwQ88L1kMLm3RJGdvG7iG yyir9AjLWOKMpEgwUPXhVoq3104HYhqkpM18sScriocikcTg11sdVZLCqSR5fdum9IU4 Rh+w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:subject:content-transfer-encoding:in-reply-to :from:references:cc:to:content-language:user-agent:mime-version:date :message-id:dkim-signature; bh=nxy9Jbp5GTwxPBiJKmfbVPecTADs9vQAWIAUvB3MVd4=; b=zEhLWTY9xnpk++JjuaWOzud3NroaF27/xG7H04YsC+69o3e+pibW5JtoIzei9SzMuJ jhEvA99Q+ru6+cJBd6urNRTmsHgPxBWnoZp0wwIDLL8CWhSOSJ5wynFukLMiQkpGtprM F398vbE8q3HKjBAGPn1TnR8tmucVV3tJyRBVIWnAk72m/7C2V9isWXeFzKz0X6wXqNXF LVlTG+KTkpckgodFKs6APUn99uvTRdYUbVgxxJLSg1VCE+gF2JcWjfMaL9qj234riPsL W4XDIaE7GciIKO2Q2xxUI/JsGkT5Cj7TiojCppiPBRPf1SRZS4YX9cjPt0CXq7P+X+8U ffgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@deltatee.com header.s=20200525 header.b=QU91CURp; 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=deltatee.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ji22-20020a170907981600b0073d97252ac7si14243189ejc.49.2022.09.14.09.19.43; Wed, 14 Sep 2022 09:20:09 -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=@deltatee.com header.s=20200525 header.b=QU91CURp; 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=deltatee.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229658AbiINQRA (ORCPT + 99 others); Wed, 14 Sep 2022 12:17:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55332 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229725AbiINQQ6 (ORCPT ); Wed, 14 Sep 2022 12:16:58 -0400 Received: from ale.deltatee.com (ale.deltatee.com [204.191.154.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 577A875FCD; Wed, 14 Sep 2022 09:16:55 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=deltatee.com; s=20200525; h=Subject:In-Reply-To:From:References:Cc:To: MIME-Version:Date:Message-ID:content-disposition; bh=nxy9Jbp5GTwxPBiJKmfbVPecTADs9vQAWIAUvB3MVd4=; b=QU91CURp1MB5WBHbfGBG3nmJKB ilIW0hPaJgD6mS4C86zeb0WH9Gxy+JI6GKMq0depsoKkGiqCPFmJj6w0xuSgrLznAuJdkHBpYgXuj ve1MHZRBvO1TfzaBWz6776YDmWAqMhLKq/KqYn0yF83K/zHdRJVEysxlFD2piprqAAqtTN6nlI3CD t2p13ROrPfvfN/fuMd68TuF9phZLtEbzqVuJs0Jb6X+khfyRuk/NIo6IjGxDWDaLCwkU32ERnVz9w ds3TFOnWvF84joOESzJ8wLXoEVkcl/UZ5JmI7EpNaodG3XrwG48wyovmhOC7XKMSSMEMTDp1M0/b9 sv+3yTKg==; Received: from s0106ac1f6bb1ecac.cg.shawcable.net ([70.73.163.230] helo=[192.168.11.155]) by ale.deltatee.com with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 (Exim 4.94.2) (envelope-from ) id 1oYV3z-001g4o-Mb; Wed, 14 Sep 2022 10:16:36 -0600 Message-ID: Date: Wed, 14 Sep 2022 10:16:31 -0600 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.13.0 Content-Language: en-US To: Yu Kuai , song@kernel.org, guoqing.jiang@linux.dev, pmenzel@molgen.mpg.de Cc: linux-raid@vger.kernel.org, linux-kernel@vger.kernel.org, yukuai3@huawei.com, yi.zhang@huawei.com References: <20220914014914.398712-1-yukuai1@huaweicloud.com> <20220914014914.398712-2-yukuai1@huaweicloud.com> From: Logan Gunthorpe In-Reply-To: <20220914014914.398712-2-yukuai1@huaweicloud.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-SA-Exim-Connect-IP: 70.73.163.230 X-SA-Exim-Rcpt-To: yukuai1@huaweicloud.com, song@kernel.org, guoqing.jiang@linux.dev, pmenzel@molgen.mpg.de, linux-raid@vger.kernel.org, linux-kernel@vger.kernel.org, yukuai3@huawei.com, yi.zhang@huawei.com X-SA-Exim-Mail-From: logang@deltatee.com X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net X-Spam-Level: X-Spam-Status: No, score=-3.7 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 Subject: Re: [PATCH v2 1/4] md/raid10: cleanup wait_barrier() X-SA-Exim-Version: 4.2.1 (built Sat, 13 Feb 2021 17:57:42 +0000) X-SA-Exim-Scanned: Yes (on ale.deltatee.com) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2022-09-13 19:49, Yu Kuai wrote: > From: Yu Kuai > > Currently the nasty condition is wait_barrier() is hard to read. This > patch factor out the condition into a function. > > There are no functional changes. > > Signed-off-by: Yu Kuai > --- > drivers/md/raid10.c | 56 ++++++++++++++++++++++++++------------------- > 1 file changed, 32 insertions(+), 24 deletions(-) > > diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c > index 64d6e4cd8a3a..56458a53043d 100644 > --- a/drivers/md/raid10.c > +++ b/drivers/md/raid10.c > @@ -957,44 +957,52 @@ static void lower_barrier(struct r10conf *conf) > wake_up(&conf->wait_barrier); > } > > +static bool stop_waiting_barrier(struct r10conf *conf) > +{ > + /* barrier is dropped */ > + if (!conf->barrier) > + return true; > + > + /* > + * If there are already pending requests (preventing the barrier from > + * rising completely), and the pre-process bio queue isn't empty, then > + * don't wait, as we need to empty that queue to get the nr_pending > + * count down. > + */ > + if (atomic_read(&conf->nr_pending)) { > + struct bio_list *bio_list = current->bio_list; I'd probably just put the bio_list declaration at the top of this function, then the nested if statements are not necessary. The compiler should be able to optimize the access just fine. > if (conf->barrier) { > - struct bio_list *bio_list = current->bio_list; > - conf->nr_waiting++; > - /* Wait for the barrier to drop. > - * However if there are already pending > - * requests (preventing the barrier from > - * rising completely), and the > - * pre-process bio queue isn't empty, > - * then don't wait, as we need to empty > - * that queue to get the nr_pending > - * count down. > - */ > /* Return false when nowait flag is set */ > if (nowait) { > ret = false; > } else { > + conf->nr_waiting++; Technically speaking, I think moving nr_waiting counts as a functional change. As best as I can see it is correct, but it should probably be at least mentioned in the commit message, or maybe done as a separate commit with it's own justification. That way if it causes problems down the road, a bisect will make the issue clearer. Thanks, Logan