610bc231d0
RSS for GTP with outer & inner ipv4 & ipv6 combination are supported in this patch, so that we can process RSS based on inner 5 tuples or 3 tuples of all the cases below of GTP packets: 1. ipv4 (outer) + ipv4 (inner) 2. ipv4 (outer) + ipv6 (inner) 3. ipv6 (outer) + ipv4 (inner) 4. ipv6 (outer) + ipv6 (inner) Signed-off-by: Junfeng Guo <junfeng.guo@intel.com> Acked-by: Qi Zhang <qi.z.zhang@intel.com>
604 lines
24 KiB
C
604 lines
24 KiB
C
/* SPDX-License-Identifier: BSD-3-Clause
|
|
* Copyright(c) 2019 Intel Corporation
|
|
*/
|
|
|
|
#ifndef _ICE_GENERIC_FLOW_H_
|
|
#define _ICE_GENERIC_FLOW_H_
|
|
|
|
#include <rte_flow_driver.h>
|
|
|
|
/* protocol */
|
|
|
|
#define ICE_PROT_MAC_INNER (1ULL << 1)
|
|
#define ICE_PROT_MAC_OUTER (1ULL << 2)
|
|
#define ICE_PROT_VLAN_INNER (1ULL << 3)
|
|
#define ICE_PROT_VLAN_OUTER (1ULL << 4)
|
|
#define ICE_PROT_IPV4_INNER (1ULL << 5)
|
|
#define ICE_PROT_IPV4_OUTER (1ULL << 6)
|
|
#define ICE_PROT_IPV6_INNER (1ULL << 7)
|
|
#define ICE_PROT_IPV6_OUTER (1ULL << 8)
|
|
#define ICE_PROT_TCP_INNER (1ULL << 9)
|
|
#define ICE_PROT_TCP_OUTER (1ULL << 10)
|
|
#define ICE_PROT_UDP_INNER (1ULL << 11)
|
|
#define ICE_PROT_UDP_OUTER (1ULL << 12)
|
|
#define ICE_PROT_SCTP_INNER (1ULL << 13)
|
|
#define ICE_PROT_SCTP_OUTER (1ULL << 14)
|
|
#define ICE_PROT_ICMP4_INNER (1ULL << 15)
|
|
#define ICE_PROT_ICMP4_OUTER (1ULL << 16)
|
|
#define ICE_PROT_ICMP6_INNER (1ULL << 17)
|
|
#define ICE_PROT_ICMP6_OUTER (1ULL << 18)
|
|
#define ICE_PROT_VXLAN (1ULL << 19)
|
|
#define ICE_PROT_NVGRE (1ULL << 20)
|
|
#define ICE_PROT_GTPU (1ULL << 21)
|
|
#define ICE_PROT_PPPOE_S (1ULL << 22)
|
|
#define ICE_PROT_ESP (1ULL << 23)
|
|
#define ICE_PROT_AH (1ULL << 24)
|
|
#define ICE_PROT_L2TPV3OIP (1ULL << 25)
|
|
#define ICE_PROT_PFCP (1ULL << 26)
|
|
|
|
/* field */
|
|
|
|
#define ICE_SMAC (1ULL << 63)
|
|
#define ICE_DMAC (1ULL << 62)
|
|
#define ICE_ETHERTYPE (1ULL << 61)
|
|
#define ICE_IP_SRC (1ULL << 60)
|
|
#define ICE_IP_DST (1ULL << 59)
|
|
#define ICE_IP_PROTO (1ULL << 58)
|
|
#define ICE_IP_TTL (1ULL << 57)
|
|
#define ICE_IP_TOS (1ULL << 56)
|
|
#define ICE_SPORT (1ULL << 55)
|
|
#define ICE_DPORT (1ULL << 54)
|
|
#define ICE_ICMP_TYPE (1ULL << 53)
|
|
#define ICE_ICMP_CODE (1ULL << 52)
|
|
#define ICE_VXLAN_VNI (1ULL << 51)
|
|
#define ICE_NVGRE_TNI (1ULL << 50)
|
|
#define ICE_GTPU_TEID (1ULL << 49)
|
|
#define ICE_GTPU_QFI (1ULL << 48)
|
|
#define ICE_PPPOE_SESSION (1ULL << 47)
|
|
#define ICE_PPPOE_PROTO (1ULL << 46)
|
|
#define ICE_ESP_SPI (1ULL << 45)
|
|
#define ICE_AH_SPI (1ULL << 44)
|
|
#define ICE_L2TPV3OIP_SESSION_ID (1ULL << 43)
|
|
#define ICE_PFCP_SEID (1ULL << 42)
|
|
#define ICE_PFCP_S_FIELD (1ULL << 41)
|
|
|
|
/* input set */
|
|
|
|
#define ICE_INSET_NONE 0ULL
|
|
|
|
/* non-tunnel */
|
|
|
|
#define ICE_INSET_SMAC (ICE_PROT_MAC_OUTER | ICE_SMAC)
|
|
#define ICE_INSET_DMAC (ICE_PROT_MAC_OUTER | ICE_DMAC)
|
|
#define ICE_INSET_VLAN_INNER (ICE_PROT_VLAN_INNER)
|
|
#define ICE_INSET_VLAN_OUTER (ICE_PROT_VLAN_OUTER)
|
|
#define ICE_INSET_ETHERTYPE (ICE_ETHERTYPE)
|
|
|
|
#define ICE_INSET_IPV4_SRC \
|
|
(ICE_PROT_IPV4_OUTER | ICE_IP_SRC)
|
|
#define ICE_INSET_IPV4_DST \
|
|
(ICE_PROT_IPV4_OUTER | ICE_IP_DST)
|
|
#define ICE_INSET_IPV4_TOS \
|
|
(ICE_PROT_IPV4_OUTER | ICE_IP_TOS)
|
|
#define ICE_INSET_IPV4_PROTO \
|
|
(ICE_PROT_IPV4_OUTER | ICE_IP_PROTO)
|
|
#define ICE_INSET_IPV4_TTL \
|
|
(ICE_PROT_IPV4_OUTER | ICE_IP_TTL)
|
|
#define ICE_INSET_IPV6_SRC \
|
|
(ICE_PROT_IPV6_OUTER | ICE_IP_SRC)
|
|
#define ICE_INSET_IPV6_DST \
|
|
(ICE_PROT_IPV6_OUTER | ICE_IP_DST)
|
|
#define ICE_INSET_IPV6_NEXT_HDR \
|
|
(ICE_PROT_IPV6_OUTER | ICE_IP_PROTO)
|
|
#define ICE_INSET_IPV6_HOP_LIMIT \
|
|
(ICE_PROT_IPV6_OUTER | ICE_IP_TTL)
|
|
#define ICE_INSET_IPV6_TC \
|
|
(ICE_PROT_IPV6_OUTER | ICE_IP_TOS)
|
|
|
|
#define ICE_INSET_TCP_SRC_PORT \
|
|
(ICE_PROT_TCP_OUTER | ICE_SPORT)
|
|
#define ICE_INSET_TCP_DST_PORT \
|
|
(ICE_PROT_TCP_OUTER | ICE_DPORT)
|
|
#define ICE_INSET_UDP_SRC_PORT \
|
|
(ICE_PROT_UDP_OUTER | ICE_SPORT)
|
|
#define ICE_INSET_UDP_DST_PORT \
|
|
(ICE_PROT_UDP_OUTER | ICE_DPORT)
|
|
#define ICE_INSET_SCTP_SRC_PORT \
|
|
(ICE_PROT_SCTP_OUTER | ICE_SPORT)
|
|
#define ICE_INSET_SCTP_DST_PORT \
|
|
(ICE_PROT_SCTP_OUTER | ICE_DPORT)
|
|
#define ICE_INSET_ICMP4_SRC_PORT \
|
|
(ICE_PROT_ICMP4_OUTER | ICE_SPORT)
|
|
#define ICE_INSET_ICMP4_DST_PORT \
|
|
(ICE_PROT_ICMP4_OUTER | ICE_DPORT)
|
|
#define ICE_INSET_ICMP6_SRC_PORT \
|
|
(ICE_PROT_ICMP6_OUTER | ICE_SPORT)
|
|
#define ICE_INSET_ICMP6_DST_PORT \
|
|
(ICE_PROT_ICMP6_OUTER | ICE_DPORT)
|
|
#define ICE_INSET_ICMP4_TYPE \
|
|
(ICE_PROT_ICMP4_OUTER | ICE_ICMP_TYPE)
|
|
#define ICE_INSET_ICMP4_CODE \
|
|
(ICE_PROT_ICMP4_OUTER | ICE_ICMP_CODE)
|
|
#define ICE_INSET_ICMP6_TYPE \
|
|
(ICE_PROT_ICMP6_OUTER | ICE_ICMP_TYPE)
|
|
#define ICE_INSET_ICMP6_CODE \
|
|
(ICE_PROT_ICMP6_OUTER | ICE_ICMP_CODE)
|
|
|
|
/* tunnel */
|
|
|
|
#define ICE_INSET_TUN_SMAC \
|
|
(ICE_PROT_MAC_INNER | ICE_SMAC)
|
|
#define ICE_INSET_TUN_DMAC \
|
|
(ICE_PROT_MAC_INNER | ICE_DMAC)
|
|
|
|
#define ICE_INSET_TUN_IPV4_SRC \
|
|
(ICE_PROT_IPV4_INNER | ICE_IP_SRC)
|
|
#define ICE_INSET_TUN_IPV4_DST \
|
|
(ICE_PROT_IPV4_INNER | ICE_IP_DST)
|
|
#define ICE_INSET_TUN_IPV4_TTL \
|
|
(ICE_PROT_IPV4_INNER | ICE_IP_TTL)
|
|
#define ICE_INSET_TUN_IPV4_PROTO \
|
|
(ICE_PROT_IPV4_INNER | ICE_IP_PROTO)
|
|
#define ICE_INSET_TUN_IPV4_TOS \
|
|
(ICE_PROT_IPV4_INNER | ICE_IP_TOS)
|
|
#define ICE_INSET_TUN_IPV6_SRC \
|
|
(ICE_PROT_IPV6_INNER | ICE_IP_SRC)
|
|
#define ICE_INSET_TUN_IPV6_DST \
|
|
(ICE_PROT_IPV6_INNER | ICE_IP_DST)
|
|
#define ICE_INSET_TUN_IPV6_HOP_LIMIT \
|
|
(ICE_PROT_IPV6_INNER | ICE_IP_TTL)
|
|
#define ICE_INSET_TUN_IPV6_NEXT_HDR \
|
|
(ICE_PROT_IPV6_INNER | ICE_IP_PROTO)
|
|
#define ICE_INSET_TUN_IPV6_TC \
|
|
(ICE_PROT_IPV6_INNER | ICE_IP_TOS)
|
|
|
|
#define ICE_INSET_TUN_TCP_SRC_PORT \
|
|
(ICE_PROT_TCP_INNER | ICE_SPORT)
|
|
#define ICE_INSET_TUN_TCP_DST_PORT \
|
|
(ICE_PROT_TCP_INNER | ICE_DPORT)
|
|
#define ICE_INSET_TUN_UDP_SRC_PORT \
|
|
(ICE_PROT_UDP_INNER | ICE_SPORT)
|
|
#define ICE_INSET_TUN_UDP_DST_PORT \
|
|
(ICE_PROT_UDP_INNER | ICE_DPORT)
|
|
#define ICE_INSET_TUN_SCTP_SRC_PORT \
|
|
(ICE_PROT_SCTP_INNER | ICE_SPORT)
|
|
#define ICE_INSET_TUN_SCTP_DST_PORT \
|
|
(ICE_PROT_SCTP_INNER | ICE_DPORT)
|
|
#define ICE_INSET_TUN_ICMP4_SRC_PORT \
|
|
(ICE_PROT_ICMP4_INNER | ICE_SPORT)
|
|
#define ICE_INSET_TUN_ICMP4_DST_PORT \
|
|
(ICE_PROT_ICMP4_INNER | ICE_DPORT)
|
|
#define ICE_INSET_TUN_ICMP6_SRC_PORT \
|
|
(ICE_PROT_ICMP6_INNER | ICE_SPORT)
|
|
#define ICE_INSET_TUN_ICMP6_DST_PORT \
|
|
(ICE_PROT_ICMP6_INNER | ICE_DPORT)
|
|
#define ICE_INSET_TUN_ICMP4_TYPE \
|
|
(ICE_PROT_ICMP4_INNER | ICE_ICMP_TYPE)
|
|
#define ICE_INSET_TUN_ICMP4_CODE \
|
|
(ICE_PROT_ICMP4_INNER | ICE_ICMP_CODE)
|
|
#define ICE_INSET_TUN_ICMP6_TYPE \
|
|
(ICE_PROT_ICMP6_INNER | ICE_ICMP_TYPE)
|
|
#define ICE_INSET_TUN_ICMP6_CODE \
|
|
(ICE_PROT_ICMP6_INNER | ICE_ICMP_CODE)
|
|
|
|
#define ICE_INSET_TUN_VXLAN_VNI \
|
|
(ICE_PROT_VXLAN | ICE_VXLAN_VNI)
|
|
#define ICE_INSET_TUN_NVGRE_TNI \
|
|
(ICE_PROT_NVGRE | ICE_NVGRE_TNI)
|
|
#define ICE_INSET_GTPU_TEID \
|
|
(ICE_PROT_GTPU | ICE_GTPU_TEID)
|
|
#define ICE_INSET_GTPU_QFI \
|
|
(ICE_PROT_GTPU | ICE_GTPU_QFI)
|
|
#define ICE_INSET_PPPOE_SESSION \
|
|
(ICE_PROT_PPPOE_S | ICE_PPPOE_SESSION)
|
|
#define ICE_INSET_PPPOE_PROTO \
|
|
(ICE_PROT_PPPOE_S | ICE_PPPOE_PROTO)
|
|
#define ICE_INSET_ESP_SPI \
|
|
(ICE_PROT_ESP | ICE_ESP_SPI)
|
|
#define ICE_INSET_AH_SPI \
|
|
(ICE_PROT_AH | ICE_AH_SPI)
|
|
#define ICE_INSET_L2TPV3OIP_SESSION_ID \
|
|
(ICE_PROT_L2TPV3OIP | ICE_L2TPV3OIP_SESSION_ID)
|
|
#define ICE_INSET_PFCP_S_FIELD \
|
|
(ICE_PROT_PFCP | ICE_PFCP_S_FIELD)
|
|
#define ICE_INSET_PFCP_SEID \
|
|
(ICE_PROT_PFCP | ICE_PFCP_S_FIELD | ICE_PFCP_SEID)
|
|
|
|
/* empty pattern */
|
|
extern enum rte_flow_item_type pattern_empty[];
|
|
|
|
/* L2 */
|
|
extern enum rte_flow_item_type pattern_ethertype[];
|
|
extern enum rte_flow_item_type pattern_ethertype_vlan[];
|
|
extern enum rte_flow_item_type pattern_ethertype_qinq[];
|
|
|
|
/* ARP */
|
|
extern enum rte_flow_item_type pattern_eth_arp[];
|
|
|
|
/* non-tunnel IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_icmp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv4_icmp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv4_icmp[];
|
|
|
|
/* non-tunnel IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_icmp6[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_ipv6_icmp6[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_ipv6_icmp6[];
|
|
|
|
/* IPv4 VXLAN IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv4_icmp[];
|
|
|
|
/* IPv4 VXLAN MAC IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv4_icmp[];
|
|
|
|
/* IPv6 VXLAN IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv4_icmp[];
|
|
|
|
/* IPv6 VXLAN MAC IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv4_icmp[];
|
|
|
|
/* IPv4 VXLAN IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_ipv6_icmp6[];
|
|
|
|
/* IPv4 VXLAN MAC IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_vxlan_eth_ipv6_icmp6[];
|
|
|
|
/* IPv6 VXLAN IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_ipv6_icmp6[];
|
|
|
|
/* IPv6 VXLAN MAC IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_vxlan_eth_ipv6_icmp6[];
|
|
|
|
/* IPv4 NVGRE IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv4_icmp[];
|
|
|
|
/* IPv4 NVGRE MAC IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv4_icmp[];
|
|
|
|
/* IPv6 NVGRE IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv4_icmp[];
|
|
|
|
/* IPv6 NVGRE MAC IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv4_icmp[];
|
|
|
|
/* IPv4 NVGRE IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_ipv6_icmp6[];
|
|
|
|
/* IPv4 NVGRE MAC IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_nvgre_eth_ipv6_icmp6[];
|
|
|
|
/* IPv6 NVGRE IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_ipv6_icmp6[];
|
|
|
|
/* IPv6 NVGRE MAC IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_nvgre_eth_ipv6_icmp6[];
|
|
|
|
/* IPv4 GTPU (EH) */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh[];
|
|
|
|
/* IPv6 GTPU (EH) */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh[];
|
|
|
|
/* IPv4 GTPU IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv4_icmp[];
|
|
|
|
/* IPv4 GTPU IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_ipv6_icmp[];
|
|
|
|
/* IPv6 GTPU IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv4_icmp[];
|
|
|
|
/* IPv6 GTPU IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_ipv6_icmp[];
|
|
|
|
/* IPv4 GTPU EH IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv4_icmp[];
|
|
|
|
/* IPv4 GTPU EH IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_gtpu_eh_ipv6_icmp[];
|
|
|
|
/* IPv6 GTPU EH IPv4 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv4_icmp[];
|
|
|
|
/* IPv6 GTPU EH IPv6 */
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_gtpu_eh_ipv6_icmp[];
|
|
|
|
/* PPPoE */
|
|
extern enum rte_flow_item_type pattern_eth_pppoed[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoed[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoed[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_proto[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_proto[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv4_icmp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv4_icmp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv4_icmp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_udp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_tcp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_sctp[];
|
|
extern enum rte_flow_item_type pattern_eth_pppoes_ipv6_icmp6[];
|
|
extern enum rte_flow_item_type pattern_eth_vlan_pppoes_ipv6_icmp6[];
|
|
extern enum rte_flow_item_type pattern_eth_qinq_pppoes_ipv6_icmp6[];
|
|
|
|
/* ESP */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_esp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_udp_esp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_esp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_esp[];
|
|
|
|
/* AH */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_ah[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_ah[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_udp_ah[];
|
|
|
|
/* L2TP */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_l2tp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_l2tp[];
|
|
|
|
/* PFCP */
|
|
extern enum rte_flow_item_type pattern_eth_ipv4_pfcp[];
|
|
extern enum rte_flow_item_type pattern_eth_ipv6_pfcp[];
|
|
|
|
struct ice_adapter;
|
|
|
|
extern const struct rte_flow_ops ice_flow_ops;
|
|
|
|
/* engine types. */
|
|
enum ice_flow_engine_type {
|
|
ICE_FLOW_ENGINE_NONE = 0,
|
|
ICE_FLOW_ENGINE_FDIR,
|
|
ICE_FLOW_ENGINE_SWITCH,
|
|
ICE_FLOW_ENGINE_HASH,
|
|
ICE_FLOW_ENGINE_ACL,
|
|
ICE_FLOW_ENGINE_MAX,
|
|
};
|
|
|
|
/**
|
|
* classification stages.
|
|
* for non-pipeline mode, we have two classification stages: Distributor/RSS
|
|
* for pipeline-mode we have three classification stages:
|
|
* Permission/Distributor/RSS
|
|
*/
|
|
enum ice_flow_classification_stage {
|
|
ICE_FLOW_STAGE_NONE = 0,
|
|
ICE_FLOW_STAGE_RSS,
|
|
ICE_FLOW_STAGE_PERMISSION,
|
|
ICE_FLOW_STAGE_DISTRIBUTOR,
|
|
ICE_FLOW_STAGE_MAX,
|
|
};
|
|
/* pattern structure */
|
|
struct ice_pattern_match_item {
|
|
enum rte_flow_item_type *pattern_list;
|
|
/* pattern_list must end with RTE_FLOW_ITEM_TYPE_END */
|
|
uint64_t input_set_mask;
|
|
void *meta;
|
|
};
|
|
|
|
enum ice_flow_redirect_type {
|
|
ICE_FLOW_REDIRECT_VSI,
|
|
};
|
|
|
|
struct ice_flow_redirect {
|
|
enum ice_flow_redirect_type type;
|
|
union {
|
|
struct {
|
|
uint16_t vsi_handle;
|
|
uint16_t new_vsi_num;
|
|
};
|
|
};
|
|
};
|
|
|
|
typedef int (*engine_init_t)(struct ice_adapter *ad);
|
|
typedef void (*engine_uninit_t)(struct ice_adapter *ad);
|
|
typedef int (*engine_create_t)(struct ice_adapter *ad,
|
|
struct rte_flow *flow,
|
|
void *meta,
|
|
struct rte_flow_error *error);
|
|
typedef int (*engine_destroy_t)(struct ice_adapter *ad,
|
|
struct rte_flow *flow,
|
|
struct rte_flow_error *error);
|
|
typedef int (*engine_query_t)(struct ice_adapter *ad,
|
|
struct rte_flow *flow,
|
|
struct rte_flow_query_count *count,
|
|
struct rte_flow_error *error);
|
|
typedef int(*engine_redirect_t)(struct ice_adapter *ad,
|
|
struct rte_flow *flow,
|
|
struct ice_flow_redirect *redirect);
|
|
typedef void (*engine_free_t) (struct rte_flow *flow);
|
|
typedef int (*parse_pattern_action_t)(struct ice_adapter *ad,
|
|
struct ice_pattern_match_item *array,
|
|
uint32_t array_len,
|
|
const struct rte_flow_item pattern[],
|
|
const struct rte_flow_action actions[],
|
|
void **meta,
|
|
struct rte_flow_error *error);
|
|
|
|
/* Struct to store engine created. */
|
|
struct ice_flow_engine {
|
|
TAILQ_ENTRY(ice_flow_engine) node;
|
|
engine_init_t init;
|
|
engine_uninit_t uninit;
|
|
engine_create_t create;
|
|
engine_destroy_t destroy;
|
|
engine_query_t query_count;
|
|
engine_redirect_t redirect;
|
|
engine_free_t free;
|
|
enum ice_flow_engine_type type;
|
|
};
|
|
TAILQ_HEAD(ice_engine_list, ice_flow_engine);
|
|
|
|
/* Struct to store flow created. */
|
|
struct rte_flow {
|
|
TAILQ_ENTRY(rte_flow) node;
|
|
struct ice_flow_engine *engine;
|
|
void *rule;
|
|
};
|
|
|
|
struct ice_flow_parser {
|
|
struct ice_flow_engine *engine;
|
|
struct ice_pattern_match_item *array;
|
|
uint32_t array_len;
|
|
parse_pattern_action_t parse_pattern_action;
|
|
enum ice_flow_classification_stage stage;
|
|
};
|
|
|
|
/* Struct to store parser created. */
|
|
struct ice_flow_parser_node {
|
|
TAILQ_ENTRY(ice_flow_parser_node) node;
|
|
struct ice_flow_parser *parser;
|
|
};
|
|
|
|
void ice_register_flow_engine(struct ice_flow_engine *engine);
|
|
int ice_flow_init(struct ice_adapter *ad);
|
|
void ice_flow_uninit(struct ice_adapter *ad);
|
|
int ice_register_parser(struct ice_flow_parser *parser,
|
|
struct ice_adapter *ad);
|
|
void ice_unregister_parser(struct ice_flow_parser *parser,
|
|
struct ice_adapter *ad);
|
|
struct ice_pattern_match_item *
|
|
ice_search_pattern_match_item(const struct rte_flow_item pattern[],
|
|
struct ice_pattern_match_item *array,
|
|
uint32_t array_len,
|
|
struct rte_flow_error *error);
|
|
int
|
|
ice_flow_redirect(struct ice_adapter *ad,
|
|
struct ice_flow_redirect *rd);
|
|
#endif
|