Netdev Archive on lore.kernel.org
help / color / mirror / Atom feed
From: DENG Qingfang <dqfext@gmail.com>
To: Sean Wang <sean.wang@mediatek.com>,
Landen Chao <Landen.Chao@mediatek.com>,
Andrew Lunn <andrew@lunn.ch>,
Vivien Didelot <vivien.didelot@gmail.com>,
Florian Fainelli <f.fainelli@gmail.com>,
Vladimir Oltean <olteanv@gmail.com>,
"David S. Miller" <davem@davemloft.net>,
Jakub Kicinski <kuba@kernel.org>,
Matthias Brugger <matthias.bgg@gmail.com>,
netdev@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
linux-mediatek@lists.infradead.org, linux-kernel@vger.kernel.org
Subject: [RFC net-next 2/2] net: dsa: tag_mtk: handle VLAN tag insertion on TX
Date: Wed, 25 Aug 2021 16:38:31 +0800 [thread overview]
Message-ID: <20210825083832.2425886-3-dqfext@gmail.com> (raw)
In-Reply-To: <20210825083832.2425886-1-dqfext@gmail.com>
Advertise TX VLAN offload features, and handle VLAN tag insertion in
the tag_xmit function.
Signed-off-by: DENG Qingfang <dqfext@gmail.com>
---
net/dsa/tag_mtk.c | 46 ++++++++++++++++++++++------------------------
1 file changed, 22 insertions(+), 24 deletions(-)
diff --git a/net/dsa/tag_mtk.c b/net/dsa/tag_mtk.c
index 415d8ece242a..e407abefa06c 100644
--- a/net/dsa/tag_mtk.c
+++ b/net/dsa/tag_mtk.c
@@ -22,7 +22,6 @@ static struct sk_buff *mtk_tag_xmit(struct sk_buff *skb,
struct net_device *dev)
{
struct dsa_port *dp = dsa_slave_to_port(dev);
- u8 xmit_tpid;
u8 *mtk_tag;
/* Build the special tag after the MAC Source Address. If VLAN header
@@ -31,33 +30,31 @@ static struct sk_buff *mtk_tag_xmit(struct sk_buff *skb,
* the both special and VLAN tag at the same time and then look up VLAN
* table with VID.
*/
- switch (skb->protocol) {
- case htons(ETH_P_8021Q):
- xmit_tpid = MTK_HDR_XMIT_TAGGED_TPID_8100;
- break;
- case htons(ETH_P_8021AD):
- xmit_tpid = MTK_HDR_XMIT_TAGGED_TPID_88A8;
- break;
- default:
- xmit_tpid = MTK_HDR_XMIT_UNTAGGED;
- skb_push(skb, MTK_HDR_LEN);
- dsa_alloc_etype_header(skb, MTK_HDR_LEN);
- }
-
+ skb_push(skb, MTK_HDR_LEN);
+ dsa_alloc_etype_header(skb, MTK_HDR_LEN);
mtk_tag = dsa_etype_header_pos_tx(skb);
- /* Mark tag attribute on special tag insertion to notify hardware
- * whether that's a combined special tag with 802.1Q header.
- */
- mtk_tag[0] = xmit_tpid;
- mtk_tag[1] = (1 << dp->index) & MTK_HDR_XMIT_DP_BIT_MASK;
-
- /* Tag control information is kept for 802.1Q */
- if (xmit_tpid == MTK_HDR_XMIT_UNTAGGED) {
- mtk_tag[2] = 0;
- mtk_tag[3] = 0;
+ if (skb_vlan_tag_present(skb)) {
+ switch (skb->vlan_proto) {
+ case htons(ETH_P_8021Q):
+ mtk_tag[0] = MTK_HDR_XMIT_TAGGED_TPID_8100;
+ break;
+ case htons(ETH_P_8021AD):
+ mtk_tag[0] = MTK_HDR_XMIT_TAGGED_TPID_88A8;
+ break;
+ default:
+ return NULL;
+ }
+
+ ((__be16 *)mtk_tag)[1] = htons(skb_vlan_tag_get(skb));
+ __vlan_hwaccel_clear_tag(skb);
+ } else {
+ mtk_tag[0] = MTK_HDR_XMIT_UNTAGGED;
+ ((__be16 *)mtk_tag)[1] = 0;
}
+ mtk_tag[1] = (1 << dp->index) & MTK_HDR_XMIT_DP_BIT_MASK;
+
return skb;
}
@@ -96,6 +93,7 @@ static const struct dsa_device_ops mtk_netdev_ops = {
.xmit = mtk_tag_xmit,
.rcv = mtk_tag_rcv,
.needed_headroom = MTK_HDR_LEN,
+ .features = NETIF_F_HW_VLAN_CTAG_TX | NETIF_F_HW_VLAN_STAG_TX,
};
MODULE_LICENSE("GPL");
--
2.25.1
next prev parent reply other threads:[~2021-08-25 8:39 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-08-25 8:38 [RFC net-next 0/2] DSA slave with customise netdev features DENG Qingfang
2021-08-25 8:38 ` [RFC net-next 1/2] net: dsa: allow taggers to " DENG Qingfang
2021-08-26 0:01 ` Vladimir Oltean
2021-08-26 11:28 ` Florian Fainelli
2021-08-25 8:38 ` DENG Qingfang [this message]
2021-08-26 0:03 ` [RFC net-next 2/2] net: dsa: tag_mtk: handle VLAN tag insertion on TX Vladimir Oltean
2021-08-26 5:29 ` DENG Qingfang
2021-08-26 11:37 ` Florian Fainelli
2021-08-26 14:13 ` Vladimir Oltean
2021-08-26 15:27 ` DENG Qingfang
2021-08-26 0:00 ` [RFC net-next 0/2] DSA slave with customise netdev features Vladimir Oltean
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20210825083832.2425886-3-dqfext@gmail.com \
--to=dqfext@gmail.com \
--cc=Landen.Chao@mediatek.com \
--cc=andrew@lunn.ch \
--cc=davem@davemloft.net \
--cc=f.fainelli@gmail.com \
--cc=kuba@kernel.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-mediatek@lists.infradead.org \
--cc=matthias.bgg@gmail.com \
--cc=netdev@vger.kernel.org \
--cc=olteanv@gmail.com \
--cc=sean.wang@mediatek.com \
--cc=vivien.didelot@gmail.com \
--subject='Re: [RFC net-next 2/2] net: dsa: tag_mtk: handle VLAN tag insertion on TX' \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).