Commit 1b1b2620 authored by Alexander Lobakin's avatar Alexander Lobakin Committed by Tony Nguyen

idpf: reuse libeth's definitions of parsed ptype structures

idpf's in-kernel parsed ptype structure is almost identical to the one
used in the previous Intel drivers, which means it can be converted to
use libeth's definitions and even helpers. The only difference is that
it doesn't use a constant table (libie), rather than one obtained from
the device.
Remove the driver counterpart and use libeth's helpers for hashes and
checksums. This slightly optimizes skb fields processing due to faster
checks. Also don't define big static array of ptypes in &idpf_vport --
allocate them dynamically. The pointer to it is anyway cached in
&idpf_rx_queue.
Reviewed-by: default avatarPrzemek Kitszel <przemyslaw.kitszel@intel.com>
Reviewed-by: default avatarJacob Keller <jacob.e.keller@intel.com>
Signed-off-by: default avatarAlexander Lobakin <aleksander.lobakin@intel.com>
Signed-off-by: default avatarTony Nguyen <anthony.l.nguyen@intel.com>
parent f771314d
...@@ -5,6 +5,7 @@ config IDPF ...@@ -5,6 +5,7 @@ config IDPF
tristate "Intel(R) Infrastructure Data Path Function Support" tristate "Intel(R) Infrastructure Data Path Function Support"
depends on PCI_MSI depends on PCI_MSI
select DIMLIB select DIMLIB
select LIBETH
select PAGE_POOL select PAGE_POOL
select PAGE_POOL_STATS select PAGE_POOL_STATS
help help
......
...@@ -312,7 +312,7 @@ struct idpf_vport { ...@@ -312,7 +312,7 @@ struct idpf_vport {
u16 num_rxq_grp; u16 num_rxq_grp;
struct idpf_rxq_group *rxq_grps; struct idpf_rxq_group *rxq_grps;
u32 rxq_model; u32 rxq_model;
struct idpf_rx_ptype_decoded rx_ptype_lkup[IDPF_RX_MAX_PTYPE]; struct libeth_rx_pt *rx_ptype_lkup;
struct idpf_adapter *adapter; struct idpf_adapter *adapter;
struct net_device *netdev; struct net_device *netdev;
......
...@@ -941,6 +941,9 @@ static void idpf_decfg_netdev(struct idpf_vport *vport) ...@@ -941,6 +941,9 @@ static void idpf_decfg_netdev(struct idpf_vport *vport)
{ {
struct idpf_adapter *adapter = vport->adapter; struct idpf_adapter *adapter = vport->adapter;
kfree(vport->rx_ptype_lkup);
vport->rx_ptype_lkup = NULL;
unregister_netdev(vport->netdev); unregister_netdev(vport->netdev);
free_netdev(vport->netdev); free_netdev(vport->netdev);
vport->netdev = NULL; vport->netdev = NULL;
......
...@@ -8,6 +8,7 @@ ...@@ -8,6 +8,7 @@
#define DRV_SUMMARY "Intel(R) Infrastructure Data Path Function Linux Driver" #define DRV_SUMMARY "Intel(R) Infrastructure Data Path Function Linux Driver"
MODULE_DESCRIPTION(DRV_SUMMARY); MODULE_DESCRIPTION(DRV_SUMMARY);
MODULE_IMPORT_NS(LIBETH);
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
/** /**
......
// SPDX-License-Identifier: GPL-2.0-only // SPDX-License-Identifier: GPL-2.0-only
/* Copyright (C) 2023 Intel Corporation */ /* Copyright (C) 2023 Intel Corporation */
#include <net/libeth/rx.h>
#include "idpf.h" #include "idpf.h"
/** /**
...@@ -601,75 +603,62 @@ static bool idpf_rx_singleq_is_non_eop(const union virtchnl2_rx_desc *rx_desc) ...@@ -601,75 +603,62 @@ static bool idpf_rx_singleq_is_non_eop(const union virtchnl2_rx_desc *rx_desc)
* @rxq: Rx ring being processed * @rxq: Rx ring being processed
* @skb: skb currently being received and modified * @skb: skb currently being received and modified
* @csum_bits: checksum bits from descriptor * @csum_bits: checksum bits from descriptor
* @ptype: the packet type decoded by hardware * @decoded: the packet type decoded by hardware
* *
* skb->protocol must be set before this function is called * skb->protocol must be set before this function is called
*/ */
static void idpf_rx_singleq_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb, static void idpf_rx_singleq_csum(struct idpf_rx_queue *rxq,
struct idpf_rx_csum_decoded *csum_bits, struct sk_buff *skb,
u16 ptype) struct idpf_rx_csum_decoded csum_bits,
struct libeth_rx_pt decoded)
{ {
struct idpf_rx_ptype_decoded decoded;
bool ipv4, ipv6; bool ipv4, ipv6;
/* check if Rx checksum is enabled */ /* check if Rx checksum is enabled */
if (unlikely(!(rxq->netdev->features & NETIF_F_RXCSUM))) if (!libeth_rx_pt_has_checksum(rxq->netdev, decoded))
return; return;
/* check if HW has decoded the packet and checksum */ /* check if HW has decoded the packet and checksum */
if (unlikely(!(csum_bits->l3l4p))) if (unlikely(!csum_bits.l3l4p))
return;
decoded = rxq->rx_ptype_lkup[ptype];
if (unlikely(!(decoded.known && decoded.outer_ip)))
return; return;
ipv4 = IDPF_RX_PTYPE_TO_IPV(&decoded, IDPF_RX_PTYPE_OUTER_IPV4); ipv4 = libeth_rx_pt_get_ip_ver(decoded) == LIBETH_RX_PT_OUTER_IPV4;
ipv6 = IDPF_RX_PTYPE_TO_IPV(&decoded, IDPF_RX_PTYPE_OUTER_IPV6); ipv6 = libeth_rx_pt_get_ip_ver(decoded) == LIBETH_RX_PT_OUTER_IPV6;
/* Check if there were any checksum errors */ /* Check if there were any checksum errors */
if (unlikely(ipv4 && (csum_bits->ipe || csum_bits->eipe))) if (unlikely(ipv4 && (csum_bits.ipe || csum_bits.eipe)))
goto checksum_fail; goto checksum_fail;
/* Device could not do any checksum offload for certain extension /* Device could not do any checksum offload for certain extension
* headers as indicated by setting IPV6EXADD bit * headers as indicated by setting IPV6EXADD bit
*/ */
if (unlikely(ipv6 && csum_bits->ipv6exadd)) if (unlikely(ipv6 && csum_bits.ipv6exadd))
return; return;
/* check for L4 errors and handle packets that were not able to be /* check for L4 errors and handle packets that were not able to be
* checksummed due to arrival speed * checksummed due to arrival speed
*/ */
if (unlikely(csum_bits->l4e)) if (unlikely(csum_bits.l4e))
goto checksum_fail; goto checksum_fail;
if (unlikely(csum_bits->nat && csum_bits->eudpe)) if (unlikely(csum_bits.nat && csum_bits.eudpe))
goto checksum_fail; goto checksum_fail;
/* Handle packets that were not able to be checksummed due to arrival /* Handle packets that were not able to be checksummed due to arrival
* speed, in this case the stack can compute the csum. * speed, in this case the stack can compute the csum.
*/ */
if (unlikely(csum_bits->pprs)) if (unlikely(csum_bits.pprs))
return; return;
/* If there is an outer header present that might contain a checksum /* If there is an outer header present that might contain a checksum
* we need to bump the checksum level by 1 to reflect the fact that * we need to bump the checksum level by 1 to reflect the fact that
* we are indicating we validated the inner checksum. * we are indicating we validated the inner checksum.
*/ */
if (decoded.tunnel_type >= IDPF_RX_PTYPE_TUNNEL_IP_GRENAT) if (decoded.tunnel_type >= LIBETH_RX_PT_TUNNEL_IP_GRENAT)
skb->csum_level = 1; skb->csum_level = 1;
/* Only report checksum unnecessary for ICMP, TCP, UDP, or SCTP */ skb->ip_summed = CHECKSUM_UNNECESSARY;
switch (decoded.inner_prot) { return;
case IDPF_RX_PTYPE_INNER_PROT_ICMP:
case IDPF_RX_PTYPE_INNER_PROT_TCP:
case IDPF_RX_PTYPE_INNER_PROT_UDP:
case IDPF_RX_PTYPE_INNER_PROT_SCTP:
skb->ip_summed = CHECKSUM_UNNECESSARY;
return;
default:
return;
}
checksum_fail: checksum_fail:
u64_stats_update_begin(&rxq->stats_sync); u64_stats_update_begin(&rxq->stats_sync);
...@@ -679,20 +668,17 @@ static void idpf_rx_singleq_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb, ...@@ -679,20 +668,17 @@ static void idpf_rx_singleq_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb,
/** /**
* idpf_rx_singleq_base_csum - Indicate in skb if hw indicated a good cksum * idpf_rx_singleq_base_csum - Indicate in skb if hw indicated a good cksum
* @rx_q: Rx completion queue
* @skb: skb currently being received and modified
* @rx_desc: the receive descriptor * @rx_desc: the receive descriptor
* @ptype: Rx packet type
* *
* This function only operates on the VIRTCHNL2_RXDID_1_32B_BASE_M base 32byte * This function only operates on the VIRTCHNL2_RXDID_1_32B_BASE_M base 32byte
* descriptor writeback format. * descriptor writeback format.
*
* Return: parsed checksum status.
**/ **/
static void idpf_rx_singleq_base_csum(struct idpf_rx_queue *rx_q, static struct idpf_rx_csum_decoded
struct sk_buff *skb, idpf_rx_singleq_base_csum(const union virtchnl2_rx_desc *rx_desc)
const union virtchnl2_rx_desc *rx_desc,
u16 ptype)
{ {
struct idpf_rx_csum_decoded csum_bits; struct idpf_rx_csum_decoded csum_bits = { };
u32 rx_error, rx_status; u32 rx_error, rx_status;
u64 qword; u64 qword;
...@@ -711,28 +697,23 @@ static void idpf_rx_singleq_base_csum(struct idpf_rx_queue *rx_q, ...@@ -711,28 +697,23 @@ static void idpf_rx_singleq_base_csum(struct idpf_rx_queue *rx_q,
rx_status); rx_status);
csum_bits.ipv6exadd = FIELD_GET(VIRTCHNL2_RX_BASE_DESC_STATUS_IPV6EXADD_M, csum_bits.ipv6exadd = FIELD_GET(VIRTCHNL2_RX_BASE_DESC_STATUS_IPV6EXADD_M,
rx_status); rx_status);
csum_bits.nat = 0;
csum_bits.eudpe = 0;
idpf_rx_singleq_csum(rx_q, skb, &csum_bits, ptype); return csum_bits;
} }
/** /**
* idpf_rx_singleq_flex_csum - Indicate in skb if hw indicated a good cksum * idpf_rx_singleq_flex_csum - Indicate in skb if hw indicated a good cksum
* @rx_q: Rx completion queue
* @skb: skb currently being received and modified
* @rx_desc: the receive descriptor * @rx_desc: the receive descriptor
* @ptype: Rx packet type
* *
* This function only operates on the VIRTCHNL2_RXDID_2_FLEX_SQ_NIC flexible * This function only operates on the VIRTCHNL2_RXDID_2_FLEX_SQ_NIC flexible
* descriptor writeback format. * descriptor writeback format.
*
* Return: parsed checksum status.
**/ **/
static void idpf_rx_singleq_flex_csum(struct idpf_rx_queue *rx_q, static struct idpf_rx_csum_decoded
struct sk_buff *skb, idpf_rx_singleq_flex_csum(const union virtchnl2_rx_desc *rx_desc)
const union virtchnl2_rx_desc *rx_desc,
u16 ptype)
{ {
struct idpf_rx_csum_decoded csum_bits; struct idpf_rx_csum_decoded csum_bits = { };
u16 rx_status0, rx_status1; u16 rx_status0, rx_status1;
rx_status0 = le16_to_cpu(rx_desc->flex_nic_wb.status_error0); rx_status0 = le16_to_cpu(rx_desc->flex_nic_wb.status_error0);
...@@ -752,9 +733,8 @@ static void idpf_rx_singleq_flex_csum(struct idpf_rx_queue *rx_q, ...@@ -752,9 +733,8 @@ static void idpf_rx_singleq_flex_csum(struct idpf_rx_queue *rx_q,
rx_status0); rx_status0);
csum_bits.nat = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_STATUS1_NAT_M, csum_bits.nat = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_STATUS1_NAT_M,
rx_status1); rx_status1);
csum_bits.pprs = 0;
idpf_rx_singleq_csum(rx_q, skb, &csum_bits, ptype); return csum_bits;
} }
/** /**
...@@ -770,11 +750,11 @@ static void idpf_rx_singleq_flex_csum(struct idpf_rx_queue *rx_q, ...@@ -770,11 +750,11 @@ static void idpf_rx_singleq_flex_csum(struct idpf_rx_queue *rx_q,
static void idpf_rx_singleq_base_hash(struct idpf_rx_queue *rx_q, static void idpf_rx_singleq_base_hash(struct idpf_rx_queue *rx_q,
struct sk_buff *skb, struct sk_buff *skb,
const union virtchnl2_rx_desc *rx_desc, const union virtchnl2_rx_desc *rx_desc,
struct idpf_rx_ptype_decoded *decoded) struct libeth_rx_pt decoded)
{ {
u64 mask, qw1; u64 mask, qw1;
if (unlikely(!(rx_q->netdev->features & NETIF_F_RXHASH))) if (!libeth_rx_pt_has_hash(rx_q->netdev, decoded))
return; return;
mask = VIRTCHNL2_RX_BASE_DESC_FLTSTAT_RSS_HASH_M; mask = VIRTCHNL2_RX_BASE_DESC_FLTSTAT_RSS_HASH_M;
...@@ -783,7 +763,7 @@ static void idpf_rx_singleq_base_hash(struct idpf_rx_queue *rx_q, ...@@ -783,7 +763,7 @@ static void idpf_rx_singleq_base_hash(struct idpf_rx_queue *rx_q,
if (FIELD_GET(mask, qw1) == mask) { if (FIELD_GET(mask, qw1) == mask) {
u32 hash = le32_to_cpu(rx_desc->base_wb.qword0.hi_dword.rss); u32 hash = le32_to_cpu(rx_desc->base_wb.qword0.hi_dword.rss);
skb_set_hash(skb, hash, idpf_ptype_to_htype(decoded)); libeth_rx_pt_set_hash(skb, hash, decoded);
} }
} }
...@@ -800,15 +780,17 @@ static void idpf_rx_singleq_base_hash(struct idpf_rx_queue *rx_q, ...@@ -800,15 +780,17 @@ static void idpf_rx_singleq_base_hash(struct idpf_rx_queue *rx_q,
static void idpf_rx_singleq_flex_hash(struct idpf_rx_queue *rx_q, static void idpf_rx_singleq_flex_hash(struct idpf_rx_queue *rx_q,
struct sk_buff *skb, struct sk_buff *skb,
const union virtchnl2_rx_desc *rx_desc, const union virtchnl2_rx_desc *rx_desc,
struct idpf_rx_ptype_decoded *decoded) struct libeth_rx_pt decoded)
{ {
if (unlikely(!(rx_q->netdev->features & NETIF_F_RXHASH))) if (!libeth_rx_pt_has_hash(rx_q->netdev, decoded))
return; return;
if (FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_STATUS0_RSS_VALID_M, if (FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_STATUS0_RSS_VALID_M,
le16_to_cpu(rx_desc->flex_nic_wb.status_error0))) le16_to_cpu(rx_desc->flex_nic_wb.status_error0))) {
skb_set_hash(skb, le32_to_cpu(rx_desc->flex_nic_wb.rss_hash), u32 hash = le32_to_cpu(rx_desc->flex_nic_wb.rss_hash);
idpf_ptype_to_htype(decoded));
libeth_rx_pt_set_hash(skb, hash, decoded);
}
} }
/** /**
...@@ -829,19 +811,22 @@ idpf_rx_singleq_process_skb_fields(struct idpf_rx_queue *rx_q, ...@@ -829,19 +811,22 @@ idpf_rx_singleq_process_skb_fields(struct idpf_rx_queue *rx_q,
const union virtchnl2_rx_desc *rx_desc, const union virtchnl2_rx_desc *rx_desc,
u16 ptype) u16 ptype)
{ {
struct idpf_rx_ptype_decoded decoded = rx_q->rx_ptype_lkup[ptype]; struct libeth_rx_pt decoded = rx_q->rx_ptype_lkup[ptype];
struct idpf_rx_csum_decoded csum_bits;
/* modifies the skb - consumes the enet header */ /* modifies the skb - consumes the enet header */
skb->protocol = eth_type_trans(skb, rx_q->netdev); skb->protocol = eth_type_trans(skb, rx_q->netdev);
/* Check if we're using base mode descriptor IDs */ /* Check if we're using base mode descriptor IDs */
if (rx_q->rxdids == VIRTCHNL2_RXDID_1_32B_BASE_M) { if (rx_q->rxdids == VIRTCHNL2_RXDID_1_32B_BASE_M) {
idpf_rx_singleq_base_hash(rx_q, skb, rx_desc, &decoded); idpf_rx_singleq_base_hash(rx_q, skb, rx_desc, decoded);
idpf_rx_singleq_base_csum(rx_q, skb, rx_desc, ptype); csum_bits = idpf_rx_singleq_base_csum(rx_desc);
} else { } else {
idpf_rx_singleq_flex_hash(rx_q, skb, rx_desc, &decoded); idpf_rx_singleq_flex_hash(rx_q, skb, rx_desc, decoded);
idpf_rx_singleq_flex_csum(rx_q, skb, rx_desc, ptype); csum_bits = idpf_rx_singleq_flex_csum(rx_desc);
} }
idpf_rx_singleq_csum(rx_q, skb, csum_bits, decoded);
} }
/** /**
......
// SPDX-License-Identifier: GPL-2.0-only // SPDX-License-Identifier: GPL-2.0-only
/* Copyright (C) 2023 Intel Corporation */ /* Copyright (C) 2023 Intel Corporation */
#include <net/libeth/rx.h>
#include "idpf.h" #include "idpf.h"
#include "idpf_virtchnl.h" #include "idpf_virtchnl.h"
...@@ -2886,30 +2888,6 @@ netdev_tx_t idpf_tx_start(struct sk_buff *skb, struct net_device *netdev) ...@@ -2886,30 +2888,6 @@ netdev_tx_t idpf_tx_start(struct sk_buff *skb, struct net_device *netdev)
return idpf_tx_singleq_frame(skb, tx_q); return idpf_tx_singleq_frame(skb, tx_q);
} }
/**
* idpf_ptype_to_htype - get a hash type
* @decoded: Decoded Rx packet type related fields
*
* Returns appropriate hash type (such as PKT_HASH_TYPE_L2/L3/L4) to be used by
* skb_set_hash based on PTYPE as parsed by HW Rx pipeline and is part of
* Rx desc.
*/
enum pkt_hash_types idpf_ptype_to_htype(const struct idpf_rx_ptype_decoded *decoded)
{
if (!decoded->known)
return PKT_HASH_TYPE_NONE;
if (decoded->payload_layer == IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY2 &&
decoded->inner_prot)
return PKT_HASH_TYPE_L4;
if (decoded->payload_layer == IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY2 &&
decoded->outer_ip)
return PKT_HASH_TYPE_L3;
if (decoded->outer_ip == IDPF_RX_PTYPE_OUTER_L2)
return PKT_HASH_TYPE_L2;
return PKT_HASH_TYPE_NONE;
}
/** /**
* idpf_rx_hash - set the hash value in the skb * idpf_rx_hash - set the hash value in the skb
* @rxq: Rx descriptor ring packet is being transacted on * @rxq: Rx descriptor ring packet is being transacted on
...@@ -2920,18 +2898,18 @@ enum pkt_hash_types idpf_ptype_to_htype(const struct idpf_rx_ptype_decoded *deco ...@@ -2920,18 +2898,18 @@ enum pkt_hash_types idpf_ptype_to_htype(const struct idpf_rx_ptype_decoded *deco
static void static void
idpf_rx_hash(const struct idpf_rx_queue *rxq, struct sk_buff *skb, idpf_rx_hash(const struct idpf_rx_queue *rxq, struct sk_buff *skb,
const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc, const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc,
struct idpf_rx_ptype_decoded *decoded) struct libeth_rx_pt decoded)
{ {
u32 hash; u32 hash;
if (unlikely(!(rxq->netdev->features & NETIF_F_RXHASH))) if (!libeth_rx_pt_has_hash(rxq->netdev, decoded))
return; return;
hash = le16_to_cpu(rx_desc->hash1) | hash = le16_to_cpu(rx_desc->hash1) |
(rx_desc->ff2_mirrid_hash2.hash2 << 16) | (rx_desc->ff2_mirrid_hash2.hash2 << 16) |
(rx_desc->hash3 << 24); (rx_desc->hash3 << 24);
skb_set_hash(skb, hash, idpf_ptype_to_htype(decoded)); libeth_rx_pt_set_hash(skb, hash, decoded);
} }
/** /**
...@@ -2944,55 +2922,43 @@ idpf_rx_hash(const struct idpf_rx_queue *rxq, struct sk_buff *skb, ...@@ -2944,55 +2922,43 @@ idpf_rx_hash(const struct idpf_rx_queue *rxq, struct sk_buff *skb,
* skb->protocol must be set before this function is called * skb->protocol must be set before this function is called
*/ */
static void idpf_rx_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb, static void idpf_rx_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb,
struct idpf_rx_csum_decoded *csum_bits, struct idpf_rx_csum_decoded csum_bits,
struct idpf_rx_ptype_decoded *decoded) struct libeth_rx_pt decoded)
{ {
bool ipv4, ipv6; bool ipv4, ipv6;
/* check if Rx checksum is enabled */ /* check if Rx checksum is enabled */
if (unlikely(!(rxq->netdev->features & NETIF_F_RXCSUM))) if (!libeth_rx_pt_has_checksum(rxq->netdev, decoded))
return; return;
/* check if HW has decoded the packet and checksum */ /* check if HW has decoded the packet and checksum */
if (!(csum_bits->l3l4p)) if (unlikely(!csum_bits.l3l4p))
return; return;
ipv4 = IDPF_RX_PTYPE_TO_IPV(decoded, IDPF_RX_PTYPE_OUTER_IPV4); ipv4 = libeth_rx_pt_get_ip_ver(decoded) == LIBETH_RX_PT_OUTER_IPV4;
ipv6 = IDPF_RX_PTYPE_TO_IPV(decoded, IDPF_RX_PTYPE_OUTER_IPV6); ipv6 = libeth_rx_pt_get_ip_ver(decoded) == LIBETH_RX_PT_OUTER_IPV6;
if (ipv4 && (csum_bits->ipe || csum_bits->eipe)) if (unlikely(ipv4 && (csum_bits.ipe || csum_bits.eipe)))
goto checksum_fail; goto checksum_fail;
if (ipv6 && csum_bits->ipv6exadd) if (unlikely(ipv6 && csum_bits.ipv6exadd))
return; return;
/* check for L4 errors and handle packets that were not able to be /* check for L4 errors and handle packets that were not able to be
* checksummed * checksummed
*/ */
if (csum_bits->l4e) if (unlikely(csum_bits.l4e))
goto checksum_fail; goto checksum_fail;
/* Only report checksum unnecessary for ICMP, TCP, UDP, or SCTP */ if (csum_bits.raw_csum_inv ||
switch (decoded->inner_prot) { decoded.inner_prot == LIBETH_RX_PT_INNER_SCTP) {
case IDPF_RX_PTYPE_INNER_PROT_ICMP:
case IDPF_RX_PTYPE_INNER_PROT_TCP:
case IDPF_RX_PTYPE_INNER_PROT_UDP:
if (!csum_bits->raw_csum_inv) {
u16 csum = csum_bits->raw_csum;
skb->csum = csum_unfold((__force __sum16)~swab16(csum));
skb->ip_summed = CHECKSUM_COMPLETE;
} else {
skb->ip_summed = CHECKSUM_UNNECESSARY;
}
break;
case IDPF_RX_PTYPE_INNER_PROT_SCTP:
skb->ip_summed = CHECKSUM_UNNECESSARY; skb->ip_summed = CHECKSUM_UNNECESSARY;
break; return;
default:
break;
} }
skb->csum = csum_unfold((__force __sum16)~swab16(csum_bits.raw_csum));
skb->ip_summed = CHECKSUM_COMPLETE;
return; return;
checksum_fail: checksum_fail:
...@@ -3004,32 +2970,34 @@ static void idpf_rx_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb, ...@@ -3004,32 +2970,34 @@ static void idpf_rx_csum(struct idpf_rx_queue *rxq, struct sk_buff *skb,
/** /**
* idpf_rx_splitq_extract_csum_bits - Extract checksum bits from descriptor * idpf_rx_splitq_extract_csum_bits - Extract checksum bits from descriptor
* @rx_desc: receive descriptor * @rx_desc: receive descriptor
* @csum: structure to extract checksum fields
* *
* Return: parsed checksum status.
**/ **/
static void static struct idpf_rx_csum_decoded
idpf_rx_splitq_extract_csum_bits(const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc, idpf_rx_splitq_extract_csum_bits(const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc)
struct idpf_rx_csum_decoded *csum)
{ {
struct idpf_rx_csum_decoded csum = { };
u8 qword0, qword1; u8 qword0, qword1;
qword0 = rx_desc->status_err0_qw0; qword0 = rx_desc->status_err0_qw0;
qword1 = rx_desc->status_err0_qw1; qword1 = rx_desc->status_err0_qw1;
csum->ipe = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_XSUM_IPE_M, csum.ipe = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_XSUM_IPE_M,
qword1);
csum.eipe = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_XSUM_EIPE_M,
qword1); qword1);
csum->eipe = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_XSUM_EIPE_M, csum.l4e = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_XSUM_L4E_M,
qword1);
csum.l3l4p = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_L3L4P_M,
qword1); qword1);
csum->l4e = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_XSUM_L4E_M, csum.ipv6exadd = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_IPV6EXADD_M,
qword1); qword0);
csum->l3l4p = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_L3L4P_M, csum.raw_csum_inv =
qword1);
csum->ipv6exadd = FIELD_GET(VIRTCHNL2_RX_FLEX_DESC_ADV_STATUS0_IPV6EXADD_M,
qword0);
csum->raw_csum_inv =
le16_get_bits(rx_desc->ptype_err_fflags0, le16_get_bits(rx_desc->ptype_err_fflags0,
VIRTCHNL2_RX_FLEX_DESC_ADV_RAW_CSUM_INV_M); VIRTCHNL2_RX_FLEX_DESC_ADV_RAW_CSUM_INV_M);
csum->raw_csum = le16_to_cpu(rx_desc->misc.raw_cs); csum.raw_csum = le16_to_cpu(rx_desc->misc.raw_cs);
return csum;
} }
/** /**
...@@ -3046,21 +3014,22 @@ idpf_rx_splitq_extract_csum_bits(const struct virtchnl2_rx_flex_desc_adv_nic_3 * ...@@ -3046,21 +3014,22 @@ idpf_rx_splitq_extract_csum_bits(const struct virtchnl2_rx_flex_desc_adv_nic_3 *
*/ */
static int idpf_rx_rsc(struct idpf_rx_queue *rxq, struct sk_buff *skb, static int idpf_rx_rsc(struct idpf_rx_queue *rxq, struct sk_buff *skb,
const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc, const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc,
struct idpf_rx_ptype_decoded *decoded) struct libeth_rx_pt decoded)
{ {
u16 rsc_segments, rsc_seg_len; u16 rsc_segments, rsc_seg_len;
bool ipv4, ipv6; bool ipv4, ipv6;
int len; int len;
if (unlikely(!decoded->outer_ip)) if (unlikely(libeth_rx_pt_get_ip_ver(decoded) ==
LIBETH_RX_PT_OUTER_L2))
return -EINVAL; return -EINVAL;
rsc_seg_len = le16_to_cpu(rx_desc->misc.rscseglen); rsc_seg_len = le16_to_cpu(rx_desc->misc.rscseglen);
if (unlikely(!rsc_seg_len)) if (unlikely(!rsc_seg_len))
return -EINVAL; return -EINVAL;
ipv4 = IDPF_RX_PTYPE_TO_IPV(decoded, IDPF_RX_PTYPE_OUTER_IPV4); ipv4 = libeth_rx_pt_get_ip_ver(decoded) == LIBETH_RX_PT_OUTER_IPV4;
ipv6 = IDPF_RX_PTYPE_TO_IPV(decoded, IDPF_RX_PTYPE_OUTER_IPV6); ipv6 = libeth_rx_pt_get_ip_ver(decoded) == LIBETH_RX_PT_OUTER_IPV6;
if (unlikely(!(ipv4 ^ ipv6))) if (unlikely(!(ipv4 ^ ipv6)))
return -EINVAL; return -EINVAL;
...@@ -3118,8 +3087,8 @@ static int ...@@ -3118,8 +3087,8 @@ static int
idpf_rx_process_skb_fields(struct idpf_rx_queue *rxq, struct sk_buff *skb, idpf_rx_process_skb_fields(struct idpf_rx_queue *rxq, struct sk_buff *skb,
const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc) const struct virtchnl2_rx_flex_desc_adv_nic_3 *rx_desc)
{ {
struct idpf_rx_csum_decoded csum_bits = { }; struct idpf_rx_csum_decoded csum_bits;
struct idpf_rx_ptype_decoded decoded; struct libeth_rx_pt decoded;
u16 rx_ptype; u16 rx_ptype;
rx_ptype = le16_get_bits(rx_desc->ptype_err_fflags0, rx_ptype = le16_get_bits(rx_desc->ptype_err_fflags0,
...@@ -3127,16 +3096,16 @@ idpf_rx_process_skb_fields(struct idpf_rx_queue *rxq, struct sk_buff *skb, ...@@ -3127,16 +3096,16 @@ idpf_rx_process_skb_fields(struct idpf_rx_queue *rxq, struct sk_buff *skb,
decoded = rxq->rx_ptype_lkup[rx_ptype]; decoded = rxq->rx_ptype_lkup[rx_ptype];
/* process RSS/hash */ /* process RSS/hash */
idpf_rx_hash(rxq, skb, rx_desc, &decoded); idpf_rx_hash(rxq, skb, rx_desc, decoded);
skb->protocol = eth_type_trans(skb, rxq->netdev); skb->protocol = eth_type_trans(skb, rxq->netdev);
if (le16_get_bits(rx_desc->hdrlen_flags, if (le16_get_bits(rx_desc->hdrlen_flags,
VIRTCHNL2_RX_FLEX_DESC_ADV_RSC_M)) VIRTCHNL2_RX_FLEX_DESC_ADV_RSC_M))
return idpf_rx_rsc(rxq, skb, rx_desc, &decoded); return idpf_rx_rsc(rxq, skb, rx_desc, decoded);
idpf_rx_splitq_extract_csum_bits(rx_desc, &csum_bits); csum_bits = idpf_rx_splitq_extract_csum_bits(rx_desc);
idpf_rx_csum(rxq, skb, &csum_bits, &decoded); idpf_rx_csum(rxq, skb, csum_bits, decoded);
return 0; return 0;
} }
......
...@@ -331,72 +331,6 @@ struct idpf_rx_buf { ...@@ -331,72 +331,6 @@ struct idpf_rx_buf {
#define IDPF_RX_MAX_BASE_PTYPE 256 #define IDPF_RX_MAX_BASE_PTYPE 256
#define IDPF_INVALID_PTYPE_ID 0xFFFF #define IDPF_INVALID_PTYPE_ID 0xFFFF
/* Packet type non-ip values */
enum idpf_rx_ptype_l2 {
IDPF_RX_PTYPE_L2_RESERVED = 0,
IDPF_RX_PTYPE_L2_MAC_PAY2 = 1,
IDPF_RX_PTYPE_L2_TIMESYNC_PAY2 = 2,
IDPF_RX_PTYPE_L2_FIP_PAY2 = 3,
IDPF_RX_PTYPE_L2_OUI_PAY2 = 4,
IDPF_RX_PTYPE_L2_MACCNTRL_PAY2 = 5,
IDPF_RX_PTYPE_L2_LLDP_PAY2 = 6,
IDPF_RX_PTYPE_L2_ECP_PAY2 = 7,
IDPF_RX_PTYPE_L2_EVB_PAY2 = 8,
IDPF_RX_PTYPE_L2_QCN_PAY2 = 9,
IDPF_RX_PTYPE_L2_EAPOL_PAY2 = 10,
IDPF_RX_PTYPE_L2_ARP = 11,
};
enum idpf_rx_ptype_outer_ip {
IDPF_RX_PTYPE_OUTER_L2 = 0,
IDPF_RX_PTYPE_OUTER_IP = 1,
};
#define IDPF_RX_PTYPE_TO_IPV(ptype, ipv) \
(((ptype)->outer_ip == IDPF_RX_PTYPE_OUTER_IP) && \
((ptype)->outer_ip_ver == (ipv)))
enum idpf_rx_ptype_outer_ip_ver {
IDPF_RX_PTYPE_OUTER_NONE = 0,
IDPF_RX_PTYPE_OUTER_IPV4 = 1,
IDPF_RX_PTYPE_OUTER_IPV6 = 2,
};
enum idpf_rx_ptype_outer_fragmented {
IDPF_RX_PTYPE_NOT_FRAG = 0,
IDPF_RX_PTYPE_FRAG = 1,
};
enum idpf_rx_ptype_tunnel_type {
IDPF_RX_PTYPE_TUNNEL_NONE = 0,
IDPF_RX_PTYPE_TUNNEL_IP_IP = 1,
IDPF_RX_PTYPE_TUNNEL_IP_GRENAT = 2,
IDPF_RX_PTYPE_TUNNEL_IP_GRENAT_MAC = 3,
IDPF_RX_PTYPE_TUNNEL_IP_GRENAT_MAC_VLAN = 4,
};
enum idpf_rx_ptype_tunnel_end_prot {
IDPF_RX_PTYPE_TUNNEL_END_NONE = 0,
IDPF_RX_PTYPE_TUNNEL_END_IPV4 = 1,
IDPF_RX_PTYPE_TUNNEL_END_IPV6 = 2,
};
enum idpf_rx_ptype_inner_prot {
IDPF_RX_PTYPE_INNER_PROT_NONE = 0,
IDPF_RX_PTYPE_INNER_PROT_UDP = 1,
IDPF_RX_PTYPE_INNER_PROT_TCP = 2,
IDPF_RX_PTYPE_INNER_PROT_SCTP = 3,
IDPF_RX_PTYPE_INNER_PROT_ICMP = 4,
IDPF_RX_PTYPE_INNER_PROT_TIMESYNC = 5,
};
enum idpf_rx_ptype_payload_layer {
IDPF_RX_PTYPE_PAYLOAD_LAYER_NONE = 0,
IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY2 = 1,
IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY3 = 2,
IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY4 = 3,
};
enum idpf_tunnel_state { enum idpf_tunnel_state {
IDPF_PTYPE_TUNNEL_IP = BIT(0), IDPF_PTYPE_TUNNEL_IP = BIT(0),
IDPF_PTYPE_TUNNEL_IP_GRENAT = BIT(1), IDPF_PTYPE_TUNNEL_IP_GRENAT = BIT(1),
...@@ -404,22 +338,9 @@ enum idpf_tunnel_state { ...@@ -404,22 +338,9 @@ enum idpf_tunnel_state {
}; };
struct idpf_ptype_state { struct idpf_ptype_state {
bool outer_ip; bool outer_ip:1;
bool outer_frag; bool outer_frag:1;
u8 tunnel_state; u8 tunnel_state:6;
};
struct idpf_rx_ptype_decoded {
u32 ptype:10;
u32 known:1;
u32 outer_ip:1;
u32 outer_ip_ver:2;
u32 outer_frag:1;
u32 tunnel_type:3;
u32 tunnel_end_prot:2;
u32 tunnel_end_frag:1;
u32 inner_prot:4;
u32 payload_layer:3;
}; };
/** /**
...@@ -677,7 +598,7 @@ struct idpf_rx_queue { ...@@ -677,7 +598,7 @@ struct idpf_rx_queue {
u16 desc_count; u16 desc_count;
u32 rxdids; u32 rxdids;
const struct idpf_rx_ptype_decoded *rx_ptype_lkup; const struct libeth_rx_pt *rx_ptype_lkup;
__cacheline_group_end_aligned(read_mostly); __cacheline_group_end_aligned(read_mostly);
__cacheline_group_begin_aligned(read_write); __cacheline_group_begin_aligned(read_write);
...@@ -1180,7 +1101,6 @@ void idpf_vport_intr_update_itr_ena_irq(struct idpf_q_vector *q_vector); ...@@ -1180,7 +1101,6 @@ void idpf_vport_intr_update_itr_ena_irq(struct idpf_q_vector *q_vector);
void idpf_vport_intr_deinit(struct idpf_vport *vport); void idpf_vport_intr_deinit(struct idpf_vport *vport);
int idpf_vport_intr_init(struct idpf_vport *vport); int idpf_vport_intr_init(struct idpf_vport *vport);
void idpf_vport_intr_ena(struct idpf_vport *vport); void idpf_vport_intr_ena(struct idpf_vport *vport);
enum pkt_hash_types idpf_ptype_to_htype(const struct idpf_rx_ptype_decoded *decoded);
int idpf_config_rss(struct idpf_vport *vport); int idpf_config_rss(struct idpf_vport *vport);
int idpf_init_rss(struct idpf_vport *vport); int idpf_init_rss(struct idpf_vport *vport);
void idpf_deinit_rss(struct idpf_vport *vport); void idpf_deinit_rss(struct idpf_vport *vport);
......
// SPDX-License-Identifier: GPL-2.0-only // SPDX-License-Identifier: GPL-2.0-only
/* Copyright (C) 2023 Intel Corporation */ /* Copyright (C) 2023 Intel Corporation */
#include <net/libeth/rx.h>
#include "idpf.h" #include "idpf.h"
#include "idpf_virtchnl.h" #include "idpf_virtchnl.h"
...@@ -2483,39 +2485,52 @@ int idpf_send_get_set_rss_key_msg(struct idpf_vport *vport, bool get) ...@@ -2483,39 +2485,52 @@ int idpf_send_get_set_rss_key_msg(struct idpf_vport *vport, bool get)
* @frag: fragmentation allowed * @frag: fragmentation allowed
* *
*/ */
static void idpf_fill_ptype_lookup(struct idpf_rx_ptype_decoded *ptype, static void idpf_fill_ptype_lookup(struct libeth_rx_pt *ptype,
struct idpf_ptype_state *pstate, struct idpf_ptype_state *pstate,
bool ipv4, bool frag) bool ipv4, bool frag)
{ {
if (!pstate->outer_ip || !pstate->outer_frag) { if (!pstate->outer_ip || !pstate->outer_frag) {
ptype->outer_ip = IDPF_RX_PTYPE_OUTER_IP;
pstate->outer_ip = true; pstate->outer_ip = true;
if (ipv4) if (ipv4)
ptype->outer_ip_ver = IDPF_RX_PTYPE_OUTER_IPV4; ptype->outer_ip = LIBETH_RX_PT_OUTER_IPV4;
else else
ptype->outer_ip_ver = IDPF_RX_PTYPE_OUTER_IPV6; ptype->outer_ip = LIBETH_RX_PT_OUTER_IPV6;
if (frag) { if (frag) {
ptype->outer_frag = IDPF_RX_PTYPE_FRAG; ptype->outer_frag = LIBETH_RX_PT_FRAG;
pstate->outer_frag = true; pstate->outer_frag = true;
} }
} else { } else {
ptype->tunnel_type = IDPF_RX_PTYPE_TUNNEL_IP_IP; ptype->tunnel_type = LIBETH_RX_PT_TUNNEL_IP_IP;
pstate->tunnel_state = IDPF_PTYPE_TUNNEL_IP; pstate->tunnel_state = IDPF_PTYPE_TUNNEL_IP;
if (ipv4) if (ipv4)
ptype->tunnel_end_prot = ptype->tunnel_end_prot = LIBETH_RX_PT_TUNNEL_END_IPV4;
IDPF_RX_PTYPE_TUNNEL_END_IPV4;
else else
ptype->tunnel_end_prot = ptype->tunnel_end_prot = LIBETH_RX_PT_TUNNEL_END_IPV6;
IDPF_RX_PTYPE_TUNNEL_END_IPV6;
if (frag) if (frag)
ptype->tunnel_end_frag = IDPF_RX_PTYPE_FRAG; ptype->tunnel_end_frag = LIBETH_RX_PT_FRAG;
} }
} }
static void idpf_finalize_ptype_lookup(struct libeth_rx_pt *ptype)
{
if (ptype->payload_layer == LIBETH_RX_PT_PAYLOAD_L2 &&
ptype->inner_prot)
ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_L4;
else if (ptype->payload_layer == LIBETH_RX_PT_PAYLOAD_L2 &&
ptype->outer_ip)
ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_L3;
else if (ptype->outer_ip == LIBETH_RX_PT_OUTER_L2)
ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_L2;
else
ptype->payload_layer = LIBETH_RX_PT_PAYLOAD_NONE;
libeth_rx_pt_gen_hash_type(ptype);
}
/** /**
* idpf_send_get_rx_ptype_msg - Send virtchnl for ptype info * idpf_send_get_rx_ptype_msg - Send virtchnl for ptype info
* @vport: virtual port data structure * @vport: virtual port data structure
...@@ -2526,7 +2541,7 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport) ...@@ -2526,7 +2541,7 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
{ {
struct virtchnl2_get_ptype_info *get_ptype_info __free(kfree) = NULL; struct virtchnl2_get_ptype_info *get_ptype_info __free(kfree) = NULL;
struct virtchnl2_get_ptype_info *ptype_info __free(kfree) = NULL; struct virtchnl2_get_ptype_info *ptype_info __free(kfree) = NULL;
struct idpf_rx_ptype_decoded *ptype_lkup = vport->rx_ptype_lkup; struct libeth_rx_pt *ptype_lkup __free(kfree) = NULL;
int max_ptype, ptypes_recvd = 0, ptype_offset; int max_ptype, ptypes_recvd = 0, ptype_offset;
struct idpf_adapter *adapter = vport->adapter; struct idpf_adapter *adapter = vport->adapter;
struct idpf_vc_xn_params xn_params = {}; struct idpf_vc_xn_params xn_params = {};
...@@ -2534,12 +2549,17 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport) ...@@ -2534,12 +2549,17 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
ssize_t reply_sz; ssize_t reply_sz;
int i, j, k; int i, j, k;
if (vport->rx_ptype_lkup)
return 0;
if (idpf_is_queue_model_split(vport->rxq_model)) if (idpf_is_queue_model_split(vport->rxq_model))
max_ptype = IDPF_RX_MAX_PTYPE; max_ptype = IDPF_RX_MAX_PTYPE;
else else
max_ptype = IDPF_RX_MAX_BASE_PTYPE; max_ptype = IDPF_RX_MAX_BASE_PTYPE;
memset(vport->rx_ptype_lkup, 0, sizeof(vport->rx_ptype_lkup)); ptype_lkup = kcalloc(max_ptype, sizeof(*ptype_lkup), GFP_KERNEL);
if (!ptype_lkup)
return -ENOMEM;
get_ptype_info = kzalloc(sizeof(*get_ptype_info), GFP_KERNEL); get_ptype_info = kzalloc(sizeof(*get_ptype_info), GFP_KERNEL);
if (!get_ptype_info) if (!get_ptype_info)
...@@ -2597,16 +2617,13 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport) ...@@ -2597,16 +2617,13 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
/* 0xFFFF indicates end of ptypes */ /* 0xFFFF indicates end of ptypes */
if (le16_to_cpu(ptype->ptype_id_10) == if (le16_to_cpu(ptype->ptype_id_10) ==
IDPF_INVALID_PTYPE_ID) IDPF_INVALID_PTYPE_ID)
return 0; goto out;
if (idpf_is_queue_model_split(vport->rxq_model)) if (idpf_is_queue_model_split(vport->rxq_model))
k = le16_to_cpu(ptype->ptype_id_10); k = le16_to_cpu(ptype->ptype_id_10);
else else
k = ptype->ptype_id_8; k = ptype->ptype_id_8;
if (ptype->proto_id_count)
ptype_lkup[k].known = 1;
for (j = 0; j < ptype->proto_id_count; j++) { for (j = 0; j < ptype->proto_id_count; j++) {
id = le16_to_cpu(ptype->proto_id[j]); id = le16_to_cpu(ptype->proto_id[j]);
switch (id) { switch (id) {
...@@ -2614,18 +2631,18 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport) ...@@ -2614,18 +2631,18 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
if (pstate.tunnel_state == if (pstate.tunnel_state ==
IDPF_PTYPE_TUNNEL_IP) { IDPF_PTYPE_TUNNEL_IP) {
ptype_lkup[k].tunnel_type = ptype_lkup[k].tunnel_type =
IDPF_RX_PTYPE_TUNNEL_IP_GRENAT; LIBETH_RX_PT_TUNNEL_IP_GRENAT;
pstate.tunnel_state |= pstate.tunnel_state |=
IDPF_PTYPE_TUNNEL_IP_GRENAT; IDPF_PTYPE_TUNNEL_IP_GRENAT;
} }
break; break;
case VIRTCHNL2_PROTO_HDR_MAC: case VIRTCHNL2_PROTO_HDR_MAC:
ptype_lkup[k].outer_ip = ptype_lkup[k].outer_ip =
IDPF_RX_PTYPE_OUTER_L2; LIBETH_RX_PT_OUTER_L2;
if (pstate.tunnel_state == if (pstate.tunnel_state ==
IDPF_TUN_IP_GRE) { IDPF_TUN_IP_GRE) {
ptype_lkup[k].tunnel_type = ptype_lkup[k].tunnel_type =
IDPF_RX_PTYPE_TUNNEL_IP_GRENAT_MAC; LIBETH_RX_PT_TUNNEL_IP_GRENAT_MAC;
pstate.tunnel_state |= pstate.tunnel_state |=
IDPF_PTYPE_TUNNEL_IP_GRENAT_MAC; IDPF_PTYPE_TUNNEL_IP_GRENAT_MAC;
} }
...@@ -2652,23 +2669,23 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport) ...@@ -2652,23 +2669,23 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
break; break;
case VIRTCHNL2_PROTO_HDR_UDP: case VIRTCHNL2_PROTO_HDR_UDP:
ptype_lkup[k].inner_prot = ptype_lkup[k].inner_prot =
IDPF_RX_PTYPE_INNER_PROT_UDP; LIBETH_RX_PT_INNER_UDP;
break; break;
case VIRTCHNL2_PROTO_HDR_TCP: case VIRTCHNL2_PROTO_HDR_TCP:
ptype_lkup[k].inner_prot = ptype_lkup[k].inner_prot =
IDPF_RX_PTYPE_INNER_PROT_TCP; LIBETH_RX_PT_INNER_TCP;
break; break;
case VIRTCHNL2_PROTO_HDR_SCTP: case VIRTCHNL2_PROTO_HDR_SCTP:
ptype_lkup[k].inner_prot = ptype_lkup[k].inner_prot =
IDPF_RX_PTYPE_INNER_PROT_SCTP; LIBETH_RX_PT_INNER_SCTP;
break; break;
case VIRTCHNL2_PROTO_HDR_ICMP: case VIRTCHNL2_PROTO_HDR_ICMP:
ptype_lkup[k].inner_prot = ptype_lkup[k].inner_prot =
IDPF_RX_PTYPE_INNER_PROT_ICMP; LIBETH_RX_PT_INNER_ICMP;
break; break;
case VIRTCHNL2_PROTO_HDR_PAY: case VIRTCHNL2_PROTO_HDR_PAY:
ptype_lkup[k].payload_layer = ptype_lkup[k].payload_layer =
IDPF_RX_PTYPE_PAYLOAD_LAYER_PAY2; LIBETH_RX_PT_PAYLOAD_L2;
break; break;
case VIRTCHNL2_PROTO_HDR_ICMPV6: case VIRTCHNL2_PROTO_HDR_ICMPV6:
case VIRTCHNL2_PROTO_HDR_IPV6_EH: case VIRTCHNL2_PROTO_HDR_IPV6_EH:
...@@ -2722,9 +2739,14 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport) ...@@ -2722,9 +2739,14 @@ int idpf_send_get_rx_ptype_msg(struct idpf_vport *vport)
break; break;
} }
} }
idpf_finalize_ptype_lookup(&ptype_lkup[k]);
} }
} }
out:
vport->rx_ptype_lkup = no_free_ptr(ptype_lkup);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment