|  | // SPDX-License-Identifier: GPL-2.0-only | 
|  | /* Copyright (C) 2024 Intel Corporation */ | 
|  |  | 
|  | #include <linux/net/intel/libie/rx.h> | 
|  |  | 
|  | /* O(1) converting i40e/ice/iavf's 8/10-bit hardware packet type to a parsed | 
|  | * bitfield struct. | 
|  | */ | 
|  |  | 
|  | /* A few supplementary definitions for when XDP hash types do not coincide | 
|  | * with what can be generated from ptype definitions by means of preprocessor | 
|  | * concatenation. | 
|  | */ | 
|  | #define XDP_RSS_L3_L2			XDP_RSS_TYPE_NONE | 
|  | #define XDP_RSS_L4_NONE			XDP_RSS_TYPE_NONE | 
|  | #define XDP_RSS_L4_TIMESYNC		XDP_RSS_TYPE_NONE | 
|  | #define XDP_RSS_TYPE_L3			XDP_RSS_TYPE_NONE | 
|  | #define XDP_RSS_TYPE_L4			XDP_RSS_L4 | 
|  |  | 
|  | #define LIBIE_RX_PT(oip, ofrag, tun, tp, tefr, iprot, pl) {		   \ | 
|  | .outer_ip		= LIBETH_RX_PT_OUTER_##oip,	   \ | 
|  | .outer_frag		= LIBETH_RX_PT_##ofrag,		   \ | 
|  | .tunnel_type		= LIBETH_RX_PT_TUNNEL_IP_##tun,	   \ | 
|  | .tunnel_end_prot	= LIBETH_RX_PT_TUNNEL_END_##tp,	   \ | 
|  | .tunnel_end_frag	= LIBETH_RX_PT_##tefr,		   \ | 
|  | .inner_prot		= LIBETH_RX_PT_INNER_##iprot,	   \ | 
|  | .payload_layer		= LIBETH_RX_PT_PAYLOAD_##pl,	   \ | 
|  | .hash_type		= XDP_RSS_L3_##oip |		   \ | 
|  | XDP_RSS_L4_##iprot |		   \ | 
|  | XDP_RSS_TYPE_##pl,		   \ | 
|  | } | 
|  |  | 
|  | #define LIBIE_RX_PT_UNUSED		{ } | 
|  |  | 
|  | #define __LIBIE_RX_PT_L2(iprot, pl)					   \ | 
|  | LIBIE_RX_PT(L2, NOT_FRAG, NONE, NONE, NOT_FRAG, iprot, pl) | 
|  | #define LIBIE_RX_PT_L2		__LIBIE_RX_PT_L2(NONE, L2) | 
|  | #define LIBIE_RX_PT_TS		__LIBIE_RX_PT_L2(TIMESYNC, L2) | 
|  | #define LIBIE_RX_PT_L3		__LIBIE_RX_PT_L2(NONE, L3) | 
|  |  | 
|  | #define LIBIE_RX_PT_IP_FRAG(oip)					   \ | 
|  | LIBIE_RX_PT(IPV##oip, FRAG, NONE, NONE, NOT_FRAG, NONE, L3) | 
|  | #define LIBIE_RX_PT_IP_L3(oip, tun, teprot, tefr)			   \ | 
|  | LIBIE_RX_PT(IPV##oip, NOT_FRAG, tun, teprot, tefr, NONE, L3) | 
|  | #define LIBIE_RX_PT_IP_L4(oip, tun, teprot, iprot)			   \ | 
|  | LIBIE_RX_PT(IPV##oip, NOT_FRAG, tun, teprot, NOT_FRAG, iprot, L4) | 
|  |  | 
|  | #define LIBIE_RX_PT_IP_NOF(oip, tun, ver)				   \ | 
|  | LIBIE_RX_PT_IP_L3(oip, tun, ver, NOT_FRAG),			   \ | 
|  | LIBIE_RX_PT_IP_L4(oip, tun, ver, UDP),				   \ | 
|  | LIBIE_RX_PT_UNUSED,						   \ | 
|  | LIBIE_RX_PT_IP_L4(oip, tun, ver, TCP),				   \ | 
|  | LIBIE_RX_PT_IP_L4(oip, tun, ver, SCTP),				   \ | 
|  | LIBIE_RX_PT_IP_L4(oip, tun, ver, ICMP) | 
|  |  | 
|  | /* IPv oip --> tun --> IPv ver */ | 
|  | #define LIBIE_RX_PT_IP_TUN_VER(oip, tun, ver)				   \ | 
|  | LIBIE_RX_PT_IP_L3(oip, tun, ver, FRAG),				   \ | 
|  | LIBIE_RX_PT_IP_NOF(oip, tun, ver) | 
|  |  | 
|  | /* Non Tunneled IPv oip */ | 
|  | #define LIBIE_RX_PT_IP_RAW(oip)						   \ | 
|  | LIBIE_RX_PT_IP_FRAG(oip),					   \ | 
|  | LIBIE_RX_PT_IP_NOF(oip, NONE, NONE) | 
|  |  | 
|  | /* IPv oip --> tun --> { IPv4, IPv6 } */ | 
|  | #define LIBIE_RX_PT_IP_TUN(oip, tun)					   \ | 
|  | LIBIE_RX_PT_IP_TUN_VER(oip, tun, IPV4),				   \ | 
|  | LIBIE_RX_PT_IP_TUN_VER(oip, tun, IPV6) | 
|  |  | 
|  | /* IPv oip --> GRE/NAT tun --> { x, IPv4, IPv6 } */ | 
|  | #define LIBIE_RX_PT_IP_GRE(oip, tun)					   \ | 
|  | LIBIE_RX_PT_IP_L3(oip, tun, NONE, NOT_FRAG),			   \ | 
|  | LIBIE_RX_PT_IP_TUN(oip, tun) | 
|  |  | 
|  | /* Non Tunneled IPv oip | 
|  | * IPv oip --> { IPv4, IPv6 } | 
|  | * IPv oip --> GRE/NAT --> { x, IPv4, IPv6 } | 
|  | * IPv oip --> GRE/NAT --> MAC --> { x, IPv4, IPv6 } | 
|  | * IPv oip --> GRE/NAT --> MAC/VLAN --> { x, IPv4, IPv6 } | 
|  | */ | 
|  | #define LIBIE_RX_PT_IP(oip)						   \ | 
|  | LIBIE_RX_PT_IP_RAW(oip),					   \ | 
|  | LIBIE_RX_PT_IP_TUN(oip, IP),					   \ | 
|  | LIBIE_RX_PT_IP_GRE(oip, GRENAT),				   \ | 
|  | LIBIE_RX_PT_IP_GRE(oip, GRENAT_MAC),				   \ | 
|  | LIBIE_RX_PT_IP_GRE(oip, GRENAT_MAC_VLAN) | 
|  |  | 
|  | /* Lookup table mapping for O(1) parsing */ | 
|  | const struct libeth_rx_pt libie_rx_pt_lut[LIBIE_RX_PT_NUM] = { | 
|  | /* L2 packet types */ | 
|  | LIBIE_RX_PT_UNUSED, | 
|  | LIBIE_RX_PT_L2, | 
|  | LIBIE_RX_PT_TS, | 
|  | LIBIE_RX_PT_L2, | 
|  | LIBIE_RX_PT_UNUSED, | 
|  | LIBIE_RX_PT_UNUSED, | 
|  | LIBIE_RX_PT_L2, | 
|  | LIBIE_RX_PT_L2, | 
|  | LIBIE_RX_PT_UNUSED, | 
|  | LIBIE_RX_PT_UNUSED, | 
|  | LIBIE_RX_PT_L2, | 
|  | LIBIE_RX_PT_UNUSED, | 
|  |  | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  | LIBIE_RX_PT_L3, | 
|  |  | 
|  | LIBIE_RX_PT_IP(4), | 
|  | LIBIE_RX_PT_IP(6), | 
|  | }; | 
|  | EXPORT_SYMBOL_NS_GPL(libie_rx_pt_lut, LIBIE); | 
|  |  | 
|  | MODULE_DESCRIPTION("Intel(R) Ethernet common library"); | 
|  | MODULE_IMPORT_NS(LIBETH); | 
|  | MODULE_LICENSE("GPL"); |