02/02/2024 01:42, Suanming Mou:
> --- a/doc/guides/rel_notes/release_24_03.rst
> +++ b/doc/guides/rel_notes/release_24_03.rst
> +* **Added compare flow matching criteria.**

Suggestion:
"Added flow matching with various comparisons."
Not sure how to illustrate the idea.

> +  Added ``RTE_FLOW_ITEM_TYPE_COMPARE`` to allow matching on compare

s/compare/comparison/

> +  result between the packet fields or value.

remove "the"


> --- a/lib/ethdev/rte_flow.h
> +++ b/lib/ethdev/rte_flow.h
> +     /**
> +      * Matches the packet with compare result.

Match packet with various comparison types.

> +      *
> +      * See struct rte_flow_item_compare.
> +      */
> +     RTE_FLOW_ITEM_TYPE_COMPARE,
>  };
>  
>  /**
> @@ -2365,6 +2372,182 @@ static const struct rte_flow_item_ptype 
> rte_flow_item_ptype_mask = {
>  };
>  #endif
>  
> +/**
> + * Field IDs for packet field.
> + * e.g. the packet field IDs used in RTE_FLOW_ACTION_TYPE_MODIFY_FIELD
> + * and RTE_FLOW_ITEM_TYPE_COMPARE.
> + */
> +enum rte_flow_field_id {
> +     RTE_FLOW_FIELD_START = 0,       /**< Start of a packet. */
> +     RTE_FLOW_FIELD_MAC_DST,         /**< Destination MAC Address. */
> +     RTE_FLOW_FIELD_MAC_SRC,         /**< Source MAC Address. */
> +     RTE_FLOW_FIELD_VLAN_TYPE,       /**< VLAN Tag Identifier. */
> +     RTE_FLOW_FIELD_VLAN_ID,         /**< VLAN Identifier. */
> +     RTE_FLOW_FIELD_MAC_TYPE,        /**< EtherType. */
> +     RTE_FLOW_FIELD_IPV4_DSCP,       /**< IPv4 DSCP. */
> +     RTE_FLOW_FIELD_IPV4_TTL,        /**< IPv4 Time To Live. */
> +     RTE_FLOW_FIELD_IPV4_SRC,        /**< IPv4 Source Address. */
> +     RTE_FLOW_FIELD_IPV4_DST,        /**< IPv4 Destination Address. */
> +     RTE_FLOW_FIELD_IPV6_DSCP,       /**< IPv6 DSCP. */
> +     RTE_FLOW_FIELD_IPV6_HOPLIMIT,   /**< IPv6 Hop Limit. */
> +     RTE_FLOW_FIELD_IPV6_SRC,        /**< IPv6 Source Address. */
> +     RTE_FLOW_FIELD_IPV6_DST,        /**< IPv6 Destination Address. */
> +     RTE_FLOW_FIELD_TCP_PORT_SRC,    /**< TCP Source Port Number. */
> +     RTE_FLOW_FIELD_TCP_PORT_DST,    /**< TCP Destination Port Number. */
> +     RTE_FLOW_FIELD_TCP_SEQ_NUM,     /**< TCP Sequence Number. */
> +     RTE_FLOW_FIELD_TCP_ACK_NUM,     /**< TCP Acknowledgment Number. */
> +     RTE_FLOW_FIELD_TCP_FLAGS,       /**< TCP Flags. */
> +     RTE_FLOW_FIELD_UDP_PORT_SRC,    /**< UDP Source Port Number. */
> +     RTE_FLOW_FIELD_UDP_PORT_DST,    /**< UDP Destination Port Number. */
> +     RTE_FLOW_FIELD_VXLAN_VNI,       /**< VXLAN Network Identifier. */
> +     RTE_FLOW_FIELD_GENEVE_VNI,      /**< GENEVE Network Identifier. */
> +     RTE_FLOW_FIELD_GTP_TEID,        /**< GTP Tunnel Endpoint Identifier. */
> +     RTE_FLOW_FIELD_TAG,             /**< Tag value. */
> +     RTE_FLOW_FIELD_MARK,            /**< Mark value. */
> +     RTE_FLOW_FIELD_META,            /**< Metadata value. */
> +     RTE_FLOW_FIELD_POINTER,         /**< Memory pointer. */
> +     RTE_FLOW_FIELD_VALUE,           /**< Immediate value. */
> +     RTE_FLOW_FIELD_IPV4_ECN,        /**< IPv4 ECN. */
> +     RTE_FLOW_FIELD_IPV6_ECN,        /**< IPv6 ECN. */
> +     RTE_FLOW_FIELD_GTP_PSC_QFI,     /**< GTP QFI. */
> +     RTE_FLOW_FIELD_METER_COLOR,     /**< Meter color marker. */
> +     RTE_FLOW_FIELD_IPV6_PROTO,      /**< IPv6 next header. */
> +     RTE_FLOW_FIELD_FLEX_ITEM,       /**< Flex item. */
> +     RTE_FLOW_FIELD_HASH_RESULT,     /**< Hash result. */
> +     RTE_FLOW_FIELD_GENEVE_OPT_TYPE, /**< GENEVE option type. */
> +     RTE_FLOW_FIELD_GENEVE_OPT_CLASS,/**< GENEVE option class. */
> +     RTE_FLOW_FIELD_GENEVE_OPT_DATA, /**< GENEVE option data. */
> +     RTE_FLOW_FIELD_MPLS,            /**< MPLS header. */
> +     RTE_FLOW_FIELD_TCP_DATA_OFFSET, /**< TCP data offset. */
> +     RTE_FLOW_FIELD_IPV4_IHL,        /**< IPv4 IHL. */
> +     RTE_FLOW_FIELD_IPV4_TOTAL_LEN,  /**< IPv4 total length. */
> +     RTE_FLOW_FIELD_IPV6_PAYLOAD_LEN,/**< IPv6 payload length. */
> +     RTE_FLOW_FIELD_RANDOM           /**< Random value. */
> +};

