mirror of
https://github.com/torvalds/linux.git
synced 2024-11-28 15:11:31 +00:00
bnxt_en: Validate vlan protocol ID on RX packets
Only pass supported VLAN protocol IDs for stripped VLAN tags to the
stack. The stack will hit WARN() if the protocol ID is unsupported.
Existing firmware sets up the chip to strip 0x8100, 0x88a8, 0x9100.
Only the 1st two protocols are supported by the kernel.
Fixes: a196e96bb6
("bnxt_en: clean up VLAN feature bit handling")
Reviewed-by: Somnath Kotur <somnath.kotur@broadcom.com>
Signed-off-by: Michael Chan <michael.chan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
3958b1da72
commit
96bdd4b9ea
@ -1671,11 +1671,16 @@ static inline struct sk_buff *bnxt_tpa_end(struct bnxt *bp,
|
||||
|
||||
if ((tpa_info->flags2 & RX_CMP_FLAGS2_META_FORMAT_VLAN) &&
|
||||
(skb->dev->features & BNXT_HW_FEATURE_VLAN_ALL_RX)) {
|
||||
u16 vlan_proto = tpa_info->metadata >>
|
||||
RX_CMP_FLAGS2_METADATA_TPID_SFT;
|
||||
__be16 vlan_proto = htons(tpa_info->metadata >>
|
||||
RX_CMP_FLAGS2_METADATA_TPID_SFT);
|
||||
u16 vtag = tpa_info->metadata & RX_CMP_FLAGS2_METADATA_TCI_MASK;
|
||||
|
||||
__vlan_hwaccel_put_tag(skb, htons(vlan_proto), vtag);
|
||||
if (eth_type_vlan(vlan_proto)) {
|
||||
__vlan_hwaccel_put_tag(skb, vlan_proto, vtag);
|
||||
} else {
|
||||
dev_kfree_skb(skb);
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
skb_checksum_none_assert(skb);
|
||||
@ -1897,9 +1902,15 @@ static int bnxt_rx_pkt(struct bnxt *bp, struct bnxt_cp_ring_info *cpr,
|
||||
(skb->dev->features & BNXT_HW_FEATURE_VLAN_ALL_RX)) {
|
||||
u32 meta_data = le32_to_cpu(rxcmp1->rx_cmp_meta_data);
|
||||
u16 vtag = meta_data & RX_CMP_FLAGS2_METADATA_TCI_MASK;
|
||||
u16 vlan_proto = meta_data >> RX_CMP_FLAGS2_METADATA_TPID_SFT;
|
||||
__be16 vlan_proto = htons(meta_data >>
|
||||
RX_CMP_FLAGS2_METADATA_TPID_SFT);
|
||||
|
||||
__vlan_hwaccel_put_tag(skb, htons(vlan_proto), vtag);
|
||||
if (eth_type_vlan(vlan_proto)) {
|
||||
__vlan_hwaccel_put_tag(skb, vlan_proto, vtag);
|
||||
} else {
|
||||
dev_kfree_skb(skb);
|
||||
goto next_rx;
|
||||
}
|
||||
}
|
||||
|
||||
skb_checksum_none_assert(skb);
|
||||
|
Loading…
Reference in New Issue
Block a user