162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */
262306a36Sopenharmony_ci/* Copyright (c) 2021, Intel Corporation. */
362306a36Sopenharmony_ci
462306a36Sopenharmony_ci#ifndef _IAVF_FDIR_H_
562306a36Sopenharmony_ci#define _IAVF_FDIR_H_
662306a36Sopenharmony_ci
762306a36Sopenharmony_cistruct iavf_adapter;
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci/* State of Flow Director filter
1062306a36Sopenharmony_ci *
1162306a36Sopenharmony_ci * *_REQUEST states are used to mark filter to be sent to PF driver to perform
1262306a36Sopenharmony_ci * an action (either add or delete filter). *_PENDING states are an indication
1362306a36Sopenharmony_ci * that request was sent to PF and the driver is waiting for response.
1462306a36Sopenharmony_ci *
1562306a36Sopenharmony_ci * Both DELETE and DISABLE states are being used to delete a filter in PF.
1662306a36Sopenharmony_ci * The difference is that after a successful response filter in DEL_PENDING
1762306a36Sopenharmony_ci * state is being deleted from VF driver as well and filter in DIS_PENDING state
1862306a36Sopenharmony_ci * is being changed to INACTIVE state.
1962306a36Sopenharmony_ci */
2062306a36Sopenharmony_cienum iavf_fdir_fltr_state_t {
2162306a36Sopenharmony_ci	IAVF_FDIR_FLTR_ADD_REQUEST,	/* User requests to add filter */
2262306a36Sopenharmony_ci	IAVF_FDIR_FLTR_ADD_PENDING,	/* Filter pending add by the PF */
2362306a36Sopenharmony_ci	IAVF_FDIR_FLTR_DEL_REQUEST,	/* User requests to delete filter */
2462306a36Sopenharmony_ci	IAVF_FDIR_FLTR_DEL_PENDING,	/* Filter pending delete by the PF */
2562306a36Sopenharmony_ci	IAVF_FDIR_FLTR_DIS_REQUEST,	/* Filter scheduled to be disabled */
2662306a36Sopenharmony_ci	IAVF_FDIR_FLTR_DIS_PENDING,	/* Filter pending disable by the PF */
2762306a36Sopenharmony_ci	IAVF_FDIR_FLTR_INACTIVE,	/* Filter inactive on link down */
2862306a36Sopenharmony_ci	IAVF_FDIR_FLTR_ACTIVE,		/* Filter is active */
2962306a36Sopenharmony_ci};
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_cienum iavf_fdir_flow_type {
3262306a36Sopenharmony_ci	/* NONE - used for undef/error */
3362306a36Sopenharmony_ci	IAVF_FDIR_FLOW_NONE = 0,
3462306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV4_TCP,
3562306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV4_UDP,
3662306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV4_SCTP,
3762306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV4_AH,
3862306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV4_ESP,
3962306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV4_OTHER,
4062306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV6_TCP,
4162306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV6_UDP,
4262306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV6_SCTP,
4362306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV6_AH,
4462306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV6_ESP,
4562306a36Sopenharmony_ci	IAVF_FDIR_FLOW_IPV6_OTHER,
4662306a36Sopenharmony_ci	IAVF_FDIR_FLOW_NON_IP_L2,
4762306a36Sopenharmony_ci	/* MAX - this must be last and add anything new just above it */
4862306a36Sopenharmony_ci	IAVF_FDIR_FLOW_PTYPE_MAX,
4962306a36Sopenharmony_ci};
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci/* Must not exceed the array element number of '__be32 data[2]' in the ethtool
5262306a36Sopenharmony_ci * 'struct ethtool_rx_flow_spec.m_ext.data[2]' to express the flex-byte (word).
5362306a36Sopenharmony_ci */
5462306a36Sopenharmony_ci#define IAVF_FLEX_WORD_NUM	2
5562306a36Sopenharmony_ci
5662306a36Sopenharmony_cistruct iavf_flex_word {
5762306a36Sopenharmony_ci	u16 offset;
5862306a36Sopenharmony_ci	u16 word;
5962306a36Sopenharmony_ci};
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_cistruct iavf_ipv4_addrs {
6262306a36Sopenharmony_ci	__be32 src_ip;
6362306a36Sopenharmony_ci	__be32 dst_ip;
6462306a36Sopenharmony_ci};
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_cistruct iavf_ipv6_addrs {
6762306a36Sopenharmony_ci	struct in6_addr src_ip;
6862306a36Sopenharmony_ci	struct in6_addr dst_ip;
6962306a36Sopenharmony_ci};
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_cistruct iavf_fdir_eth {
7262306a36Sopenharmony_ci	__be16 etype;
7362306a36Sopenharmony_ci};
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_cistruct iavf_fdir_ip {
7662306a36Sopenharmony_ci	union {
7762306a36Sopenharmony_ci		struct iavf_ipv4_addrs v4_addrs;
7862306a36Sopenharmony_ci		struct iavf_ipv6_addrs v6_addrs;
7962306a36Sopenharmony_ci	};
8062306a36Sopenharmony_ci	__be16 src_port;
8162306a36Sopenharmony_ci	__be16 dst_port;
8262306a36Sopenharmony_ci	__be32 l4_header;	/* first 4 bytes of the layer 4 header */
8362306a36Sopenharmony_ci	__be32 spi;		/* security parameter index for AH/ESP */
8462306a36Sopenharmony_ci	union {
8562306a36Sopenharmony_ci		u8 tos;
8662306a36Sopenharmony_ci		u8 tclass;
8762306a36Sopenharmony_ci	};
8862306a36Sopenharmony_ci	u8 proto;
8962306a36Sopenharmony_ci};
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_cistruct iavf_fdir_extra {
9262306a36Sopenharmony_ci	u32 usr_def[IAVF_FLEX_WORD_NUM];
9362306a36Sopenharmony_ci};
9462306a36Sopenharmony_ci
9562306a36Sopenharmony_ci/* bookkeeping of Flow Director filters */
9662306a36Sopenharmony_cistruct iavf_fdir_fltr {
9762306a36Sopenharmony_ci	enum iavf_fdir_fltr_state_t state;
9862306a36Sopenharmony_ci	struct list_head list;
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci	enum iavf_fdir_flow_type flow_type;
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ci	struct iavf_fdir_eth eth_data;
10362306a36Sopenharmony_ci	struct iavf_fdir_eth eth_mask;
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_ci	struct iavf_fdir_ip ip_data;
10662306a36Sopenharmony_ci	struct iavf_fdir_ip ip_mask;
10762306a36Sopenharmony_ci
10862306a36Sopenharmony_ci	struct iavf_fdir_extra ext_data;
10962306a36Sopenharmony_ci	struct iavf_fdir_extra ext_mask;
11062306a36Sopenharmony_ci
11162306a36Sopenharmony_ci	enum virtchnl_action action;
11262306a36Sopenharmony_ci
11362306a36Sopenharmony_ci	/* flex byte filter data */
11462306a36Sopenharmony_ci	u8 ip_ver; /* used to adjust the flex offset, 4 : IPv4, 6 : IPv6 */
11562306a36Sopenharmony_ci	u8 flex_cnt;
11662306a36Sopenharmony_ci	struct iavf_flex_word flex_words[IAVF_FLEX_WORD_NUM];
11762306a36Sopenharmony_ci
11862306a36Sopenharmony_ci	u32 flow_id;
11962306a36Sopenharmony_ci
12062306a36Sopenharmony_ci	u32 loc;	/* Rule location inside the flow table */
12162306a36Sopenharmony_ci	u32 q_index;
12262306a36Sopenharmony_ci
12362306a36Sopenharmony_ci	struct virtchnl_fdir_add vc_add_msg;
12462306a36Sopenharmony_ci};
12562306a36Sopenharmony_ci
12662306a36Sopenharmony_ciint iavf_validate_fdir_fltr_masks(struct iavf_adapter *adapter,
12762306a36Sopenharmony_ci				  struct iavf_fdir_fltr *fltr);
12862306a36Sopenharmony_ciint iavf_fill_fdir_add_msg(struct iavf_adapter *adapter, struct iavf_fdir_fltr *fltr);
12962306a36Sopenharmony_civoid iavf_print_fdir_fltr(struct iavf_adapter *adapter, struct iavf_fdir_fltr *fltr);
13062306a36Sopenharmony_cibool iavf_fdir_is_dup_fltr(struct iavf_adapter *adapter, struct iavf_fdir_fltr *fltr);
13162306a36Sopenharmony_civoid iavf_fdir_list_add_fltr(struct iavf_adapter *adapter, struct iavf_fdir_fltr *fltr);
13262306a36Sopenharmony_cistruct iavf_fdir_fltr *iavf_find_fdir_fltr_by_loc(struct iavf_adapter *adapter, u32 loc);
13362306a36Sopenharmony_ci#endif /* _IAVF_FDIR_H_ */
134