Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp1032795pxj; Wed, 2 Jun 2021 18:50:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy8AxuwIWjwU0HyHTXMjmWFHU7gJpcExs2j+UrnTMFO2SOKx7JBQMMwGgWlIUn1KHlV9+hv X-Received: by 2002:a17:906:174e:: with SMTP id d14mr36999354eje.397.1622685048572; Wed, 02 Jun 2021 18:50:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622685048; cv=none; d=google.com; s=arc-20160816; b=V0hDiRlDpFOC6Lw9SuO2k/KPPBK0QcRxkTvvPlt1H8gEUHQ/oN7TNsTa8ctTNiJQdb IWNqf/5ltNWmm5kOwPqtciSLoKh7zotyHwv5wCUaY+zpZMm82XYsulYN/ibL4KyShz8x EPAZKeGzXCcDXVw89dxE1lWThmMRcaV8fgTyEbWsoUkjjykaLQ3SN4kuUIfYTrve2IFB JEUjUg1iLTH+BqFatpc95dJQ6AV31yIQF4CH4s3y06yOCTpcgjYGOVlFsUECEWSxy0bq dOTrR0xTC6KXkKbxPci3x1CRevS0ygM4ffEISPZHCiEW+3bCU1eNewOJj39oOhuQXSLM OepQ== 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=/Pj5KZOyY1SWAs+bWnHKNvaUugTxije7RU4ZwJvfv+E=; b=fiW41eERSPzIQydE1V37S4GG2BN8nE0cZKaZ1RcGkTPtpN+KceMaktZfaHKAx2c0eF ORHDmPdn9JOMtVBYYmvygrdU288WK0dTqUYLjjhSMVczS7sgMd+HVJtuJ9OyaMY09j17 50CbZBrIAxJYJTs+5DmHNGYd+R7Yr4QbME9avWMQ88/sce13KwcRCADMRwIxp5Z2KRSR UcPGfDC5GVowZJQ8PkyBQtjTayjSEYinfP1qNKIE8xdkJ1dffGUzSKKvaRy0W7snqKAu mfJrfKoRhcNW0kVoN+vVHeLDYz3z9vErcCzEA5OnXtbRmB3Sg778Xm6M2tFhH/Kdr1cS kzMw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v15si1242609edc.109.2021.06.02.18.50.26; Wed, 02 Jun 2021 18:50:48 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229921AbhFCBuH (ORCPT + 99 others); Wed, 2 Jun 2021 21:50:07 -0400 Received: from szxga02-in.huawei.com ([45.249.212.188]:2970 "EHLO szxga02-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229825AbhFCBuA (ORCPT ); Wed, 2 Jun 2021 21:50:00 -0400 Received: from dggemv704-chm.china.huawei.com (unknown [172.30.72.56]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4FwTHH4djnz6tps; Thu, 3 Jun 2021 09:45:15 +0800 (CST) Received: from dggpemm500005.china.huawei.com (7.185.36.74) by dggemv704-chm.china.huawei.com (10.3.19.47) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.2; Thu, 3 Jun 2021 09:48:14 +0800 Received: from localhost.localdomain (10.69.192.56) by dggpemm500005.china.huawei.com (7.185.36.74) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.2; Thu, 3 Jun 2021 09:48:13 +0800 From: Yunsheng Lin To: , CC: , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , Subject: [PATCH net-next v2 3/3] net: sched: remove qdisc->empty for lockless qdisc Date: Thu, 3 Jun 2021 09:48:00 +0800 Message-ID: <1622684880-39895-4-git-send-email-linyunsheng@huawei.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1622684880-39895-1-git-send-email-linyunsheng@huawei.com> References: <1622684880-39895-1-git-send-email-linyunsheng@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.69.192.56] X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To dggpemm500005.china.huawei.com (7.185.36.74) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As MISSED and DRAINING state are used to indicate a non-empty qdisc, qdisc->empty is not longer needed, so remove it. Signed-off-by: Yunsheng Lin --- include/net/sch_generic.h | 13 +++---------- net/sched/sch_generic.c | 3 --- 2 files changed, 3 insertions(+), 13 deletions(-) diff --git a/include/net/sch_generic.h b/include/net/sch_generic.h index 177f240..c99ffe9 100644 --- a/include/net/sch_generic.h +++ b/include/net/sch_generic.h @@ -117,8 +117,6 @@ struct Qdisc { spinlock_t busylock ____cacheline_aligned_in_smp; spinlock_t seqlock; - /* for NOLOCK qdisc, true if there are no enqueued skbs */ - bool empty; struct rcu_head rcu; /* private data */ @@ -165,7 +163,7 @@ static inline bool qdisc_is_percpu_stats(const struct Qdisc *q) static inline bool qdisc_is_empty(const struct Qdisc *qdisc) { if (qdisc_is_percpu_stats(qdisc)) - return READ_ONCE(qdisc->empty); + return nolock_qdisc_is_empty(qdisc); return !READ_ONCE(qdisc->q.qlen); } @@ -173,7 +171,7 @@ static inline bool qdisc_run_begin(struct Qdisc *qdisc) { if (qdisc->flags & TCQ_F_NOLOCK) { if (spin_trylock(&qdisc->seqlock)) - goto nolock_empty; + return true; /* If the MISSED flag is set, it means other thread has * set the MISSED flag before second spin_trylock(), so @@ -195,12 +193,7 @@ static inline bool qdisc_run_begin(struct Qdisc *qdisc) /* Retry again in case other CPU may not see the new flag * after it releases the lock at the end of qdisc_run_end(). */ - if (!spin_trylock(&qdisc->seqlock)) - return false; - -nolock_empty: - WRITE_ONCE(qdisc->empty, false); - return true; + return spin_trylock(&qdisc->seqlock); } else if (qdisc_is_running(qdisc)) { return false; } diff --git a/net/sched/sch_generic.c b/net/sched/sch_generic.c index 83d7f5f..1abd9c7 100644 --- a/net/sched/sch_generic.c +++ b/net/sched/sch_generic.c @@ -707,8 +707,6 @@ static struct sk_buff *pfifo_fast_dequeue(struct Qdisc *qdisc) need_retry = false; goto retry; - } else { - WRITE_ONCE(qdisc->empty, true); } return skb; @@ -909,7 +907,6 @@ struct Qdisc *qdisc_alloc(struct netdev_queue *dev_queue, sch->enqueue = ops->enqueue; sch->dequeue = ops->dequeue; sch->dev_queue = dev_queue; - sch->empty = true; dev_hold(dev); refcount_set(&sch->refcnt, 1); -- 2.7.4