Received: by 2002:a05:6358:111d:b0:dc:6189:e246 with SMTP id f29csp2006975rwi; Tue, 1 Nov 2022 02:39:28 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4fWMDpnJzfh2RIwy2grvEr7sdizu9hEdbHcspnpxWjJJ8gUZfX7u9G3eCtV5UNeSLCn6Ad X-Received: by 2002:a17:90b:378f:b0:213:acf2:13ba with SMTP id mz15-20020a17090b378f00b00213acf213bamr17696570pjb.25.1667295568375; Tue, 01 Nov 2022 02:39:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1667295568; cv=none; d=google.com; s=arc-20160816; b=OauxRBXe2K/eqDPlqfTvWG9XsugJ7a+RnBK+IQCFQ0wDB9TqCjSGHZ8bm2oFYi1kOI xVBViFhiFbEnvDK3WEIx9u7EhOeuj+PZJv3tURanVFe49cblfh5CC1wE4XXl8pQCu7QT 4+S63BkXZEbgsn8RW7WuDm5WNB8Dyxn934OP8Q9cjL/uoE6w064UNLKnJD4sXmMnG8RV kPoriw459/uM8OSGN5Tl9uajzOVXoFTlSoM7bLX7+ooxIu/UzLBT5fEv90Dss+dd8TH/ OUw44BxuGMiWlxqG6JsreQgyIltMaklTGgozq4hKML1gLerlDh9PbdmugysBiwi5cas1 2VXg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:in-reply-to:message-id :date:subject:cc:to:from; bh=IbqMZi+QSQygCDAX0VIGATvGkAqj54LVO4TcAgQJmaI=; b=GcHHJbiRn+n1W9cMuygJPQTs2186vxkQ9zxC0UigBzVQH0E+7ViAiE+O6QbxPHVM2J 9XkdMKsznKYX9waBga9lO6d4EkGtnPmRiefngQTFheLXx951bDiZUw3QccIpm7aNODpP 6eETZLEOpUkCsIZIMWVBTCpLltfPUWAC3bEQZX3JozJ23oisNXzHLmpzvGYMHhcZXe8B igthwXd40H0Go25GtI/gWm8w+boIfRLBJRwcxNcgfd9wtUCWIU7Dc/+Zs0kgxNWRkUgK bgmFoP2nS0K9TvH4gDJ02KVGwbJ1K/qUTt7WGVS0fbbPKROtalKaQLDzE9jYN13XOXsJ lsGg== 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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l71-20020a63914a000000b0046eecbac482si12269942pge.415.2022.11.01.02.39.15; Tue, 01 Nov 2022 02:39:28 -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=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230314AbiKAJfZ (ORCPT + 97 others); Tue, 1 Nov 2022 05:35:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39994 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230063AbiKAJen (ORCPT ); Tue, 1 Nov 2022 05:34:43 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EB09119027; Tue, 1 Nov 2022 02:34:30 -0700 (PDT) Received: from kwepemi500016.china.huawei.com (unknown [172.30.72.54]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4N1l8r705dzRnsb; Tue, 1 Nov 2022 17:29:32 +0800 (CST) Received: from huawei.com (10.174.178.129) by kwepemi500016.china.huawei.com (7.221.188.220) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Tue, 1 Nov 2022 17:34:28 +0800 From: Kemeng Shi To: , CC: , , Subject: [PATCH 15/20] block, bfq: some cleanups for function bfq_pos_tree_add_move Date: Tue, 1 Nov 2022 17:34:12 +0800 Message-ID: <20221101093417.10540-16-shikemeng@huawei.com> X-Mailer: git-send-email 2.14.1.windows.1 In-Reply-To: <20221101093417.10540-1-shikemeng@huawei.com> References: <20221101093417.10540-1-shikemeng@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.174.178.129] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To kwepemi500016.china.huawei.com (7.221.188.220) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS 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 There are three cleanups in this patch: 1. The oom_bfqq is never inserted to tree, so return immediately for oom_bfqq before unnecessary NULL check of bfqq->pos_root. 2. Only set bfqq->pos_root after bfq_rq_pos_tree_lookup successes rather than set bfqq->pos_root unconditionally and reset to NULL if bfq_rq_pos_tree_lookup fails. 3. Remove unnecessary local variable __bfqq which is only used to check return value of bfq_rq_pos_tree_lookup. Signed-off-by: Kemeng Shi --- block/bfq-iosched.c | 22 ++++++++++------------ 1 file changed, 10 insertions(+), 12 deletions(-) diff --git a/block/bfq-iosched.c b/block/bfq-iosched.c index 776951156fbc..dd9a51255a0f 100644 --- a/block/bfq-iosched.c +++ b/block/bfq-iosched.c @@ -758,17 +758,16 @@ void __cold bfq_pos_tree_add_move(struct bfq_data *bfqd, struct bfq_queue *bfqq) { struct rb_node **p, *parent; - struct bfq_queue *__bfqq; + + /* oom_bfqq does not participate in queue merging */ + if (bfqq == &bfqd->oom_bfqq) + return; if (bfqq->pos_root) { rb_erase(&bfqq->pos_node, bfqq->pos_root); bfqq->pos_root = NULL; } - /* oom_bfqq does not participate in queue merging */ - if (bfqq == &bfqd->oom_bfqq) - return; - /* * bfqq cannot be merged any longer (see comments in * bfq_setup_cooperator): no point in adding bfqq into the @@ -782,14 +781,13 @@ bfq_pos_tree_add_move(struct bfq_data *bfqd, struct bfq_queue *bfqq) if (!bfqq->next_rq) return; + if (bfq_rq_pos_tree_lookup(bfqd, &bfqq_group(bfqq)->rq_pos_tree, + blk_rq_pos(bfqq->next_rq), &parent, &p)) + return; + bfqq->pos_root = &bfqq_group(bfqq)->rq_pos_tree; - __bfqq = bfq_rq_pos_tree_lookup(bfqd, bfqq->pos_root, - blk_rq_pos(bfqq->next_rq), &parent, &p); - if (!__bfqq) { - rb_link_node(&bfqq->pos_node, parent, p); - rb_insert_color(&bfqq->pos_node, bfqq->pos_root); - } else - bfqq->pos_root = NULL; + rb_link_node(&bfqq->pos_node, parent, p); + rb_insert_color(&bfqq->pos_node, bfqq->pos_root); } /* -- 2.30.0