[PATCH][lunar/linux-azure] net: mana: Add support for vlan tagging

Tim Gardner tim.gardner at canonical.com
Wed Jun 14 14:26:44 UTC 2023


On 6/14/23 01:00, Andrei Gherzan wrote:
> On 23/06/13 02:09PM, Tim Gardner wrote:
>> From: Haiyang Zhang <haiyangz at microsoft.com>
>>
>> BugLink: https://bugs.launchpad.net/bugs/2023695
>>
>> To support vlan, use MANA_LONG_PKT_FMT if vlan tag is present in TX
>> skb. Then extract the vlan tag from the skb struct, and save it to
>> tx_oob for the NIC to transmit. For vlan tags on the payload, they
>> are accepted by the NIC too.
>>
>> For RX, extract the vlan tag from CQE and put it into skb.
>>
>> Signed-off-by: Haiyang Zhang <haiyangz at microsoft.com>
>> Signed-off-by: David S. Miller <davem at davemloft.net>
>> (backported from commit b803d1fded4085d268507a432dac8077ead68971 linux-next)
> 
> Initially I thought this was a small typo and supposed to be a
> clean cherrypick but after trying to apply it I could see that it
> doesn't. As such, we should also include a backport comment - it looks
> like this is due to the same XDP missing features.
> 

Yeah, I just forgot the backport comment (which is the same as the other 
patches). I'll add it when I apply the patch.

>> Signed-off-by: Tim Gardner <tim.gardner at canonical.com>
>> ---
>>   drivers/net/ethernet/microsoft/mana/mana_en.c | 19 +++++++++++++++++--
>>   1 file changed, 17 insertions(+), 2 deletions(-)
>>
>> diff --git a/drivers/net/ethernet/microsoft/mana/mana_en.c b/drivers/net/ethernet/microsoft/mana/mana_en.c
>> index 202f2f34f016..a3b239b401bb 100644
>> --- a/drivers/net/ethernet/microsoft/mana/mana_en.c
>> +++ b/drivers/net/ethernet/microsoft/mana/mana_en.c
>> @@ -179,6 +179,14 @@ netdev_tx_t mana_start_xmit(struct sk_buff *skb, struct net_device *ndev)
>>   		pkg.tx_oob.s_oob.short_vp_offset = txq->vp_offset;
>>   	}
>>   
>> +	if (skb_vlan_tag_present(skb)) {
>> +		pkt_fmt = MANA_LONG_PKT_FMT;
>> +		pkg.tx_oob.l_oob.inject_vlan_pri_tag = 1;
>> +		pkg.tx_oob.l_oob.pcp = skb_vlan_tag_get_prio(skb);
>> +		pkg.tx_oob.l_oob.dei = skb_vlan_tag_get_cfi(skb);
>> +		pkg.tx_oob.l_oob.vlan_id = skb_vlan_tag_get_id(skb);
>> +	}
>> +
>>   	pkg.tx_oob.s_oob.pkt_fmt = pkt_fmt;
>>   
>>   	if (pkt_fmt == MANA_SHORT_PKT_FMT) {
>> @@ -1461,6 +1469,12 @@ static void mana_rx_skb(void *buf_va, struct mana_rxcomp_oob *cqe,
>>   			skb_set_hash(skb, hash_value, PKT_HASH_TYPE_L3);
>>   	}
>>   
>> +	if (cqe->rx_vlantag_present) {
>> +		u16 vlan_tci = cqe->rx_vlan_id;
>> +
>> +		__vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), vlan_tci);
>> +	}
>> +
>>   	u64_stats_update_begin(&rx_stats->syncp);
>>   	rx_stats->packets++;
>>   	rx_stats->bytes += pkt_len;
>> @@ -2461,8 +2475,9 @@ static int mana_probe_port(struct mana_context *ac, int port_idx,
>>   	ndev->hw_features |= NETIF_F_RXCSUM;
>>   	ndev->hw_features |= NETIF_F_TSO | NETIF_F_TSO6;
>>   	ndev->hw_features |= NETIF_F_RXHASH;
>> -	ndev->features = ndev->hw_features;
>> -	ndev->vlan_features = 0;
>> +	ndev->features = ndev->hw_features | NETIF_F_HW_VLAN_CTAG_TX |
>> +			 NETIF_F_HW_VLAN_CTAG_RX;
>> +	ndev->vlan_features = ndev->features;
>>   
>>   	err = register_netdev(ndev);
>>   	if (err) {
>> -- 
>> 2.34.1
> 

-- 
-----------
Tim Gardner
Canonical, Inc




More information about the kernel-team mailing list