You should use spaces for aligmnent of the comments.

[...]
> +struct rte_flow_field_data {
> +     enum rte_flow_field_id field; /**< Field or memory type ID. */
> +     union {
> +             struct {
> +                     /** Encapsulation level and tag index or flex item 
> handle. */
> +                     union {
> +                             struct {
> +                                     /**
> +                                      * Packet encapsulation level containing
> +                                      * the field to modify.
> +                                      *
> +                                      * - @p 0 requests the default behavior.
> +                                      *   Depending on the packet type, it
> +                                      *   can mean outermost, innermost or
> +                                      *   anything in between.
> +                                      *
> +                                      *   It basically stands for the
> +                                      *   innermost encapsulation level.
> +                                      *   Modification can be performed
> +                                      *   according to PMD and device
> +                                      *   capabilities.
> +                                      *
> +                                      * - @p 1 requests modification to be
> +                                      *   performed on the outermost packet
> +                                      *   encapsulation level.
> +                                      *
> +                                      * - @p 2 and subsequent values request
> +                                      *   modification to be performed on
> +                                      *   the specified inner packet
> +                                      *   encapsulation level, from
> +                                      *   outermost to innermost (lower to
> +                                      *   higher values).
> +                                      *
> +                                      * Values other than @p 0 are not
> +                                      * necessarily supported.
> +                                      *
> +                                      * @note that for MPLS field,
> +                                      * encapsulation level also include
> +                                      * tunnel since MPLS may appear in
> +                                      * outer, inner or tunnel.
> +                                      */
> +                                     uint8_t level;
> +                                     union {
> +                                             /**
> +                                              * Tag index array inside
> +                                              * encapsulation level.
> +                                              * Used for VLAN, MPLS or TAG 
> types.
> +                                              */
> +                                             uint8_t tag_index;
> +                                             /**
> +                                              * Geneve option identifier.
> +                                              * Relevant only for
> +                                              * 
> RTE_FLOW_FIELD_GENEVE_OPT_XXXX
> +                                              * modification type.
> +                                              */
> +                                             struct {
> +                                                     /**
> +                                                      * Geneve option type.
> +                                                      */
> +                                                     uint8_t type;
> +                                                     /**
> +                                                      * Geneve option class.
> +                                                      */
> +                                                     rte_be16_t class_id;
> +                                             };
> +                                     };
> +                             };
> +                             struct rte_flow_item_flex_handle *flex_handle;
> +                     };
> +                     /** Number of bits to skip from a field. */
> +                     uint32_t offset;
> +             };
> +             /**
> +              * Immediate value for RTE_FLOW_FIELD_VALUE, presented in the
> +              * same byte order and length as in relevant rte_flow_item_xxx.
> +              * The immediate source bitfield offset is inherited from
> +              * the destination's one.
> +              */
> +             uint8_t value[16];
> +             /**
> +              * Memory address for RTE_FLOW_FIELD_POINTER, memory layout
> +              * should be the same as for relevant field in the
> +              * rte_flow_item_xxx structure.
> +              */
> +             void *pvalue;
> +     };
> +};
> +
> +/**
> + * Expected operation types for compare item.
> + */
> +enum rte_flow_item_compare_op {
> +     RTE_FLOW_ITEM_COMPARE_EQ,       /* Compare result equal. */
> +     RTE_FLOW_ITEM_COMPARE_NE,       /* Compare result not equal. */
> +     RTE_FLOW_ITEM_COMPARE_LT,       /* Compare result less than. */
> +     RTE_FLOW_ITEM_COMPARE_LE,       /* Compare result less than or equal. */
> +     RTE_FLOW_ITEM_COMPARE_GT,       /* Compare result great than. */
> +     RTE_FLOW_ITEM_COMPARE_GE,       /* Compare result great than or equal. 
> */
> +};

It's a pity we cannot easily what changed because it moved.
Maybe make the move in a separate patch before changing it?


Reply via email to