Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp303154pxb; Wed, 25 Aug 2021 03:48:16 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyhV9EC2es2jW1rceEYMP2qh4kVut6lP4W1pTzcufgJ8Y0B3It1cUu9V4G3/vwrtTBcuMkv X-Received: by 2002:a92:c542:: with SMTP id a2mr28907997ilj.191.1629888495795; Wed, 25 Aug 2021 03:48:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629888495; cv=none; d=google.com; s=arc-20160816; b=okb/lH/ErnX212tg6p82dWzFDDAA3pO0WuJZM8rgtwaPzsh8lPlVJyJyfxuchp1yTg 2QNRszLWmkT8AfCzdppfH8RSyIozjQhr1MoZD738wJe1ca2NK+B+RM18BkvetbE3GDOc 1UFsjPsoykzmxpop2kjgHgZn4mLlpNilJfTZfBlT4Fp4jgi7nciq2l+RvNTJhQOzT0c9 nvI7j8aBK+cm1uvSkQDLpnzO06tsL0GUAo5XY7ncxlX2U+58rMxhk2kNSYoCGiBQ3dpq 9RPnRjbbEN5j74q3gM+d6on16nL4QjyjfhbBwbSPDJI7qeSJN7EQQc7UtmzlXKEm4L6+ 7kuw== 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:date:subject:to:from :dkim-signature; bh=Dbzh7P/VLZjz7T/PHz/hbVveQrgt7YUkwRS8X1gGPMQ=; b=ZXKEmGNT1Sph2HlSTS+ieZpBtxhkPnto+62iFuO6bCXE1t+eqZX66HZaxyAODu2P4C plWfIR0uFHRNqW9HjgbHqhUr8enGr+PXgw8R3WN+J1Y2hr+awuWG7sAG5BMj6tr0aNLN psCGTYv6ArRJwvLgMJmyR1ZjnwJ/++VUbR9NL83/RqHBTdqncGMGViKnBx3rHF9NLUr8 wZeiVRL6EbMcl1hBzaOA8FpTLj8C4cHn/hkVs75DEZhOYe2cKUITx81C0wlYfLOrtR8u zESV9MjustFp0XkFvJ+gyGu8bWxbhELGSb6MWyg92o/AEg89rjKNKr5A70lKAEt1jdIl Ax7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=PTryOgjr; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id q4si22752185jaj.45.2021.08.25.03.48.03; Wed, 25 Aug 2021 03:48:15 -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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=PTryOgjr; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239338AbhHYIjn (ORCPT + 99 others); Wed, 25 Aug 2021 04:39:43 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43592 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239367AbhHYIjj (ORCPT ); Wed, 25 Aug 2021 04:39:39 -0400 Received: from mail-pg1-x534.google.com (mail-pg1-x534.google.com [IPv6:2607:f8b0:4864:20::534]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C8A4AC0617AE; Wed, 25 Aug 2021 01:38:49 -0700 (PDT) Received: by mail-pg1-x534.google.com with SMTP id w8so22371361pgf.5; Wed, 25 Aug 2021 01:38:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:subject:date:message-id:in-reply-to:references:mime-version :content-transfer-encoding; bh=Dbzh7P/VLZjz7T/PHz/hbVveQrgt7YUkwRS8X1gGPMQ=; b=PTryOgjrkt3xSyLLZ3nI0ySlPsg/rl42Z0nmnf4JRFvvk84qFrsvr2LFark0zt6Zak KupWKcKNvx4c7Kp/JxLfkkMJ5hHP0qa0vGDfzYUEcKlfzYynxZH7176zVLY7hjT/webd RsJkq6SgkfevzO0pn/U5EJneZBoK5QW6SCi+cP1M/1dOLqYHQ+RmwS0iV51F8yTjm0eF r3vARMZhBwWhsOWRwpVF/DAgWgEgb11ZmyT/y6KHl/7s300OE8fwyf9ZYkVgqCCIdvfc fex16reT0nrhHm1tz13SsnBM9Ini/rBK9wRaSpkGpdYP1BhHkX/gxzrIdxd6tnqRFXdH UUrQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=Dbzh7P/VLZjz7T/PHz/hbVveQrgt7YUkwRS8X1gGPMQ=; b=O2r/U/vM2BuoHwtKOjosuDM8O/WNeZvo29h3Ew5MwnLm3seiPBcWm85IjVwtxZH7ZM SH1JicHeCPPlHTIa1e6HbDv4TsIkICfpcsBNI6pkLBjFzvefDXEKAG6H2KJc5lziQkJk ol0g9bv2du7gvPKYOv4E2bBnuw+zAUL1MWBUoC98DWggGfcL5R3A8dbELeACmW7+x8YN 0ZGXgB8FsNBzUuCzgKGyILk2ED6slOck3pLlVv3DS/9cT/LNNeEFh45W+6lrEac/M8xK nO5vKdOfTHdsOipfGfFz9esWYz2CsyNbJYjpCftA8gMxblbe5/r4uI0YGd+jdS0C8XyN DJNQ== X-Gm-Message-State: AOAM533L7sSKF/xF4apUh34vuoj8g9o/aAehGiK35v2W5xcs06cw2lko h9SvgHRfV4OboE7UZRkWRzE= X-Received: by 2002:a63:3dcd:: with SMTP id k196mr1250905pga.387.1629880729365; Wed, 25 Aug 2021 01:38:49 -0700 (PDT) Received: from haswell-ubuntu20.lan ([138.197.212.246]) by smtp.gmail.com with ESMTPSA id p18sm24872294pgk.28.2021.08.25.01.38.44 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 25 Aug 2021 01:38:48 -0700 (PDT) From: DENG Qingfang To: Andrew Lunn , Vivien Didelot , Florian Fainelli , Vladimir Oltean , "David S. Miller" , Jakub Kicinski , Sean Wang , Landen Chao , Matthias Brugger , netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org Subject: [RFC net-next 1/2] net: dsa: allow taggers to customise netdev features Date: Wed, 25 Aug 2021 16:38:30 +0800 Message-Id: <20210825083832.2425886-2-dqfext@gmail.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20210825083832.2425886-1-dqfext@gmail.com> References: <20210825083832.2425886-1-dqfext@gmail.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Allow taggers to add netdev features, such as VLAN offload, to slave devices, which will make it possible for taggers to handle VLAN tags themselves. Signed-off-by: DENG Qingfang --- include/net/dsa.h | 2 ++ net/dsa/slave.c | 3 ++- 2 files changed, 4 insertions(+), 1 deletion(-) diff --git a/include/net/dsa.h b/include/net/dsa.h index f9a17145255a..f65442858f71 100644 --- a/include/net/dsa.h +++ b/include/net/dsa.h @@ -96,6 +96,8 @@ struct dsa_device_ops { * its RX filter. */ bool promisc_on_master; + /* Additional features to be applied to the slave. */ + netdev_features_t features; }; /* This structure defines the control interfaces that are overlayed by the diff --git a/net/dsa/slave.c b/net/dsa/slave.c index 662ff531d4e2..6d6f1aebf1ca 100644 --- a/net/dsa/slave.c +++ b/net/dsa/slave.c @@ -1885,7 +1885,8 @@ void dsa_slave_setup_tagger(struct net_device *slave) p->xmit = cpu_dp->tag_ops->xmit; - slave->features = master->vlan_features | NETIF_F_HW_TC; + slave->features = master->vlan_features | cpu_dp->tag_ops->features | + NETIF_F_HW_TC; slave->hw_features |= NETIF_F_HW_TC; slave->features |= NETIF_F_LLTX; if (slave->needed_tailroom) -- 2.25.1