devargs: add common key definition
[dpdk.git] / drivers / net / sfc / sfc_ef100_rx.c
index c1c56d0..8cde24c 100644 (file)
@@ -1,6 +1,6 @@
 /* SPDX-License-Identifier: BSD-3-Clause
  *
- * Copyright(c) 2019-2020 Xilinx, Inc.
+ * Copyright(c) 2019-2021 Xilinx, Inc.
  * Copyright(c) 2018-2019 Solarflare Communications Inc.
  *
  * This software was jointly developed between OKTET Labs (under contract
@@ -46,6 +46,9 @@
        ((_ndesc) - 1 /* head must not step on tail */ - \
         1 /* Rx error */ - 1 /* flush */)
 
+/** Invalid user mark value when the mark should be treated as unset */
+#define SFC_EF100_USER_MARK_INVALID    0
+
 struct sfc_ef100_rx_sw_desc {
        struct rte_mbuf                 *mbuf;
 };
@@ -305,7 +308,7 @@ sfc_ef100_rx_class_decode(const efx_word_t class, uint64_t *ol_flags)
                        break;
                case ESE_GZ_RH_HCLASS_L3_CLASS_IP4BAD:
                        ptype |= RTE_PTYPE_L3_IPV4_EXT_UNKNOWN;
-                       *ol_flags |= PKT_RX_EIP_CKSUM_BAD;
+                       *ol_flags |= PKT_RX_OUTER_IP_CKSUM_BAD;
                        break;
                case ESE_GZ_RH_HCLASS_L3_CLASS_IP6:
                        ptype |= RTE_PTYPE_L3_IPV6_EXT_UNKNOWN;
@@ -365,7 +368,6 @@ static const efx_rx_prefix_layout_t sfc_ef100_rx_prefix_layout = {
 
                SFC_EF100_RX_PREFIX_FIELD(LENGTH, B_FALSE),
                SFC_EF100_RX_PREFIX_FIELD(RSS_HASH_VALID, B_FALSE),
-               SFC_EF100_RX_PREFIX_FIELD(USER_FLAG, B_FALSE),
                SFC_EF100_RX_PREFIX_FIELD(CLASS, B_FALSE),
                SFC_EF100_RX_PREFIX_FIELD(RSS_HASH, B_FALSE),
                SFC_EF100_RX_PREFIX_FIELD(USER_MARK, B_FALSE),
@@ -404,12 +406,16 @@ sfc_ef100_rx_prefix_to_offloads(const struct sfc_ef100_rxq *rxq,
                                              ESF_GZ_RX_PREFIX_RSS_HASH);
        }
 
-       if ((rxq->flags & SFC_EF100_RXQ_USER_MARK) &&
-           EFX_TEST_OWORD_BIT(rx_prefix[0], ESF_GZ_RX_PREFIX_USER_FLAG_LBN)) {
-               ol_flags |= PKT_RX_FDIR_ID;
+       if (rxq->flags & SFC_EF100_RXQ_USER_MARK) {
+               uint32_t user_mark;
+
                /* EFX_OWORD_FIELD converts little-endian to CPU */
-               m->hash.fdir.hi = EFX_OWORD_FIELD(rx_prefix[0],
-                                                 ESF_GZ_RX_PREFIX_USER_MARK);
+               user_mark = EFX_OWORD_FIELD(rx_prefix[0],
+                                           ESF_GZ_RX_PREFIX_USER_MARK);
+               if (user_mark != SFC_EF100_USER_MARK_INVALID) {
+                       ol_flags |= PKT_RX_FDIR_ID;
+                       m->hash.fdir.hi = user_mark;
+               }
        }
 
        m->ol_flags = ol_flags;
@@ -794,8 +800,7 @@ sfc_ef100_rx_qstart(struct sfc_dp_rxq *dp_rxq, unsigned int evq_read_ptr,
                rxq->flags &= ~SFC_EF100_RXQ_RSS_HASH;
 
        if ((unsup_rx_prefix_fields &
-            ((1U << EFX_RX_PREFIX_FIELD_USER_FLAG) |
-             (1U << EFX_RX_PREFIX_FIELD_USER_MARK))) == 0)
+            (1U << EFX_RX_PREFIX_FIELD_USER_MARK)) == 0)
                rxq->flags |= SFC_EF100_RXQ_USER_MARK;
        else
                rxq->flags &= ~SFC_EF100_RXQ_USER_MARK;