2022-09-06 04:00:10 +00:00
|
|
|
/* SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
* Copyright(C) 2021 HiSilicon Limited
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _HNS3_FLOW_H_
|
|
|
|
#define _HNS3_FLOW_H_
|
|
|
|
|
|
|
|
#include <rte_flow.h>
|
|
|
|
|
2023-09-11 06:58:14 +00:00
|
|
|
#include "hns3_fdir.h"
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
struct hns3_flow_counter {
|
|
|
|
LIST_ENTRY(hns3_flow_counter) next; /* Pointer to the next counter. */
|
|
|
|
uint32_t shared:1; /* Share counter ID with other flow rules. */
|
|
|
|
uint32_t ref_cnt:31; /* Reference counter. */
|
|
|
|
uint16_t id; /* Counter ID. */
|
|
|
|
uint64_t hits; /* Number of packets matched by the rule. */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct rte_flow {
|
|
|
|
enum rte_filter_type filter_type;
|
|
|
|
void *rule;
|
|
|
|
uint32_t counter_id;
|
|
|
|
};
|
|
|
|
|
2023-09-11 06:58:14 +00:00
|
|
|
struct hns3_flow_rss_conf {
|
|
|
|
struct rte_flow_action_rss conf;
|
|
|
|
uint8_t key[HNS3_RSS_KEY_SIZE_MAX]; /* Hash key */
|
|
|
|
uint16_t queue[HNS3_RSS_QUEUES_BUFFER_NUM]; /* Queues indices to use */
|
|
|
|
uint64_t pattern_type;
|
|
|
|
uint64_t hw_pctypes; /* packet types in driver */
|
|
|
|
};
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
/* rss filter list structure */
|
|
|
|
struct hns3_rss_conf_ele {
|
|
|
|
TAILQ_ENTRY(hns3_rss_conf_ele) entries;
|
2023-09-11 06:58:14 +00:00
|
|
|
struct hns3_flow_rss_conf filter_info;
|
2022-09-06 04:00:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* hns3_flow memory list structure */
|
|
|
|
struct hns3_flow_mem {
|
|
|
|
TAILQ_ENTRY(hns3_flow_mem) entries;
|
|
|
|
struct rte_flow *flow;
|
|
|
|
};
|
|
|
|
|
2023-09-11 06:58:14 +00:00
|
|
|
|
|
|
|
union hns3_filter_conf {
|
|
|
|
struct hns3_fdir_rule fdir_conf;
|
|
|
|
struct hns3_flow_rss_conf rss_conf;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct hns3_filter_info {
|
|
|
|
enum rte_filter_type type;
|
|
|
|
union hns3_filter_conf conf;
|
|
|
|
};
|
|
|
|
|
2022-09-06 04:00:10 +00:00
|
|
|
TAILQ_HEAD(hns3_rss_filter_list, hns3_rss_conf_ele);
|
|
|
|
TAILQ_HEAD(hns3_flow_mem_list, hns3_flow_mem);
|
|
|
|
|
|
|
|
int hns3_dev_flow_ops_get(struct rte_eth_dev *dev,
|
|
|
|
const struct rte_flow_ops **ops);
|
|
|
|
void hns3_flow_init(struct rte_eth_dev *dev);
|
|
|
|
void hns3_flow_uninit(struct rte_eth_dev *dev);
|
2023-09-11 06:58:14 +00:00
|
|
|
int hns3_restore_filter(struct hns3_adapter *hns);
|
2022-09-06 04:00:10 +00:00
|
|
|
|
|
|
|
#endif /* _HNS3_FLOW_H_ */
|